mirror of
				https://github.com/python/cpython.git
				synced 2025-10-26 19:24:34 +00:00 
			
		
		
		
	 f9c18bab7f
			
		
	
	
		f9c18bab7f
		
			
		
	
	
	
	
		
			
			[3.14] gh-128605: Revert "Add branch protections for x86_64 in asm_tr…ampoline.S (GH-128606) (GH-135077)" (GH-135175) This reverts commit899cca6dbf, which broke buildbots. (cherry picked from commitb477e21d5c) Co-authored-by: Petr Viktorin <encukou@gmail.com>
		
			
				
	
	
		
			36 lines
		
	
	
	
		
			913 B
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
	
		
			913 B
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
|     .text
 | |
|     .globl	_Py_trampoline_func_start
 | |
| # The following assembly is equivalent to:
 | |
| # PyObject *
 | |
| # trampoline(PyThreadState *ts, _PyInterpreterFrame *f,
 | |
| #            int throwflag, py_evaluator evaluator)
 | |
| # {
 | |
| #     return evaluator(ts, f, throwflag);
 | |
| # }
 | |
| _Py_trampoline_func_start:
 | |
| #ifdef __x86_64__
 | |
|     sub    $8, %rsp
 | |
|     call    *%rcx
 | |
|     add    $8, %rsp
 | |
|     ret
 | |
| #endif // __x86_64__
 | |
| #if defined(__aarch64__) && defined(__AARCH64EL__) && !defined(__ILP32__)
 | |
|     // ARM64 little endian, 64bit ABI
 | |
|     // generate with aarch64-linux-gnu-gcc 12.1
 | |
|     stp     x29, x30, [sp, -16]!
 | |
|     mov     x29, sp
 | |
|     blr     x3
 | |
|     ldp     x29, x30, [sp], 16
 | |
|     ret
 | |
| #endif
 | |
| #ifdef __riscv
 | |
|     addi    sp,sp,-16
 | |
|     sd      ra,8(sp)
 | |
|     jalr    a3
 | |
|     ld      ra,8(sp)
 | |
|     addi    sp,sp,16
 | |
|     jr      ra
 | |
| #endif
 | |
|     .globl	_Py_trampoline_func_end
 | |
| _Py_trampoline_func_end:
 | |
|     .section        .note.GNU-stack,"",@progbits
 |