Mail Archives: djgpp-workers/1999/01/25/02:20:07
Thanks for the feedback.
On Mon, 25 Jan 1999, Bill Currie wrote:
> > Usually these problems happened for me when there were more than a single
> > signal that could be raised. For example, the problems with SIGALRM
> > above happened when the program in question was compiled with -pg.
> >
> > Any ideas?
>
> The signal is comming in while the app is still in the exception code?
How can this be? The exception-handling code in exceptn.S fixes the
DS limit and restores ES and SS as one of the first things, before it
jumps to any application code, and that code runs with interrupts
disabled (I think).
> > One problem that particularly bothers me is that I cannot find the place
> > in the exception-handling code where we switch back to the normal
> > application stack. Can somebody point my stupid self to the right spot?
> > I cannot analyze these problems without knowing where they should have
> > been handled.
>
> I believe this is handled by the longjump code. As I remember it, *all*
> registers are restored from the longjump buffer, including the seg regs.
What longjmp? The one near the end of __djgpp_exception_processor?
If so, this is a disaster: it means that if I define a non-trivial
signal handler, it runs entirely on the exception stack (which is
quite small), because `longjmp' is called after `raise'.
Imagine that, while the signal handler runs, another signal arrives, and
another--soon enough we will overflow the exception stack.
Charles, is this true?
- Raw text -