Re: kgdb issues in 2.6.26.5-rt9
From: Jason Wessel
Date: Thu Dec 09 2010 - 13:41:52 EST
On 12/05/2010 02:04 AM, Tal Lubko wrote:
> Hello all,
>
> I am running a custom 2.6.26.5-rt9 kernel which is the 2.6.26.5 vanilla kernel
> with version 9 of the real time patch for that specific version. I am trying to
> debug a "hard" problem which means not a problem which is easily reproducibe,
> appears only on boot, only under certain conditions etc. In order to debug the
> problem I am using kgdb.
>
> Before anyone flames me, I am aware that kgdb is not the highway as far as
> kernel debugging is concerned, but due to certain external factors I am
> interested in making that approach work.
>
> My understanding of the kgdb status (please correct me if I am wrong on any of
> the following...):
> - kgdb is supported in 2.6.26.5 vanilla and the important stuff works.
> - the version of kgdb in 2.6.26.5 is the "light" version by Ingo, Thomas and
> Jason which means that some features are missing.
> - I am not aware of any limitations of the host side gdb that I am supposed to
> use in order to debug the target (I tried using 6.6 and 6.8)
>
> The problems I have with kgdb:
> - info threads shows most of the threads on the system but then hangs for a
> short time with various data errors. As a first stab this seems like a protocol
> issue between host and target.
>
It depends. The only way to know for sure is to do something like
following command before issuing your commands in gdb.
set debug remote 1
That will at least tell you were things started "hang".
> - thread [tid] does not work. It claims that the thread ids that I use do not
> exist although the info that I do manage to get out of "info threads" admits
> that they do. ps(1) on the target also confirms the thread id numbers.
>
In gdb the thread command only works if you could obtain the thread
list. If you know the thread struct address of some process you are
interested in, it may be easier to just reference it in the debugger.
The debugger is a tool that you can use as a helper and it is not good
at "every scenario" under the sun especially if you are concerned at all
about speed or determinism. You would be better served to be looking
at tracing tools if that is the case.
> - I haven't managed to set breakpoints. For instance: breaking on printk using
> "break printk" results in a segv of the debugger (huh?!?). This looks like a gdb
>
>
Perhaps the documentation sheds some light in later releases of kgdb
(and the kernel for that matter). My guess is that you need to turn
off the kernel option CONFIG_DEBUG_RODATA. There was no safety check
for this in 2.6.26. A great number of other problems have been solved
over time as well with HW breakpoints and SMP robustness.
Best of luck debugging. :-)
Cheers,
Jason.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/