Initialize context before RtlContextCapture

* exceptions.cc (call_signal_handler): Zero initialize context and set
	context flags, as RlCaptureContext doesn't.

Signed-off-by: Jon TURNEY <jon.turney@dronecode.org.uk>
This commit is contained in:
Jon TURNEY 2015-04-04 16:19:31 +01:00 committed by Corinna Vinschen
parent 19dc6ee82c
commit 65c071bc4d
2 changed files with 11 additions and 2 deletions

View File

@ -1,3 +1,8 @@
2015-04-04 Jon TURNEY <jon.turney@dronecode.org.uk>
* exceptions.cc (call_signal_handler): Zero initialize context and set
context flags, as RlCaptureContext doesn't.
2015-04-09 Corinna Vinschen <corinna@vinschen.de>
* fhandler_dsp.cc (fhandler_dev_dsp::open): Call open_null.

View File

@ -1496,8 +1496,12 @@ _cygtls::call_signal_handler ()
if (thissi.si_cyg)
memcpy (&thiscontext.uc_mcontext, ((cygwin_exception *)thissi.si_cyg)->context(), sizeof(CONTEXT));
else
RtlCaptureContext ((CONTEXT *)&thiscontext.uc_mcontext);
/* FIXME: Really this should be the context which the signal interrupted? */
{
/* FIXME: Really this should be the context which the signal interrupted? */
memset(&thiscontext.uc_mcontext, 0, sizeof(struct __mcontext));
thiscontext.uc_mcontext.ctxflags = CONTEXT_FULL;
RtlCaptureContext ((CONTEXT *)&thiscontext.uc_mcontext);
}
/* FIXME: If/when sigaltstack is implemented, this will need to do
something more complicated */