[Ada] Do not compute task ptid when debugging core file
authorJoel Brobecker <brobecker@gnat.com>
Wed, 22 Sep 2010 22:50:54 +0000 (22:50 +0000)
committerJoel Brobecker <brobecker@gnat.com>
Wed, 22 Sep 2010 22:50:54 +0000 (22:50 +0000)
commit39383a48f726a69d632f4899acaccb0ba5f5a61b
tree272bf33c9328a6481c46003b93861ec387f1d340
parent7a360e83fc3bfe89586d408f2107242c85a0daf8
[Ada] Do not compute task ptid when debugging core file

After thread support over core files was added for GNU/Linux was added,
we started noticing the following type of crash when trying to perform
task switches (this is a bit accademic, since task switching is not
supported when debugging core files - this is what our testcase was
verifying).

(please check out the comment inside ada-tasks.c:task_command for
more details on this topic)

The reason for the crash comes from the fact that the GNU/Linux thread
layer now gets pushed on the target stack, causing the associated
to_get_ada_task_ptid target method to be activated.  This routine
makes the assumption that, for all threads, the private area is not
NULL.  This is incorrect in the case of core files, as the core layer
creates some threads with no private data.

But, taking a step back, we don't need to try to compute the task ptid,
as we'll never be using it anyways (we only use it for task switching).
So the fix is to avoid the ptid computation altogether when debugging
a core file.

gdb/ChangeLog:

        * ada-tasks.c (read_atcb): Do not compute the task ptid when
        debugging a core file.
gdb/ChangeLog
gdb/ada-tasks.c
This page took 0.024915 seconds and 4 git commands to generate.