From: Jan Kiszka <jan.kiszka@web.de>
To: Samuel Bronson <naesten@gmail.com>
Cc: gdb@sources.redhat.com
Subject: Re: Towards better x86 system debugging support
Date: Sun, 31 May 2009 09:36:00 -0000 [thread overview]
Message-ID: <4A224FA6.7050501@web.de> (raw)
In-Reply-To: <loom.20090529T190319-951@post.gmane.org>
[-- Attachment #1: Type: text/plain, Size: 2450 bytes --]
Samuel Bronson wrote:
> Jan Kiszka <jan.kiszka <at> web.de> writes:
>> Mark Kettenis wrote:
>>>> From: Jan Kiszka <jan.kiszka <at> web.de>
>
>>>> Unfortunately, the x86 support is incomplete in so far that neither the
>>>> gdb remote protocol nor the gdb backend are aware of most special
>>>> registers x86 system-level software uses. This comes with several drawbacks:
>
>>>> o Current code bit width (16, 32 or 64) is unknown to the debugger,
>>>> so correct disassembling is not automatically possible
>
>>>> o Real mode cannot be detected, which would include setting 16 bit
>>>> disassembly mode and calculating segment bases appropriately
>
>>>> o Only flat memory models are supported and debugging becomes very
>>>> hairy when some segment uses a non-zero base address - note that this
>>>> also prevents support for TLS variable lookup (which is GS or
>>>> FS-based)
>
>>>> As a first step toward enhanced x86 support, I think there is a need for
>>>> an extended register set in the remote protocol. The following registers
>>>> should be added:
>
>>>> o GDTR, LDTR, IDTR, TR (visible part, ie. selector value)
>>>> o CR0..4
>>>> o DR0..7
>>>> o selected MSRs, at least
>>>> - IA32_EFER (64-bit mode detection)
>>>> - IA32_FS_Base (TLS)
>>>> - IA32_GS_Base (TLS)
>>>> - IA32_KernelGSbase (TLS)
>>>> o Shadow states of segment registers, GDTR, LDTR, IDTR and TR
>>>> (relevant for virtual targets where the VM often has access to these
>>>> hidden states, helpful when debugging targets that modify in-use
>>>> descriptor table entries)
>
> These things have also been bothering me lately, along with GDB's poor handling
> of interrupt handlers, namely:
>
> o the "finish" command doesn't work in an interrupt-handler frame
>
> o GDB (presumably) does not notice when a frame's (interrupt) return CS:EIP
> is at a different privilege level from that frame's own CS:EIP, which it
> would need to do in order to correctly unwind the calling frame's SS:ESP,
> which are stored on the stack in this situation rather than inferred
> based on the present frame
>
> Have you made any progress on any of this, Jan?
Unfortunately not. I was hoping my todo list would shrink a bit or some
customer explicitly ask for a clean integration, but both did not happen
yet. But it's not forgotten, it's just "slightly" delayed.
Jan
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 257 bytes --]
next prev parent reply other threads:[~2009-05-31 9:36 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-01-04 13:34 Jan Kiszka
2009-01-05 3:44 ` Daniel Jacobowitz
2009-01-05 8:52 ` GDB MI and actual type of a pointer or reference Elmenthaler, Jens
2009-01-05 9:36 ` Towards better x86 system debugging support Jan Kiszka
2009-01-06 15:14 ` Daniel Jacobowitz
2009-01-05 20:20 ` Mark Kettenis
2009-01-06 12:13 ` Jan Kiszka
2009-05-29 19:20 ` Samuel Bronson
2009-05-31 9:36 ` Jan Kiszka [this message]
2009-01-06 23:59 ` Doug Evans
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4A224FA6.7050501@web.de \
--to=jan.kiszka@web.de \
--cc=gdb@sources.redhat.com \
--cc=naesten@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox