Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/i386/gdbscripts gdb script for backtracing an i386 ...
details: https://anonhg.NetBSD.org/src/rev/ad4e7e275f97
branches: trunk
changeset: 487458:ad4e7e275f97
user: jhawk <jhawk%NetBSD.org@localhost>
date: Thu Jun 08 03:15:40 2000 +0000
description:
gdb script for backtracing an i386 kernel stack.
Useful when "where" in gdb fails to cross trap()s,
e.g. port-i386/10313
diffstat:
sys/arch/i386/gdbscripts/stack | 99 ++++++++++++++++++++++++++++++++++++++++++
1 files changed, 99 insertions(+), 0 deletions(-)
diffs (104 lines):
diff -r ff4be6f0e727 -r ad4e7e275f97 sys/arch/i386/gdbscripts/stack
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/arch/i386/gdbscripts/stack Thu Jun 08 03:15:40 2000 +0000
@@ -0,0 +1,99 @@
+# $NetBSD: stack,v 1.1 2000/06/08 03:15:40 jhawk Exp $
+
+# Copyright (c) 2000 The NetBSD Foundation, Inc.
+# All rights reserved.
+#
+# This code is derived from software contributed to The NetBSD Foundation
+# by John A. Hawkinson.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions
+# are met:
+# 1. Redistributions of source code must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+# 2. Redistributions in binary form must reproduce the above copyright
+# notice, this list of conditions and the following disclaimer in the
+# documentation and/or other materials provided with the distribution.
+# 3. All advertising materials mentioning features or use of this software
+# must display the following acknowledgement:
+# This product includes software developed by the NetBSD
+# Foundation, Inc. and its contributors.
+# 4. Neither the name of The NetBSD Foundation nor the names of its
+# contributors may be used to endorse or promote products derived
+# from this software without specific prior written permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+# ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+# BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+
+
+# Follow an i386 kernel stack trace.
+# This code makes presumptions about the way frames look, consistent
+# with arch/i386/i386/db_trace.c. It also steals algorithms from there.
+
+# Output looks like:
+#
+# 0xc03049cb <cpu_reboot+99>(0x100,0x0,0xc04fd728,0x0,0x6)
+# at 0xc01bc97d <panic+197> (frame at 0xc5633bd0)
+#
+# In this case, the initial hex number and offset should be disregarded,
+# and it should be interprted as if it were:
+#
+# cpu_reboot(0x100,0x0,0xc04fd728,0x0,0x6)
+# at 0xc01bc97d <panic+197> (frame at 0xc5633bd0)
+#
+# due to limitations of gdb scripting.
+
+define stack
+ set $frame=$arg0
+ set $retaddr=$arg1
+
+ while ($frame != 0)
+ set $callpc = $retaddr
+ set $retaddr = *(long*)($frame+4)
+
+ set $inst=*(long*)$retaddr
+ if (($inst & 0xff) == 0x59)
+# (popl %ecx)
+ set $narg=1
+ else if (($inst & 0xffff) == 0xc483)
+# (addl %n, %esp)
+ set $narg = (($inst >> 16) & 0xff) / 4
+ else
+ set $narg = 5
+ end
+
+ set $argp = $frame+8
+ printf " "
+ output/a $callpc
+ printf "("
+ while ($narg != 0)
+ printf "0x%lx", *(long*)$argp
+ set $argp = $argp+4
+ set $narg = $narg-1
+ if ($narg != 0)
+ printf ","
+ end
+ end
+ printf ")\n at "
+ output/a $retaddr
+ printf " (frame at %#x)\n", $frame
+
+ set $frame=*(long*)($frame+0)
+ end
+end
+
+document stack
+ ==> (gdb) stack FP IP
+ print a backtrace of all stack frames, starting at frame pointer FP,
+ and instruction pointer IP. For the default trace, run:
+ "stack $ebp $eip"
+end
\ No newline at end of file
Home |
Main Index |
Thread Index |
Old Index