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:
parent
a44e09fd49
commit
a5efc75cc1
@ -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-10 Corinna Vinschen <corinna@vinschen.de>
|
||||
|
||||
* fhandler.cc (fhandler_base::open_with_arch): Call open with mode
|
||||
|
@ -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 */
|
||||
|
Loading…
Reference in New Issue
Block a user