diff options
| -rw-r--r-- | arch/mips/kernel/ftrace.c | 21 | ||||
| -rw-r--r-- | arch/mips/kernel/mcount.S | 14 |
2 files changed, 33 insertions, 2 deletions
diff --git a/arch/mips/kernel/ftrace.c b/arch/mips/kernel/ftrace.c index 65a3f8a89927..e981a497c98f 100644 --- a/arch/mips/kernel/ftrace.c +++ b/arch/mips/kernel/ftrace.c | |||
| @@ -115,6 +115,27 @@ int __init ftrace_dyn_arch_init(void *data) | |||
| 115 | 115 | ||
| 116 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | 116 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER |
| 117 | 117 | ||
| 118 | #ifdef CONFIG_DYNAMIC_FTRACE | ||
| 119 | |||
| 120 | extern void ftrace_graph_call(void); | ||
| 121 | #define JMP 0x08000000 /* jump to target directly */ | ||
| 122 | #define CALL_FTRACE_GRAPH_CALLER \ | ||
| 123 | jump_insn_encode(JMP, (unsigned long)(&ftrace_graph_caller)) | ||
| 124 | #define FTRACE_GRAPH_CALL_IP ((unsigned long)(&ftrace_graph_call)) | ||
| 125 | |||
| 126 | int ftrace_enable_ftrace_graph_caller(void) | ||
| 127 | { | ||
| 128 | return ftrace_modify_code(FTRACE_GRAPH_CALL_IP, | ||
| 129 | CALL_FTRACE_GRAPH_CALLER); | ||
| 130 | } | ||
| 131 | |||
| 132 | int ftrace_disable_ftrace_graph_caller(void) | ||
| 133 | { | ||
| 134 | return ftrace_modify_code(FTRACE_GRAPH_CALL_IP, ftrace_nop); | ||
| 135 | } | ||
| 136 | |||
| 137 | #endif /* !CONFIG_DYNAMIC_FTRACE */ | ||
| 138 | |||
| 118 | #define S_RA_SP (0xafbf << 16) /* s{d,w} ra, offset(sp) */ | 139 | #define S_RA_SP (0xafbf << 16) /* s{d,w} ra, offset(sp) */ |
| 119 | #define S_R_SP (0xafb0 << 16) /* s{d,w} R, offset(sp) */ | 140 | #define S_R_SP (0xafb0 << 16) /* s{d,w} R, offset(sp) */ |
| 120 | #define OFFSET_MASK 0xffff /* stack offset range: 0 ~ PT_SIZE */ | 141 | #define OFFSET_MASK 0xffff /* stack offset range: 0 ~ PT_SIZE */ |
diff --git a/arch/mips/kernel/mcount.S b/arch/mips/kernel/mcount.S index b50e38d828c4..98d469032506 100644 --- a/arch/mips/kernel/mcount.S +++ b/arch/mips/kernel/mcount.S | |||
| @@ -77,6 +77,13 @@ ftrace_call: | |||
| 77 | nop /* a placeholder for the call to a real tracing function */ | 77 | nop /* a placeholder for the call to a real tracing function */ |
| 78 | move a1, AT /* arg2: the caller's next ip, parent */ | 78 | move a1, AT /* arg2: the caller's next ip, parent */ |
| 79 | 79 | ||
| 80 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | ||
| 81 | .globl ftrace_graph_call | ||
| 82 | ftrace_graph_call: | ||
| 83 | nop | ||
| 84 | nop | ||
| 85 | #endif | ||
| 86 | |||
| 80 | MCOUNT_RESTORE_REGS | 87 | MCOUNT_RESTORE_REGS |
| 81 | .globl ftrace_stub | 88 | .globl ftrace_stub |
| 82 | ftrace_stub: | 89 | ftrace_stub: |
| @@ -124,10 +131,13 @@ ftrace_stub: | |||
| 124 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER | 131 | #ifdef CONFIG_FUNCTION_GRAPH_TRACER |
| 125 | 132 | ||
| 126 | NESTED(ftrace_graph_caller, PT_SIZE, ra) | 133 | NESTED(ftrace_graph_caller, PT_SIZE, ra) |
| 134 | #ifdef CONFIG_DYNAMIC_FTRACE | ||
| 135 | PTR_L a1, PT_R31(sp) /* load the original ra from the stack */ | ||
| 136 | #else | ||
| 127 | MCOUNT_SAVE_REGS | 137 | MCOUNT_SAVE_REGS |
| 128 | |||
| 129 | PTR_LA a0, PT_R1(sp) /* arg1: &AT -> a0 */ | ||
| 130 | move a1, ra /* arg2: next ip, selfaddr */ | 138 | move a1, ra /* arg2: next ip, selfaddr */ |
| 139 | #endif | ||
| 140 | PTR_LA a0, PT_R1(sp) /* arg1: &AT -> a0 */ | ||
| 131 | jal prepare_ftrace_return | 141 | jal prepare_ftrace_return |
| 132 | move a2, fp /* arg3: frame pointer */ | 142 | move a2, fp /* arg3: frame pointer */ |
| 133 | 143 | ||
