summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMasami Hiramatsu <mhiramat@kernel.org>2019-02-12 11:11:47 -0500
committerIngo Molnar <mingo@kernel.org>2019-02-13 02:16:39 -0500
commit877b145f0f4723133f934be402b8dfc769eb971f (patch)
treef788a9d1dc74203612d62ca4035a0e31aad7174c
parent0192e6535ebe9af68614198ced4fd6d37b778ebf (diff)
x86/kprobes: Move trampoline code into RODATA
Move optprobe trampoline code into RODATA since it is not executed, but copied and modified to be used on a trampoline buffer. Signed-off-by: Masami Hiramatsu <mhiramat@kernel.org> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Andrea Righi <righi.andrea@gmail.com> Cc: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Mathieu Desnoyers <mathieu.desnoyers@efficios.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Steven Rostedt <rostedt@goodmis.org> Cc: Thomas Gleixner <tglx@linutronix.de> Link: http://lkml.kernel.org/r/154998790744.31052.3016106262944915510.stgit@devbox Signed-off-by: Ingo Molnar <mingo@kernel.org>
-rw-r--r--arch/x86/kernel/kprobes/opt.c9
1 files changed, 2 insertions, 7 deletions
diff --git a/arch/x86/kernel/kprobes/opt.c b/arch/x86/kernel/kprobes/opt.c
index 544bd41a514c..f14262952015 100644
--- a/arch/x86/kernel/kprobes/opt.c
+++ b/arch/x86/kernel/kprobes/opt.c
@@ -97,6 +97,7 @@ static void synthesize_set_arg1(kprobe_opcode_t *addr, unsigned long val)
97} 97}
98 98
99asm ( 99asm (
100 ".pushsection .rodata\n"
100 "optprobe_template_func:\n" 101 "optprobe_template_func:\n"
101 ".global optprobe_template_entry\n" 102 ".global optprobe_template_entry\n"
102 "optprobe_template_entry:\n" 103 "optprobe_template_entry:\n"
@@ -136,16 +137,10 @@ asm (
136#endif 137#endif
137 ".global optprobe_template_end\n" 138 ".global optprobe_template_end\n"
138 "optprobe_template_end:\n" 139 "optprobe_template_end:\n"
139 ".type optprobe_template_func, @function\n" 140 ".popsection\n");
140 ".size optprobe_template_func, .-optprobe_template_func\n");
141 141
142void optprobe_template_func(void); 142void optprobe_template_func(void);
143STACK_FRAME_NON_STANDARD(optprobe_template_func); 143STACK_FRAME_NON_STANDARD(optprobe_template_func);
144NOKPROBE_SYMBOL(optprobe_template_func);
145NOKPROBE_SYMBOL(optprobe_template_entry);
146NOKPROBE_SYMBOL(optprobe_template_val);
147NOKPROBE_SYMBOL(optprobe_template_call);
148NOKPROBE_SYMBOL(optprobe_template_end);
149 144
150#define TMPL_MOVE_IDX \ 145#define TMPL_MOVE_IDX \
151 ((long)optprobe_template_val - (long)optprobe_template_entry) 146 ((long)optprobe_template_val - (long)optprobe_template_entry)