summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeff Dike2005-11-07 09:58:45 +0100
committerLinus Torvalds2005-11-07 16:53:30 +0100
commit953206858070e5921b9d5931c293ec983a6790cb (patch)
tree9caf1d094ee6f001856d5c433b3c60f309c9da98
parent[PATCH] cris: "extern inline" -> "static inline" (diff)
downloadkernel-qcow2-linux-953206858070e5921b9d5931c293ec983a6790cb.tar.gz
kernel-qcow2-linux-953206858070e5921b9d5931c293ec983a6790cb.tar.xz
kernel-qcow2-linux-953206858070e5921b9d5931c293ec983a6790cb.zip
[PATCH] uml: improve stub debugging
Add some more debugging information when a stub does something unexpected, usually segfaulting. Now, it dumps out the stub's registers as well as the signal. Signed-off-by: Jeff Dike <jdike@addtoit.com> Cc: Paolo Giarrusso <blaisorblade@yahoo.it> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
-rw-r--r--arch/um/kernel/skas/process.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/arch/um/kernel/skas/process.c b/arch/um/kernel/skas/process.c
index 5cd0e9929789..42f2da687dc8 100644
--- a/arch/um/kernel/skas/process.c
+++ b/arch/um/kernel/skas/process.c
@@ -69,6 +69,17 @@ void wait_stub_done(int pid, int sig, char * fname)
if((n < 0) || !WIFSTOPPED(status) ||
(WSTOPSIG(status) != SIGUSR1 && WSTOPSIG(status) != SIGTRAP)){
+ unsigned long regs[FRAME_SIZE];
+ if(ptrace(PTRACE_GETREGS, pid, 0, regs) < 0)
+ printk("Failed to get registers from stub, "
+ "errno = %d\n", errno);
+ else {
+ int i;
+
+ printk("Stub registers -\n");
+ for(i = 0; i < FRAME_SIZE; i++)
+ printk("\t%d - %lx\n", i, regs[i]);
+ }
panic("%s : failed to wait for SIGUSR1/SIGTRAP, "
"pid = %d, n = %d, errno = %d, status = 0x%x\n",
fname, pid, n, errno, status);