mirror of
https://github.com/reactos/reactos.git
synced 2024-11-02 12:53:33 +00:00
e801b7dda2
RtlpCaptureNonVolatileContextPointers walks the stack and captures the addresses of all non-volatile registers on the stack, when they have been saved first. This is needed to be able to fix up the non-volatile on a system call, which doesn't capture non-volatiles, but relies on them to be restored by the callees. Instead of only checking for the TargetFrame, also check for a mode change, i.e. RIP went from kernel to user, in which case the target frame was not reached yet, because it was too large, but processing can't continue here. RtlSetUnwindContext uses RtlpCaptureNonVolatileContextPointers to set the non-volatile registers in the the stack. They will be picked up, when returning back or unwinding, e.g. to the system call handler. |
||
---|---|---|
.. | ||
amd64 | ||
arm | ||
i386 | ||
powerpc | ||
access.c | ||
acl.c | ||
actctx.c | ||
appverifier.c | ||
assert.c | ||
atom.c | ||
avlsupp.c | ||
avltable.c | ||
bitmap.c | ||
bitmap64.c | ||
bootdata.c | ||
byteswap.c | ||
CMakeLists.txt | ||
compress.c | ||
condvar.c | ||
crc32.c | ||
critical.c | ||
dbgbuffer.c | ||
debug.c | ||
dos8dot3.c | ||
encode.c | ||
env.c | ||
error.c | ||
exception.c | ||
generictable.c | ||
handle.c | ||
heap.c | ||
heap.h | ||
heapdbg.c | ||
heappage.c | ||
heapuser.c | ||
image.c | ||
interlck.c | ||
largeint.c | ||
luid.c | ||
mem.c | ||
memstream.c | ||
message.c | ||
network.c | ||
nls.c | ||
path.c | ||
ppb.c | ||
prefix.c | ||
priv.c | ||
process.c | ||
propvar.c | ||
random.c | ||
rangelist.c | ||
readme.txt | ||
registry.c | ||
res.c | ||
resource.c | ||
rtl.h | ||
rtl_vista.h | ||
rtlavl.h | ||
rtlp.h | ||
runonce.c | ||
rxact.c | ||
sd.c | ||
security.c | ||
sid.c | ||
slist.c | ||
splaytree.c | ||
srw.c | ||
sysvol.c | ||
thread.c | ||
time.c | ||
timerqueue.c | ||
timezone.c | ||
trace.c | ||
unicode.c | ||
unicodeprefix.c | ||
vectoreh.c | ||
version.c | ||
wait.c | ||
workitem.c |
RTL restrictions: ExAllocatePool (and friends) must be used exclusively. RtlAllocateHeap (and friends) must NOT be used! ExAllocatePool (and friends) translate to RtlAllocateHeap (and friends) in ntdll\rtl\libsupp.c. RtlEnterCriticalSection (and friends) must be used exclusively. ExAcquireFastMutex (and friends) must NOT be used! RtlEnterCriticalSection (and friends) translate to ExAcquireFastMutex (and friends) in ntoskrnl\rtl\libsupp.c. This means that RtlEnterCriticalSection (and friends) can NOT be used recursively in RTL. The reason for choosing RtlEnterCriticalSection (and friends) over ExAcquireFastMutex (and friends) is that the FAST_MUTEX struct is smaller than the RTL_CRITICAL_SECTION struct.