Steven Rostedt | 81d68a9 | 2008-05-12 21:20:42 +0200 | [diff] [blame] | 1 | /* |
| 2 | * Trampoline to trace irqs off. (otherwise CALLER_ADDR1 might crash) |
| 3 | * Copyright 2008 by Steven Rostedt, Red Hat, Inc |
| 4 | * (inspired by Andi Kleen's thunk_64.S) |
| 5 | * Subject to the GNU public license, v.2. No warranty of any kind. |
| 6 | */ |
Steven Rostedt | 81d68a9 | 2008-05-12 21:20:42 +0200 | [diff] [blame] | 7 | #include <linux/linkage.h> |
Masami Hiramatsu | 98def1d | 2014-04-17 17:17:26 +0900 | [diff] [blame] | 8 | #include <asm/asm.h> |
Steven Rostedt | 81d68a9 | 2008-05-12 21:20:42 +0200 | [diff] [blame] | 9 | |
Steven Rostedt | 81d68a9 | 2008-05-12 21:20:42 +0200 | [diff] [blame] | 10 | /* put return address in eax (arg1) */ |
Oleg Nesterov | 0ad6e3c | 2014-09-21 20:41:53 +0200 | [diff] [blame^] | 11 | .macro THUNK name, func, put_ret_addr_in_eax=0 |
Steven Rostedt | 81d68a9 | 2008-05-12 21:20:42 +0200 | [diff] [blame] | 12 | .globl \name |
| 13 | \name: |
| 14 | pushl %eax |
| 15 | pushl %ecx |
| 16 | pushl %edx |
Oleg Nesterov | 0ad6e3c | 2014-09-21 20:41:53 +0200 | [diff] [blame^] | 17 | |
| 18 | .if \put_ret_addr_in_eax |
Steven Rostedt | 81d68a9 | 2008-05-12 21:20:42 +0200 | [diff] [blame] | 19 | /* Place EIP in the arg1 */ |
| 20 | movl 3*4(%esp), %eax |
Oleg Nesterov | 0ad6e3c | 2014-09-21 20:41:53 +0200 | [diff] [blame^] | 21 | .endif |
| 22 | |
Steven Rostedt | 81d68a9 | 2008-05-12 21:20:42 +0200 | [diff] [blame] | 23 | call \func |
| 24 | popl %edx |
| 25 | popl %ecx |
| 26 | popl %eax |
| 27 | ret |
Masami Hiramatsu | 98def1d | 2014-04-17 17:17:26 +0900 | [diff] [blame] | 28 | _ASM_NOKPROBE(\name) |
Steven Rostedt | 81d68a9 | 2008-05-12 21:20:42 +0200 | [diff] [blame] | 29 | .endm |
| 30 | |
Oleg Nesterov | 0ad6e3c | 2014-09-21 20:41:53 +0200 | [diff] [blame^] | 31 | #ifdef CONFIG_TRACE_IRQFLAGS |
| 32 | THUNK trace_hardirqs_on_thunk,trace_hardirqs_on_caller,1 |
| 33 | THUNK trace_hardirqs_off_thunk,trace_hardirqs_off_caller,1 |
Steven Rostedt | 81d68a9 | 2008-05-12 21:20:42 +0200 | [diff] [blame] | 34 | #endif |
Oleg Nesterov | 0ad6e3c | 2014-09-21 20:41:53 +0200 | [diff] [blame^] | 35 | |
| 36 | #ifdef CONFIG_PREEMPT |
| 37 | THUNK ___preempt_schedule, preempt_schedule |
| 38 | #ifdef CONFIG_CONTEXT_TRACKING |
| 39 | THUNK ___preempt_schedule_context, preempt_schedule_context |
| 40 | #endif |
| 41 | #endif |
| 42 | |