diff options
author | Jon Medhurst <tixy@yxit.co.uk> | 2011-07-07 05:21:40 -0400 |
---|---|---|
committer | Tixy <tixy@medhuaa1.miniserver.com> | 2011-07-13 13:32:41 -0400 |
commit | 6c8df3300f60cae54aeb2a6dda8efe7ffe16a322 (patch) | |
tree | c7cac1abd0d5a46db1a4b4b3785238874822218b /arch/arm/kernel/kprobes-common.c | |
parent | 1b59d874660be7f790861ad849858cc009089515 (diff) |
ARM: kprobes: Move find_str_pc_offset into kprobes-common.c
Move str_pc_offset into kprobes-common.c as it will be needed by common
code later.
Signed-off-by: Jon Medhurst <tixy@yxit.co.uk>
Acked-by: Nicolas Pitre <nicolas.pitre@linaro.org>
Diffstat (limited to 'arch/arm/kernel/kprobes-common.c')
-rw-r--r-- | arch/arm/kernel/kprobes-common.c | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/arch/arm/kernel/kprobes-common.c b/arch/arm/kernel/kprobes-common.c index 794827ec27d7..e18576cca6cf 100644 --- a/arch/arm/kernel/kprobes-common.c +++ b/arch/arm/kernel/kprobes-common.c | |||
@@ -3,6 +3,9 @@ | |||
3 | * | 3 | * |
4 | * Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>. | 4 | * Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>. |
5 | * | 5 | * |
6 | * Some contents moved here from arch/arm/include/asm/kprobes-arm.c which is | ||
7 | * Copyright (C) 2006, 2007 Motorola Inc. | ||
8 | * | ||
6 | * This program is free software; you can redistribute it and/or modify | 9 | * This program is free software; you can redistribute it and/or modify |
7 | * it under the terms of the GNU General Public License version 2 as | 10 | * it under the terms of the GNU General Public License version 2 as |
8 | * published by the Free Software Foundation. | 11 | * published by the Free Software Foundation. |
@@ -14,6 +17,36 @@ | |||
14 | #include "kprobes.h" | 17 | #include "kprobes.h" |
15 | 18 | ||
16 | 19 | ||
20 | /* | ||
21 | * For STR and STM instructions, an ARM core may choose to use either | ||
22 | * a +8 or a +12 displacement from the current instruction's address. | ||
23 | * Whichever value is chosen for a given core, it must be the same for | ||
24 | * both instructions and may not change. This function measures it. | ||
25 | */ | ||
26 | |||
27 | int str_pc_offset; | ||
28 | |||
29 | void __init find_str_pc_offset(void) | ||
30 | { | ||
31 | int addr, scratch, ret; | ||
32 | |||
33 | __asm__ ( | ||
34 | "sub %[ret], pc, #4 \n\t" | ||
35 | "str pc, %[addr] \n\t" | ||
36 | "ldr %[scr], %[addr] \n\t" | ||
37 | "sub %[ret], %[scr], %[ret] \n\t" | ||
38 | : [ret] "=r" (ret), [scr] "=r" (scratch), [addr] "+m" (addr)); | ||
39 | |||
40 | str_pc_offset = ret; | ||
41 | } | ||
42 | |||
43 | |||
44 | void __init arm_kprobe_decode_init(void) | ||
45 | { | ||
46 | find_str_pc_offset(); | ||
47 | } | ||
48 | |||
49 | |||
17 | static unsigned long __kprobes __check_eq(unsigned long cpsr) | 50 | static unsigned long __kprobes __check_eq(unsigned long cpsr) |
18 | { | 51 | { |
19 | return cpsr & PSR_Z_BIT; | 52 | return cpsr & PSR_Z_BIT; |