提交 aea49029 编写于 作者: J Jon Medhurst 提交者: Tixy

ARM: kprobes: Make str_pc_offset a constant on ARMv7

The str_pc_offset value is architecturally defined on ARMv7 onwards so
we can make it a compile time constant. This means on Thumb kernels the
runtime checking code isn't needed, which saves us from having to fix it
to work for Thumb.
Signed-off-by: NJon Medhurst <tixy@yxit.co.uk>
Acked-by: NNicolas Pitre <nicolas.pitre@linaro.org>
上级 6c8df330
...@@ -17,6 +17,8 @@ ...@@ -17,6 +17,8 @@
#include "kprobes.h" #include "kprobes.h"
#ifndef find_str_pc_offset
/* /*
* For STR and STM instructions, an ARM core may choose to use either * For STR and STM instructions, an ARM core may choose to use either
* a +8 or a +12 displacement from the current instruction's address. * a +8 or a +12 displacement from the current instruction's address.
...@@ -40,6 +42,8 @@ void __init find_str_pc_offset(void) ...@@ -40,6 +42,8 @@ void __init find_str_pc_offset(void)
str_pc_offset = ret; str_pc_offset = ret;
} }
#endif /* !find_str_pc_offset */
void __init arm_kprobe_decode_init(void) void __init arm_kprobe_decode_init(void)
{ {
......
...@@ -36,7 +36,21 @@ void __init arm_kprobe_decode_init(void); ...@@ -36,7 +36,21 @@ void __init arm_kprobe_decode_init(void);
extern kprobe_check_cc * const kprobe_condition_checks[16]; extern kprobe_check_cc * const kprobe_condition_checks[16];
#if __LINUX_ARM_ARCH__ >= 7
/* str_pc_offset is architecturally defined from ARMv7 onwards */
#define str_pc_offset 8
#define find_str_pc_offset()
#else /* __LINUX_ARM_ARCH__ < 7 */
/* We need a run-time check to determine str_pc_offset */
extern int str_pc_offset; extern int str_pc_offset;
void __init find_str_pc_offset(void);
#endif
/* /*
* Test if load/store instructions writeback the address register. * Test if load/store instructions writeback the address register.
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册