diff options
author | Paul Mundt <lethal@linux-sh.org> | 2010-06-14 02:16:53 -0400 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2010-06-14 02:16:53 -0400 |
commit | eaaaeef392cb245e415c31d480ed2d5a466fd88f (patch) | |
tree | 483761495ceb9cc3a277769f52d0ec8abeed1ac0 /arch/sh/kernel | |
parent | 9973e38575070b70c68bad177fb5056548fea349 (diff) |
sh: Add kprobe-based event tracer.
This follows the x86/ppc changes for kprobe-based event tracing on sh.
While kprobes is only supported on 32-bit sh, we provide the API for
HAVE_REGS_AND_STACK_ACCESS_API for both 32 and 64-bit.
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh/kernel')
-rw-r--r-- | arch/sh/kernel/Makefile | 2 | ||||
-rw-r--r-- | arch/sh/kernel/ptrace.c | 33 | ||||
-rw-r--r-- | arch/sh/kernel/ptrace_32.c | 27 | ||||
-rw-r--r-- | arch/sh/kernel/ptrace_64.c | 79 |
4 files changed, 140 insertions, 1 deletions
diff --git a/arch/sh/kernel/Makefile b/arch/sh/kernel/Makefile index e25f3c69525d..1086ba1abdab 100644 --- a/arch/sh/kernel/Makefile +++ b/arch/sh/kernel/Makefile | |||
@@ -14,7 +14,7 @@ CFLAGS_REMOVE_return_address.o = -pg | |||
14 | obj-y := clkdev.o debugtraps.o dma-nommu.o dumpstack.o \ | 14 | obj-y := clkdev.o debugtraps.o dma-nommu.o dumpstack.o \ |
15 | idle.o io.o irq.o \ | 15 | idle.o io.o irq.o \ |
16 | irq_$(BITS).o machvec.o nmi_debug.o process.o \ | 16 | irq_$(BITS).o machvec.o nmi_debug.o process.o \ |
17 | process_$(BITS).o ptrace_$(BITS).o \ | 17 | process_$(BITS).o ptrace.o ptrace_$(BITS).o \ |
18 | reboot.o return_address.o \ | 18 | reboot.o return_address.o \ |
19 | setup.o signal_$(BITS).o sys_sh.o sys_sh$(BITS).o \ | 19 | setup.o signal_$(BITS).o sys_sh.o sys_sh$(BITS).o \ |
20 | syscalls_$(BITS).o time.o topology.o traps.o \ | 20 | syscalls_$(BITS).o time.o topology.o traps.o \ |
diff --git a/arch/sh/kernel/ptrace.c b/arch/sh/kernel/ptrace.c new file mode 100644 index 000000000000..0a05983633ca --- /dev/null +++ b/arch/sh/kernel/ptrace.c | |||
@@ -0,0 +1,33 @@ | |||
1 | #include <linux/ptrace.h> | ||
2 | |||
3 | /** | ||
4 | * regs_query_register_offset() - query register offset from its name | ||
5 | * @name: the name of a register | ||
6 | * | ||
7 | * regs_query_register_offset() returns the offset of a register in struct | ||
8 | * pt_regs from its name. If the name is invalid, this returns -EINVAL; | ||
9 | */ | ||
10 | int regs_query_register_offset(const char *name) | ||
11 | { | ||
12 | const struct pt_regs_offset *roff; | ||
13 | for (roff = regoffset_table; roff->name != NULL; roff++) | ||
14 | if (!strcmp(roff->name, name)) | ||
15 | return roff->offset; | ||
16 | return -EINVAL; | ||
17 | } | ||
18 | |||
19 | /** | ||
20 | * regs_query_register_name() - query register name from its offset | ||
21 | * @offset: the offset of a register in struct pt_regs. | ||
22 | * | ||
23 | * regs_query_register_name() returns the name of a register from its | ||
24 | * offset in struct pt_regs. If the @offset is invalid, this returns NULL; | ||
25 | */ | ||
26 | const char *regs_query_register_name(unsigned int offset) | ||
27 | { | ||
28 | const struct pt_regs_offset *roff; | ||
29 | for (roff = regoffset_table; roff->name != NULL; roff++) | ||
30 | if (roff->offset == offset) | ||
31 | return roff->name; | ||
32 | return NULL; | ||
33 | } | ||
diff --git a/arch/sh/kernel/ptrace_32.c b/arch/sh/kernel/ptrace_32.c index 6c4bbba2a675..2cd42b58cb20 100644 --- a/arch/sh/kernel/ptrace_32.c +++ b/arch/sh/kernel/ptrace_32.c | |||
@@ -274,6 +274,33 @@ static int dspregs_active(struct task_struct *target, | |||
274 | } | 274 | } |
275 | #endif | 275 | #endif |
276 | 276 | ||
277 | const struct pt_regs_offset regoffset_table[] = { | ||
278 | REGS_OFFSET_NAME(0), | ||
279 | REGS_OFFSET_NAME(1), | ||
280 | REGS_OFFSET_NAME(2), | ||
281 | REGS_OFFSET_NAME(3), | ||
282 | REGS_OFFSET_NAME(4), | ||
283 | REGS_OFFSET_NAME(5), | ||
284 | REGS_OFFSET_NAME(6), | ||
285 | REGS_OFFSET_NAME(7), | ||
286 | REGS_OFFSET_NAME(8), | ||
287 | REGS_OFFSET_NAME(9), | ||
288 | REGS_OFFSET_NAME(10), | ||
289 | REGS_OFFSET_NAME(11), | ||
290 | REGS_OFFSET_NAME(12), | ||
291 | REGS_OFFSET_NAME(13), | ||
292 | REGS_OFFSET_NAME(14), | ||
293 | REGS_OFFSET_NAME(15), | ||
294 | REG_OFFSET_NAME(pc), | ||
295 | REG_OFFSET_NAME(pr), | ||
296 | REG_OFFSET_NAME(sr), | ||
297 | REG_OFFSET_NAME(gbr), | ||
298 | REG_OFFSET_NAME(mach), | ||
299 | REG_OFFSET_NAME(macl), | ||
300 | REG_OFFSET_NAME(tra), | ||
301 | REG_OFFSET_END, | ||
302 | }; | ||
303 | |||
277 | /* | 304 | /* |
278 | * These are our native regset flavours. | 305 | * These are our native regset flavours. |
279 | */ | 306 | */ |
diff --git a/arch/sh/kernel/ptrace_64.c b/arch/sh/kernel/ptrace_64.c index 5fd644da7f02..b97817016b6a 100644 --- a/arch/sh/kernel/ptrace_64.c +++ b/arch/sh/kernel/ptrace_64.c | |||
@@ -252,6 +252,85 @@ static int fpregs_active(struct task_struct *target, | |||
252 | } | 252 | } |
253 | #endif | 253 | #endif |
254 | 254 | ||
255 | const struct pt_regs_offset regoffset_table[] = { | ||
256 | REG_OFFSET_NAME(pc), | ||
257 | REG_OFFSET_NAME(sr), | ||
258 | REG_OFFSET_NAME(syscall_nr), | ||
259 | REGS_OFFSET_NAME(0), | ||
260 | REGS_OFFSET_NAME(1), | ||
261 | REGS_OFFSET_NAME(2), | ||
262 | REGS_OFFSET_NAME(3), | ||
263 | REGS_OFFSET_NAME(4), | ||
264 | REGS_OFFSET_NAME(5), | ||
265 | REGS_OFFSET_NAME(6), | ||
266 | REGS_OFFSET_NAME(7), | ||
267 | REGS_OFFSET_NAME(8), | ||
268 | REGS_OFFSET_NAME(9), | ||
269 | REGS_OFFSET_NAME(10), | ||
270 | REGS_OFFSET_NAME(11), | ||
271 | REGS_OFFSET_NAME(12), | ||
272 | REGS_OFFSET_NAME(13), | ||
273 | REGS_OFFSET_NAME(14), | ||
274 | REGS_OFFSET_NAME(15), | ||
275 | REGS_OFFSET_NAME(16), | ||
276 | REGS_OFFSET_NAME(17), | ||
277 | REGS_OFFSET_NAME(18), | ||
278 | REGS_OFFSET_NAME(19), | ||
279 | REGS_OFFSET_NAME(20), | ||
280 | REGS_OFFSET_NAME(21), | ||
281 | REGS_OFFSET_NAME(22), | ||
282 | REGS_OFFSET_NAME(23), | ||
283 | REGS_OFFSET_NAME(24), | ||
284 | REGS_OFFSET_NAME(25), | ||
285 | REGS_OFFSET_NAME(26), | ||
286 | REGS_OFFSET_NAME(27), | ||
287 | REGS_OFFSET_NAME(28), | ||
288 | REGS_OFFSET_NAME(29), | ||
289 | REGS_OFFSET_NAME(30), | ||
290 | REGS_OFFSET_NAME(31), | ||
291 | REGS_OFFSET_NAME(32), | ||
292 | REGS_OFFSET_NAME(33), | ||
293 | REGS_OFFSET_NAME(34), | ||
294 | REGS_OFFSET_NAME(35), | ||
295 | REGS_OFFSET_NAME(36), | ||
296 | REGS_OFFSET_NAME(37), | ||
297 | REGS_OFFSET_NAME(38), | ||
298 | REGS_OFFSET_NAME(39), | ||
299 | REGS_OFFSET_NAME(40), | ||
300 | REGS_OFFSET_NAME(41), | ||
301 | REGS_OFFSET_NAME(42), | ||
302 | REGS_OFFSET_NAME(43), | ||
303 | REGS_OFFSET_NAME(44), | ||
304 | REGS_OFFSET_NAME(45), | ||
305 | REGS_OFFSET_NAME(46), | ||
306 | REGS_OFFSET_NAME(47), | ||
307 | REGS_OFFSET_NAME(48), | ||
308 | REGS_OFFSET_NAME(49), | ||
309 | REGS_OFFSET_NAME(50), | ||
310 | REGS_OFFSET_NAME(51), | ||
311 | REGS_OFFSET_NAME(52), | ||
312 | REGS_OFFSET_NAME(53), | ||
313 | REGS_OFFSET_NAME(54), | ||
314 | REGS_OFFSET_NAME(55), | ||
315 | REGS_OFFSET_NAME(56), | ||
316 | REGS_OFFSET_NAME(57), | ||
317 | REGS_OFFSET_NAME(58), | ||
318 | REGS_OFFSET_NAME(59), | ||
319 | REGS_OFFSET_NAME(60), | ||
320 | REGS_OFFSET_NAME(61), | ||
321 | REGS_OFFSET_NAME(62), | ||
322 | REGS_OFFSET_NAME(63), | ||
323 | TREGS_OFFSET_NAME(0), | ||
324 | TREGS_OFFSET_NAME(1), | ||
325 | TREGS_OFFSET_NAME(2), | ||
326 | TREGS_OFFSET_NAME(3), | ||
327 | TREGS_OFFSET_NAME(4), | ||
328 | TREGS_OFFSET_NAME(5), | ||
329 | TREGS_OFFSET_NAME(6), | ||
330 | TREGS_OFFSET_NAME(7), | ||
331 | REG_OFFSET_END, | ||
332 | }; | ||
333 | |||
255 | /* | 334 | /* |
256 | * These are our native regset flavours. | 335 | * These are our native regset flavours. |
257 | */ | 336 | */ |