> I can see why you would want to preserve the signal, but shouldn't you
> also preserve the PID (and any other core related data) as well ?  In
> fact isn't this really a multithreading problem, with a single BFD
> structure being used to represent multiple (potential) thread cores ?

It wouldn't matter for Solaris (and as I said, using the first note section
for the signal in the currently running thread is a Solaris convention, which
might not be true on other platforms), as prstat.pr_pid is the same for all
threads.
Using per thread signal/pid descriptions would gain nothing on Solaris, as
the pid is all the same and the signal in all not currently running threads
is SIGKILL. I suspect that something similar will happen on other platforms
as well though.

> Hi Andrew,
> 
> > Something that has been kicking around the GDB list but is really a 
> > BFD problem.  Anyone want to grab this and run with it?  I don't
> > know enough about core dumps to do the job myself.
> 
> Sadly neither do I.  The patch however looks wrong to me.  With the
> patch applied, the code looks like this:
> 
> >         offset   = offsetof (prstatus_t, pr_reg);
> >         memcpy (&prstat, note->descdata, sizeof (prstat));
> >   
> > !       if (elf_tdata (abfd)->core_signal == 0)
> > !       elf_tdata (abfd)->core_signal = prstat.pr_cursig;
> >         elf_tdata (abfd)->core_pid = prstat.pr_pid;
> >   
> >         /* pr_who exists on:
> 
> So it seem that if core_signal has already been set (from a previous
> thread ?) then it will not be overwritten.  But the process ID will be
> changed, so now you have a signal and a PID that do not match...
> 
> I can see why you would want to preserve the signal, but shouldn't you
> also preserve the PID (and any other core related data) as well ?  In
> fact isn't this really a multithreading problem, with a single BFD
> structure being used to represent multiple (potential) thread cores ?
> 
> Cheers
>         Nick

-- 
Peter Schauer                   [EMAIL PROTECTED]

_______________________________________________
Bug-gdb mailing list
[EMAIL PROTECTED]
http://mail.gnu.org/mailman/listinfo/bug-gdb

Reply via email to