Commit f74954f0 authored by Jan Beulich's avatar Jan Beulich Committed by Thomas Gleixner
parent 5f1d919a
...@@ -6,14 +6,19 @@ ...@@ -6,14 +6,19 @@
*/ */
#include <linux/linkage.h> #include <linux/linkage.h>
#include <asm/asm.h> #include <asm/asm.h>
#include <asm/dwarf2.h>
/* put return address in eax (arg1) */ /* put return address in eax (arg1) */
.macro THUNK name, func, put_ret_addr_in_eax=0 .macro THUNK name, func, put_ret_addr_in_eax=0
.globl \name .globl \name
\name: \name:
pushl %eax CFI_STARTPROC
pushl %ecx pushl_cfi %eax
pushl %edx CFI_REL_OFFSET eax, 0
pushl_cfi %ecx
CFI_REL_OFFSET ecx, 0
pushl_cfi %edx
CFI_REL_OFFSET edx, 0
.if \put_ret_addr_in_eax .if \put_ret_addr_in_eax
/* Place EIP in the arg1 */ /* Place EIP in the arg1 */
...@@ -21,10 +26,14 @@ ...@@ -21,10 +26,14 @@
.endif .endif
call \func call \func
popl %edx popl_cfi %edx
popl %ecx CFI_RESTORE edx
popl %eax popl_cfi %ecx
CFI_RESTORE ecx
popl_cfi %eax
CFI_RESTORE eax
ret ret
CFI_ENDPROC
_ASM_NOKPROBE(\name) _ASM_NOKPROBE(\name)
.endm .endm
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment