diff options
author | Jason Wessel <jason.wessel@windriver.com> | 2010-08-05 10:22:20 -0400 |
---|---|---|
committer | Jason Wessel <jason.wessel@windriver.com> | 2010-08-05 10:22:20 -0400 |
commit | 534af1082329392bc29f6badf815e69ae2ae0f4c (patch) | |
tree | e163c1d5c418334538447983b7d5934e05fa4d71 /kernel/debug/gdbstub.c | |
parent | 84a0bd5b2830722cf80ff6ad33ef98101a947e14 (diff) |
kgdb,kdb: individual register set and and get API
The kdb shell specification includes the ability to get and set
architecture specific registers by name.
For the time being individual register get and set will be implemented
on a per architecture basis. If an architecture defines
DBG_MAX_REG_NUM > 0 then kdb and the gdbstub will use the capability
for individually getting and setting architecture specific registers.
Signed-off-by: Jason Wessel <jason.wessel@windriver.com>
Diffstat (limited to 'kernel/debug/gdbstub.c')
-rw-r--r-- | kernel/debug/gdbstub.c | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/kernel/debug/gdbstub.c b/kernel/debug/gdbstub.c index e117cfd75887..006bad8905d3 100644 --- a/kernel/debug/gdbstub.c +++ b/kernel/debug/gdbstub.c | |||
@@ -328,6 +328,32 @@ static int kgdb_ebin2mem(char *buf, char *mem, int count) | |||
328 | return probe_kernel_write(mem, c, size); | 328 | return probe_kernel_write(mem, c, size); |
329 | } | 329 | } |
330 | 330 | ||
331 | #if DBG_MAX_REG_NUM > 0 | ||
332 | void pt_regs_to_gdb_regs(unsigned long *gdb_regs, struct pt_regs *regs) | ||
333 | { | ||
334 | int i; | ||
335 | int idx = 0; | ||
336 | char *ptr = (char *)gdb_regs; | ||
337 | |||
338 | for (i = 0; i < DBG_MAX_REG_NUM; i++) { | ||
339 | dbg_get_reg(i, ptr + idx, regs); | ||
340 | idx += dbg_reg_def[i].size; | ||
341 | } | ||
342 | } | ||
343 | |||
344 | void gdb_regs_to_pt_regs(unsigned long *gdb_regs, struct pt_regs *regs) | ||
345 | { | ||
346 | int i; | ||
347 | int idx = 0; | ||
348 | char *ptr = (char *)gdb_regs; | ||
349 | |||
350 | for (i = 0; i < DBG_MAX_REG_NUM; i++) { | ||
351 | dbg_set_reg(i, ptr + idx, regs); | ||
352 | idx += dbg_reg_def[i].size; | ||
353 | } | ||
354 | } | ||
355 | #endif /* DBG_MAX_REG_NUM > 0 */ | ||
356 | |||
331 | /* Write memory due to an 'M' or 'X' packet. */ | 357 | /* Write memory due to an 'M' or 'X' packet. */ |
332 | static int write_mem_msg(int binary) | 358 | static int write_mem_msg(int binary) |
333 | { | 359 | { |