mirror of
git://git.sv.gnu.org/emacs.git
synced 2025-12-24 06:20:43 -08:00
Implement MutatorContextCheck on Windows. Add AVERT(MutatorContext, context) in PoolAccess and other functions. Document initialization functions MutatorContextInitFault and MutatorContextInitThread and implement them on Windows. Add a union discriminator to MutatorContextStruct on Windows so that we don't accidentally try to get the stack pointer from a fault context, or the exception address from a thread context. Copied from Perforce Change: 192567 ServerID: perforce.ravenbrook.com
137 lines
4.5 KiB
C
137 lines
4.5 KiB
C
/* prmcw3.c: MUTATOR CONTEXT FOR WIN32
|
|
*
|
|
* $Id$
|
|
* Copyright (c) 2016 Ravenbrook Limited. See end of file for license.
|
|
*
|
|
* .purpose: Implement the mutator context module. See <design/prmc/>.
|
|
*
|
|
*
|
|
* ASSUMPTIONS
|
|
*
|
|
* .context.regroots: The root registers are assumed to be recorded in
|
|
* the context at word-aligned boundaries.
|
|
*
|
|
* .context.flags: The ContextFlags field in the CONTEXT structure
|
|
* determines what is recorded by GetThreadContext. This must include:
|
|
*
|
|
* .context.sp: CONTEXT_CONTROL, so that the stack pointer (Esp on
|
|
* IA-32; Rsp on x86-64) is recorded.
|
|
*
|
|
* .context.regroots: CONTEXT_INTEGER, so that the root registers
|
|
* (Edi, Esi, Ebx, Edx, Ecx, Eax on IA-32; Rdi, Rsi, Rbx, Rbp, Rdx,
|
|
* Rcx, Rax, R8, ..., R15 on x86-64) are recorded.
|
|
*
|
|
* See the header WinNT.h for documentation of CONTEXT and
|
|
* ContextFlags.
|
|
*/
|
|
|
|
#include "prmcw3.h"
|
|
|
|
SRCID(prmcw3, "$Id$");
|
|
|
|
#if !defined(MPS_OS_W3)
|
|
#error "prmcw3.c is specific to MPS_OS_W3"
|
|
#endif
|
|
|
|
|
|
Bool MutatorContextCheck(MutatorContext context)
|
|
{
|
|
CHECKS(MutatorContext, context);
|
|
CHECKL(NONNEGATIVE(context->var));
|
|
CHECKL(context->var < MutatorContextLIMIT);
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
Res MutatorContextInitThread(MutatorContext context, HANDLE thread)
|
|
{
|
|
BOOL success;
|
|
|
|
AVER(context != NULL);
|
|
|
|
context->var = MutatorContextTHREAD;
|
|
/* This dumps the relevant registers into the context */
|
|
/* .context.flags */
|
|
context->the.context.ContextFlags = CONTEXT_CONTROL | CONTEXT_INTEGER;
|
|
success = GetThreadContext(thread, &context->the.context);
|
|
if (!success)
|
|
return ResFAIL;
|
|
context->sig = MutatorContextSig;
|
|
|
|
AVERT(MutatorContext, context);
|
|
return ResOK;
|
|
}
|
|
|
|
|
|
void MutatorContextInitFault(MutatorContext context,
|
|
LPEXCEPTION_POINTERS ep)
|
|
{
|
|
AVER(context != NULL);
|
|
AVER(ep != NULL);
|
|
|
|
context->var = MutatorContextFAULT;
|
|
context->the.ep = ep;
|
|
context->sig = MutatorContextSig;
|
|
|
|
AVERT(MutatorContext, context);
|
|
}
|
|
|
|
|
|
Res MutatorContextScan(ScanState ss, MutatorContext context,
|
|
mps_area_scan_t scan_area, void *closure)
|
|
{
|
|
CONTEXT *cx;
|
|
Res res;
|
|
|
|
AVERT(ScanState, ss);
|
|
AVERT(MutatorContext, context);
|
|
AVER(context->var == MutatorContextTHREAD);
|
|
|
|
cx = &context->the.context;
|
|
res = TraceScanArea(ss, (Word *)cx, (Word *)((char *)cx + sizeof *cx),
|
|
scan_area, closure); /* .context.regroots */
|
|
|
|
return res;
|
|
}
|
|
|
|
|
|
/* C. COPYRIGHT AND LICENSE
|
|
*
|
|
* Copyright (C) 2001-2016 Ravenbrook Limited <http://www.ravenbrook.com/>.
|
|
* All rights reserved. This is an open source license. Contact
|
|
* Ravenbrook for commercial licensing options.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions are
|
|
* met:
|
|
*
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
*
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
*
|
|
* 3. Redistributions in any form must be accompanied by information on how
|
|
* to obtain complete source code for this software and any accompanying
|
|
* software that uses this software. The source code must either be
|
|
* included in the distribution or be available for no more than the cost
|
|
* of distribution plus a nominal fee, and must be freely redistributable
|
|
* under reasonable conditions. For an executable file, complete source
|
|
* code means the source code for all modules it contains. It does not
|
|
* include source code for modules or files that typically accompany the
|
|
* major components of the operating system on which the executable file
|
|
* runs.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
|
|
* IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
|
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
|
* PURPOSE, OR NON-INFRINGEMENT, ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
* COPYRIGHT HOLDERS AND CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
|
|
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|