2 * COPYRIGHT: See COPYING in the top level directory
3 * PROJECT: ReactOS System Libraries
5 * PURPOSE: Run-Time Libary Internal Header
6 * PROGRAMMER: Alex Ionescu
9 /* INCLUDES ******************************************************************/
11 /* PAGED_CODE equivalent for user-mode RTL */
13 extern VOID FASTCALL
CHECK_PAGED_CODE_RTL(char *file
, int line
);
14 #define PAGED_CODE_RTL() CHECK_PAGED_CODE_RTL(__FILE__, __LINE__)
16 #define PAGED_CODE_RTL()
20 #define SWAPD(x) ((((x)&0xff)<<24)|(((x)&0xff00)<<8)|(((x)>>8)&0xff00)|(((x)>>24)&0xff))
21 #define SWAPW(x) ((((x)&0xff)<<8)|(((x)>>8)&0xff))
22 #define SWAPQ(x) ((SWAPD((x)&0xffffffff) << 32) | (SWAPD((x)>>32)))
29 #define ROUND_DOWN(n, align) \
30 (((ULONG_PTR)(n)) & ~((align) - 1l))
32 #define ROUND_UP(n, align) \
33 ROUND_DOWN(((ULONG_PTR)(n)) + (align) - 1, (align))
35 #define RVA(m, b) ((PVOID)((ULONG_PTR)(b) + (ULONG_PTR)(m)))
37 extern PVOID MmHighestUserAddress
;
42 _Out_writes_bytes_all_(Length
) VOID UNALIGNED
*Destination
,
43 _In_reads_bytes_(Length
) CONST VOID UNALIGNED
*Source
,
48 RtlpGetStackLimits(PULONG_PTR LowLimit
,
49 PULONG_PTR HighLimit
);
51 PEXCEPTION_REGISTRATION_RECORD
53 RtlpGetExceptionList(VOID
);
57 RtlpSetHeapParameters(IN PRTL_HEAP_PARAMETERS Parameters
);
61 RtlpSetExceptionList(PEXCEPTION_REGISTRATION_RECORD NewExceptionList
);
65 RtlCallVectoredExceptionHandlers(
66 IN PEXCEPTION_RECORD ExceptionRecord
,
72 RtlCallVectoredContinueHandlers(
73 IN PEXCEPTION_RECORD ExceptionRecord
,
77 typedef struct _DISPATCHER_CONTEXT
79 PEXCEPTION_REGISTRATION_RECORD RegistrationPointer
;
80 } DISPATCHER_CONTEXT
, *PDISPATCHER_CONTEXT
;
82 /* These provide support for sharing code between User and Kernel RTL */
101 RtlpCaptureStackLimits(
103 IN ULONG_PTR
*StackBegin
,
104 IN ULONG_PTR
*StackEnd
109 RtlDeleteHeapLock(IN OUT PHEAP_LOCK Lock
);
113 RtlEnterHeapLock(IN OUT PHEAP_LOCK Lock
, IN BOOLEAN Exclusive
);
117 RtlTryEnterHeapLock(IN OUT PHEAP_LOCK Lock
, IN BOOLEAN Exclusive
);
121 RtlInitializeHeapLock(IN OUT PHEAP_LOCK
*Lock
);
125 RtlLeaveHeapLock(IN OUT PHEAP_LOCK Lock
);
129 RtlpCheckForActiveDebugger(VOID
);
133 RtlpHandleDpcStackException(IN PEXCEPTION_REGISTRATION_RECORD RegistrationFrame
,
134 IN ULONG_PTR RegistrationFrameEnd
,
135 IN OUT PULONG_PTR StackLow
,
136 IN OUT PULONG_PTR StackHigh
);
138 #define RtlpAllocateStringMemory RtlpAllocateMemory
139 #define RtlpFreeStringMemory RtlpFreeMemory
143 RtlGetTickCount(VOID
);
144 #define NtGetTickCount RtlGetTickCount
160 EXCEPTION_DISPOSITION
162 RtlpExecuteHandlerForException(PEXCEPTION_RECORD ExceptionRecord
,
163 PEXCEPTION_REGISTRATION_RECORD RegistrationFrame
,
165 PVOID DispatcherContext
,
166 PEXCEPTION_ROUTINE ExceptionHandler
);
168 EXCEPTION_DISPOSITION
170 RtlpExecuteHandlerForUnwind(PEXCEPTION_RECORD ExceptionRecord
,
171 PEXCEPTION_REGISTRATION_RECORD RegistrationFrame
,
173 PVOID DispatcherContext
,
174 PEXCEPTION_ROUTINE ExceptionHandler
);
178 RtlpCheckLogException(IN PEXCEPTION_RECORD ExceptionRecord
,
179 IN PCONTEXT ContextRecord
,
180 IN PVOID ContextData
,
185 RtlpCaptureContext(OUT PCONTEXT ContextRecord
);
188 // Debug Service calls
208 /* Tags for the String Allocators */
209 #define TAG_USTR 'RTSU'
210 #define TAG_ASTR 'RTSA'
211 #define TAG_OSTR 'RTSO'
215 extern HANDLE TimerThreadHandle
;
218 RtlpInitializeTimerThread(VOID
);
221 typedef struct _RTL_BITMAP64
223 ULONG64 SizeOfBitMap
;
225 } RTL_BITMAP64
, *PRTL_BITMAP64
;
227 typedef struct _RTL_BITMAP_RUN64
229 ULONG64 StartingIndex
;
230 ULONG64 NumberOfBits
;
231 } RTL_BITMAP_RUN64
, *PRTL_BITMAP_RUN64
;
236 RtlpUpcaseUnicodeChar(IN WCHAR Source
);
240 RtlpDowncaseUnicodeChar(IN WCHAR Source
);