mirror of
https://github.com/reactos/reactos.git
synced 2025-05-19 09:10:56 +00:00
![]() The changes are: - Do not allocate an additional WCHAR for the terminating UNICODE_NULL, since we already have that accounted for by sizeof(manifest_dirW) - Use strcpyW intead of memcpy / strlenW, which does the same thing - Add a define for user_shared_data |
||
---|---|---|
.. | ||
amd64 | ||
arm | ||
i386 | ||
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 | ||
utf8.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.