diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-03-24 13:07:50 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-03-24 13:07:50 -0400 |
| commit | 3dab04e6978e358ad2307bca563fabd6c5d2c58b (patch) | |
| tree | 893e9bc5041e7f722722fe13a3b145396f2554d8 /kernel | |
| parent | 6d1e9a42e7176bbce9348274784b2e5f69223936 (diff) | |
| parent | 5a4b65ab506398ba5a35c37e06edddd387cc0add (diff) | |
Merge branch 'next' of git://git.kernel.org/pub/scm/linux/kernel/git/dhowells/linux-2.6-mn10300
* 'next' of git://git.kernel.org/pub/scm/linux/kernel/git/dhowells/linux-2.6-mn10300:
MN10300: gcc 4.6 vs am33 inline assembly
MN10300: Deprecate gdbstub
MN10300: Allow KGDB to use the MN10300 serial ports
MN10300: Emulate single stepping in KGDB on MN10300
MN10300: Generalise kernel debugger kernel halt, reboot or power off hook
KGDB: Notify GDB of machine halt, reboot or power off
MN10300: Use KGDB
MN10300: Create generic kernel debugger hooks
MN10300: Create general kernel debugger cache flushing
MN10300: Introduce a general config option for kernel debugger hooks
MN10300: The icache invalidate functions should disable the icache first
MN10300: gdbstub: Restrict single-stepping to non-preemptable non-SMP configs
Diffstat (limited to 'kernel')
| -rw-r--r-- | kernel/debug/gdbstub.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/kernel/debug/gdbstub.c b/kernel/debug/gdbstub.c index 481a7bd2dfe7..a11db956dd62 100644 --- a/kernel/debug/gdbstub.c +++ b/kernel/debug/gdbstub.c | |||
| @@ -1093,3 +1093,33 @@ int gdbstub_state(struct kgdb_state *ks, char *cmd) | |||
| 1093 | put_packet(remcom_out_buffer); | 1093 | put_packet(remcom_out_buffer); |
| 1094 | return 0; | 1094 | return 0; |
| 1095 | } | 1095 | } |
| 1096 | |||
| 1097 | /** | ||
| 1098 | * gdbstub_exit - Send an exit message to GDB | ||
| 1099 | * @status: The exit code to report. | ||
| 1100 | */ | ||
| 1101 | void gdbstub_exit(int status) | ||
| 1102 | { | ||
| 1103 | unsigned char checksum, ch, buffer[3]; | ||
| 1104 | int loop; | ||
| 1105 | |||
| 1106 | buffer[0] = 'W'; | ||
| 1107 | buffer[1] = hex_asc_hi(status); | ||
| 1108 | buffer[2] = hex_asc_lo(status); | ||
| 1109 | |||
| 1110 | dbg_io_ops->write_char('$'); | ||
| 1111 | checksum = 0; | ||
| 1112 | |||
| 1113 | for (loop = 0; loop < 3; loop++) { | ||
| 1114 | ch = buffer[loop]; | ||
| 1115 | checksum += ch; | ||
| 1116 | dbg_io_ops->write_char(ch); | ||
| 1117 | } | ||
| 1118 | |||
| 1119 | dbg_io_ops->write_char('#'); | ||
| 1120 | dbg_io_ops->write_char(hex_asc_hi(checksum)); | ||
| 1121 | dbg_io_ops->write_char(hex_asc_lo(checksum)); | ||
| 1122 | |||
| 1123 | /* make sure the output is flushed, lest the bootloader clobber it */ | ||
| 1124 | dbg_io_ops->flush(); | ||
| 1125 | } | ||
