|
@@ -115,6 +115,27 @@ int __init ftrace_dyn_arch_init(void *data)
|
|
|
|
|
|
#ifdef CONFIG_FUNCTION_GRAPH_TRACER
|
|
|
|
|
|
+#ifdef CONFIG_DYNAMIC_FTRACE
|
|
|
+
|
|
|
+extern void ftrace_graph_call(void);
|
|
|
+#define JMP 0x08000000 /* jump to target directly */
|
|
|
+#define CALL_FTRACE_GRAPH_CALLER \
|
|
|
+ jump_insn_encode(JMP, (unsigned long)(&ftrace_graph_caller))
|
|
|
+#define FTRACE_GRAPH_CALL_IP ((unsigned long)(&ftrace_graph_call))
|
|
|
+
|
|
|
+int ftrace_enable_ftrace_graph_caller(void)
|
|
|
+{
|
|
|
+ return ftrace_modify_code(FTRACE_GRAPH_CALL_IP,
|
|
|
+ CALL_FTRACE_GRAPH_CALLER);
|
|
|
+}
|
|
|
+
|
|
|
+int ftrace_disable_ftrace_graph_caller(void)
|
|
|
+{
|
|
|
+ return ftrace_modify_code(FTRACE_GRAPH_CALL_IP, ftrace_nop);
|
|
|
+}
|
|
|
+
|
|
|
+#endif /* !CONFIG_DYNAMIC_FTRACE */
|
|
|
+
|
|
|
#define S_RA_SP (0xafbf << 16) /* s{d,w} ra, offset(sp) */
|
|
|
#define S_R_SP (0xafb0 << 16) /* s{d,w} R, offset(sp) */
|
|
|
#define OFFSET_MASK 0xffff /* stack offset range: 0 ~ PT_SIZE */
|