diff options
author | Masami Hiramatsu <mhiramat@kernel.org> | 2019-02-12 11:11:47 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2019-02-13 02:16:39 -0500 |
commit | 877b145f0f4723133f934be402b8dfc769eb971f (patch) | |
tree | f788a9d1dc74203612d62ca4035a0e31aad7174c | |
parent | 0192e6535ebe9af68614198ced4fd6d37b778ebf (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.c | 9 |
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 | ||
99 | asm ( | 99 | asm ( |
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 | ||
142 | void optprobe_template_func(void); | 142 | void optprobe_template_func(void); |
143 | STACK_FRAME_NON_STANDARD(optprobe_template_func); | 143 | STACK_FRAME_NON_STANDARD(optprobe_template_func); |
144 | NOKPROBE_SYMBOL(optprobe_template_func); | ||
145 | NOKPROBE_SYMBOL(optprobe_template_entry); | ||
146 | NOKPROBE_SYMBOL(optprobe_template_val); | ||
147 | NOKPROBE_SYMBOL(optprobe_template_call); | ||
148 | NOKPROBE_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) |