diff options
Diffstat (limited to 'arch/s390/kernel/mcount64.S')
-rw-r--r-- | arch/s390/kernel/mcount64.S | 30 |
1 files changed, 14 insertions, 16 deletions
diff --git a/arch/s390/kernel/mcount64.S b/arch/s390/kernel/mcount64.S index 8cf976f83a10..07abe8d464d4 100644 --- a/arch/s390/kernel/mcount64.S +++ b/arch/s390/kernel/mcount64.S | |||
@@ -16,7 +16,6 @@ ENTRY(ftrace_stub) | |||
16 | br %r14 | 16 | br %r14 |
17 | 17 | ||
18 | #define STACK_FRAME_SIZE (STACK_FRAME_OVERHEAD + __PT_SIZE) | 18 | #define STACK_FRAME_SIZE (STACK_FRAME_OVERHEAD + __PT_SIZE) |
19 | #define STACK_PARENT_IP (STACK_FRAME_SIZE + 8) | ||
20 | #define STACK_PTREGS (STACK_FRAME_OVERHEAD) | 19 | #define STACK_PTREGS (STACK_FRAME_OVERHEAD) |
21 | #define STACK_PTREGS_GPRS (STACK_PTREGS + __PT_GPRS) | 20 | #define STACK_PTREGS_GPRS (STACK_PTREGS + __PT_GPRS) |
22 | #define STACK_PTREGS_PSW (STACK_PTREGS + __PT_PSW) | 21 | #define STACK_PTREGS_PSW (STACK_PTREGS + __PT_PSW) |
@@ -31,40 +30,39 @@ ENTRY(ftrace_caller) | |||
31 | aghi %r15,-STACK_FRAME_SIZE | 30 | aghi %r15,-STACK_FRAME_SIZE |
32 | stg %r1,__SF_BACKCHAIN(%r15) | 31 | stg %r1,__SF_BACKCHAIN(%r15) |
33 | stg %r1,(STACK_PTREGS_GPRS+15*8)(%r15) | 32 | stg %r1,(STACK_PTREGS_GPRS+15*8)(%r15) |
34 | stmg %r0,%r13,STACK_PTREGS_GPRS(%r15) | 33 | stg %r0,(STACK_PTREGS_PSW+8)(%r15) |
35 | stg %r14,(STACK_PTREGS_PSW+8)(%r15) | 34 | stmg %r2,%r14,(STACK_PTREGS_GPRS+2*8)(%r15) |
36 | #ifdef CONFIG_HAVE_MARCH_Z196_FEATURES | 35 | #ifdef CONFIG_HAVE_MARCH_Z196_FEATURES |
37 | aghik %r2,%r14,-MCOUNT_INSN_SIZE | 36 | aghik %r2,%r0,-MCOUNT_INSN_SIZE |
38 | lgrl %r4,function_trace_op | 37 | lgrl %r4,function_trace_op |
39 | lgrl %r14,ftrace_trace_function | 38 | lgrl %r1,ftrace_trace_function |
40 | #else | 39 | #else |
41 | lgr %r2,%r14 | 40 | lgr %r2,%r0 |
42 | aghi %r2,-MCOUNT_INSN_SIZE | 41 | aghi %r2,-MCOUNT_INSN_SIZE |
43 | larl %r4,function_trace_op | 42 | larl %r4,function_trace_op |
44 | lg %r4,0(%r4) | 43 | lg %r4,0(%r4) |
45 | larl %r14,ftrace_trace_function | 44 | larl %r1,ftrace_trace_function |
46 | lg %r14,0(%r14) | 45 | lg %r1,0(%r1) |
47 | #endif | 46 | #endif |
48 | lg %r3,STACK_PARENT_IP(%r15) | 47 | lgr %r3,%r14 |
49 | la %r5,STACK_PTREGS(%r15) | 48 | la %r5,STACK_PTREGS(%r15) |
50 | basr %r14,%r14 | 49 | basr %r14,%r1 |
51 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | 50 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER |
52 | # The j instruction gets runtime patched to a nop instruction. | 51 | # The j instruction gets runtime patched to a nop instruction. |
53 | # See ftrace_enable_ftrace_graph_caller. The patched instruction is: | 52 | # See ftrace_enable_ftrace_graph_caller. The patched instruction is: |
54 | # j .+4 | 53 | # j .+4 |
55 | ENTRY(ftrace_graph_caller) | 54 | ENTRY(ftrace_graph_caller) |
56 | j ftrace_graph_caller_end | 55 | j ftrace_graph_caller_end |
57 | lg %r2,STACK_PARENT_IP(%r15) | 56 | lg %r2,(STACK_PTREGS_GPRS+14*8)(%r15) |
58 | lg %r3,(STACK_PTREGS_PSW+8)(%r15) | 57 | lg %r3,(STACK_PTREGS_PSW+8)(%r15) |
59 | brasl %r14,prepare_ftrace_return | 58 | brasl %r14,prepare_ftrace_return |
60 | stg %r2,STACK_PARENT_IP(%r15) | 59 | stg %r2,(STACK_PTREGS_GPRS+14*8)(%r15) |
61 | ftrace_graph_caller_end: | 60 | ftrace_graph_caller_end: |
62 | .globl ftrace_graph_caller_end | 61 | .globl ftrace_graph_caller_end |
63 | #endif | 62 | #endif |
64 | lmg %r0,%r13,STACK_PTREGS_GPRS(%r15) | 63 | lg %r1,(STACK_PTREGS_PSW+8)(%r15) |
65 | lg %r14,(STACK_PTREGS_PSW+8)(%r15) | 64 | lmg %r2,%r15,(STACK_PTREGS_GPRS+2*8)(%r15) |
66 | aghi %r15,STACK_FRAME_SIZE | 65 | br %r1 |
67 | br %r14 | ||
68 | 66 | ||
69 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | 67 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER |
70 | 68 | ||