kernel/kld debugging on amd64 (qemu gdbstub, gdbinit, asf(1)...)
John Baldwin
jhb at freebsd.org
Thu May 1 14:36:15 UTC 2008
On Thursday 01 May 2008 06:51:38 am Juergen Lock wrote:
> Before I forget, here are some things I found out while debugging the
> kqemu amd64 SMP issue...
>
> 1. I used a patched kgdb to be able to use it with qemu's gdbstub
> (kgdb -r 127.1:1234 kernel.debug), that patch I already posted:
> http://docs.freebsd.org/cgi/mid.cgi?20080304213153.GB15959
> (Yeah you can also used regular gdb or gdb66 from ports with qemu's
> gdbstub, but those don't understand kernel stack frames and maybe
> other things...)
This patch just went into the tree (a variant of it) in the commits to kgdb in
HEAD earlier this week.
> 2. the ps and kldstat macros from src/tools/debugscripts/gdbinit.kernel
> (and probably others) use %08x for pointers, so on 64 bit archs like amd64
> the upper half gets chopped off. I didn't fix this correctly tho, but
> instead defined my own ps64 and kldstat64 macros using %016lx...
Try using macros at www.freebsd.org/~jhb/gdb/gdb6 instead as they handle
64-bit vs 32-bit.
> 3. asf(1) also didn't work correctly for amd64 (bss and data were wrong),
> here is the patch I ended up using: (maybe you want to ifdef for amd64
> instead of checking for zero VMA tho)
I haven't seen this, but I also haven't used asf(8) on amd64. You can grab
the kgdb sources from HEAD though and then you can use kgdb's native kld
support (i.e. add-kld and the shared library stuff) for remote targets to
load symbols.
--
John Baldwin
More information about the freebsd-amd64
mailing list