| 1 | /* $Id: ntdll.h,v 1.12 2000-08-20 15:16:57 phaller Exp $ */ | 
|---|
| 2 |  | 
|---|
| 3 | /* | 
|---|
| 4 | this file defines interfaces mainly exposed to device drivers and | 
|---|
| 5 | native nt dll's | 
|---|
| 6 |  | 
|---|
| 7 | */ | 
|---|
| 8 | #ifndef __WINE_NTDDK_H | 
|---|
| 9 | #define __WINE_NTDDK_H | 
|---|
| 10 |  | 
|---|
| 11 | #include <os2win.h> | 
|---|
| 12 | #include <misc.h> | 
|---|
| 13 |  | 
|---|
| 14 | #include <ntdef.h> | 
|---|
| 15 | #include <winnt.h> | 
|---|
| 16 | #include "winbase.h"                     /* fixme: should be taken out sometimes */ | 
|---|
| 17 |  | 
|---|
| 18 | #ifdef __cplusplus | 
|---|
| 19 | extern "C" { | 
|---|
| 20 | #endif | 
|---|
| 21 |  | 
|---|
| 22 |  | 
|---|
| 23 | /* Win32 register functions */ | 
|---|
| 24 | // @@@PH what does GCC with this ? | 
|---|
| 25 | #define REGS_FUNC(name) __regs_##name | 
|---|
| 26 |  | 
|---|
| 27 |  | 
|---|
| 28 | /**************************************************************************** | 
|---|
| 29 | * adjust WINE header to ODIN                                               * | 
|---|
| 30 | ****************************************************************************/ | 
|---|
| 31 |  | 
|---|
| 32 | #ifdef NTAPI | 
|---|
| 33 | #  undef NTAPI | 
|---|
| 34 | #endif | 
|---|
| 35 | #define NTAPI WIN32API | 
|---|
| 36 |  | 
|---|
| 37 | #ifdef WINAPI | 
|---|
| 38 | #  undef WINAPI | 
|---|
| 39 | #endif | 
|---|
| 40 | #define WINAPI WIN32API | 
|---|
| 41 |  | 
|---|
| 42 | #ifndef BOOLEAN | 
|---|
| 43 | #  define BOOLEAN BOOL | 
|---|
| 44 | #endif | 
|---|
| 45 |  | 
|---|
| 46 |  | 
|---|
| 47 | //SvL: Internal heap allocation definitions for NTDLL | 
|---|
| 48 | extern HANDLE NTDLL_hHeap; | 
|---|
| 49 | #define Heap_Alloc(a)   HeapAlloc(NTDLL_hHeap, HEAP_ZERO_MEMORY, a) | 
|---|
| 50 | #define Heap_Free(a)    HeapFree(NTDLL_hHeap, 0, (PVOID)a) | 
|---|
| 51 |  | 
|---|
| 52 | typedef struct _IO_STATUS_BLOCK | 
|---|
| 53 | {  union | 
|---|
| 54 | { NTSTATUS Status; | 
|---|
| 55 | PVOID Pointer; | 
|---|
| 56 | } u; | 
|---|
| 57 | ULONG_PTR Information; | 
|---|
| 58 | } IO_STATUS_BLOCK, *PIO_STATUS_BLOCK; | 
|---|
| 59 |  | 
|---|
| 60 | // @@@PH - this seems to be wrong in WINE | 
|---|
| 61 | // typedef VOID (NTAPI* PIO_APC_ROUTINE) ( PVOID ApcContext, PIO_STATUS_BLOCK IoStatusBlock, ULONG Reserved ); | 
|---|
| 62 | typedef PVOID PIO_APC_ROUTINE; | 
|---|
| 63 |  | 
|---|
| 64 | typedef enum _KEY_INFORMATION_CLASS { | 
|---|
| 65 | KeyBasicInformation, | 
|---|
| 66 | KeyNodeInformation, | 
|---|
| 67 | KeyFullInformation | 
|---|
| 68 | } KEY_INFORMATION_CLASS; | 
|---|
| 69 |  | 
|---|
| 70 | typedef enum _KEY_VALUE_INFORMATION_CLASS { | 
|---|
| 71 | KeyValueBasicInformation, | 
|---|
| 72 | KeyValueFullInformation, | 
|---|
| 73 | KeyValuePartialInformation, | 
|---|
| 74 | KeyValueFullInformationAlign64, | 
|---|
| 75 | KeyValuePartialInformationAlign64 | 
|---|
| 76 | } KEY_VALUE_INFORMATION_CLASS; | 
|---|
| 77 |  | 
|---|
| 78 | typedef enum _THREADINFOCLASS | 
|---|
| 79 | {  ThreadBasicInformation, | 
|---|
| 80 | ThreadTimes, | 
|---|
| 81 | ThreadPriority, | 
|---|
| 82 | ThreadBasePriority, | 
|---|
| 83 | ThreadAffinityMask, | 
|---|
| 84 | ThreadImpersonationToken, | 
|---|
| 85 | ThreadDescriptorTableEntry, | 
|---|
| 86 | ThreadEnableAlignmentFaultFixup, | 
|---|
| 87 | ThreadEventPair_Reusable, | 
|---|
| 88 | ThreadQuerySetWin32StartAddress, | 
|---|
| 89 | ThreadZeroTlsCell, | 
|---|
| 90 | ThreadPerformanceCount, | 
|---|
| 91 | ThreadAmILastThread, | 
|---|
| 92 | ThreadIdealProcessor, | 
|---|
| 93 | ThreadPriorityBoost, | 
|---|
| 94 | ThreadSetTlsArrayAddress, | 
|---|
| 95 | ThreadIsIoPending, | 
|---|
| 96 | MaxThreadInfoClass | 
|---|
| 97 | } THREADINFOCLASS; | 
|---|
| 98 |  | 
|---|
| 99 | typedef enum _FILE_INFORMATION_CLASS { | 
|---|
| 100 | FileDirectoryInformation = 1, | 
|---|
| 101 | FileFullDirectoryInformation, | 
|---|
| 102 | FileBothDirectoryInformation, | 
|---|
| 103 | FileBasicInformation, | 
|---|
| 104 | FileStandardInformation, | 
|---|
| 105 | FileInternalInformation, | 
|---|
| 106 | FileEaInformation, | 
|---|
| 107 | FileAccessInformation, | 
|---|
| 108 | FileNameInformation, | 
|---|
| 109 | FileRenameInformation, | 
|---|
| 110 | FileLinkInformation, | 
|---|
| 111 | FileNamesInformation, | 
|---|
| 112 | FileDispositionInformation, | 
|---|
| 113 | FilePositionInformation, | 
|---|
| 114 | FileFullEaInformation, | 
|---|
| 115 | FileModeInformation, | 
|---|
| 116 | FileAlignmentInformation, | 
|---|
| 117 | FileAllInformation, | 
|---|
| 118 | FileAllocationInformation, | 
|---|
| 119 | FileEndOfFileInformation, | 
|---|
| 120 | FileAlternateNameInformation, | 
|---|
| 121 | FileStreamInformation, | 
|---|
| 122 | FilePipeInformation, | 
|---|
| 123 | FilePipeLocalInformation, | 
|---|
| 124 | FilePipeRemoteInformation, | 
|---|
| 125 | FileMailslotQueryInformation, | 
|---|
| 126 | FileMailslotSetInformation, | 
|---|
| 127 | FileCompressionInformation, | 
|---|
| 128 | FileObjectIdInformation, | 
|---|
| 129 | FileCompletionInformation, | 
|---|
| 130 | FileMoveClusterInformation, | 
|---|
| 131 | FileQuotaInformation, | 
|---|
| 132 | FileReparsePointInformation, | 
|---|
| 133 | FileNetworkOpenInformation, | 
|---|
| 134 | FileAttributeTagInformation, | 
|---|
| 135 | FileTrackingInformation, | 
|---|
| 136 | FileMaximumInformation | 
|---|
| 137 | } FILE_INFORMATION_CLASS, *PFILE_INFORMATION_CLASS; | 
|---|
| 138 |  | 
|---|
| 139 | typedef enum _SECTION_INHERIT | 
|---|
| 140 | { | 
|---|
| 141 | ViewShare = 1, | 
|---|
| 142 | ViewUnmap = 2 | 
|---|
| 143 |  | 
|---|
| 144 | } SECTION_INHERIT; | 
|---|
| 145 |  | 
|---|
| 146 | /* | 
|---|
| 147 | placeholder | 
|---|
| 148 | */ | 
|---|
| 149 | typedef enum _OBJECT_INFORMATION_CLASS | 
|---|
| 150 | { | 
|---|
| 151 | DunnoTheConstants1 | 
|---|
| 152 |  | 
|---|
| 153 | } OBJECT_INFORMATION_CLASS, *POBJECT_INFORMATION_CLASS; | 
|---|
| 154 |  | 
|---|
| 155 |  | 
|---|
| 156 | /* | 
|---|
| 157 | * NtQuerySystemInformation | 
|---|
| 158 | */ | 
|---|
| 159 |  | 
|---|
| 160 | typedef enum SYSTEM_INFORMATION_CLASS | 
|---|
| 161 | {  Unknown1 = 1, | 
|---|
| 162 | Unknown2, | 
|---|
| 163 | Unknown3, | 
|---|
| 164 | Unknown4, | 
|---|
| 165 | SystemPerformanceInformation | 
|---|
| 166 | } SYSTEM_INFORMATION_CLASS, *PSYSTEM_INFORMATION_CLASS; | 
|---|
| 167 |  | 
|---|
| 168 | /* reading coffee grounds... */ | 
|---|
| 169 | typedef struct _THREAD_INFO | 
|---|
| 170 | {  DWORD Unknown1[6]; | 
|---|
| 171 | DWORD ThreadID; | 
|---|
| 172 | DWORD Unknown2[3]; | 
|---|
| 173 | DWORD Status; | 
|---|
| 174 | DWORD WaitReason; | 
|---|
| 175 | DWORD Unknown3[4]; | 
|---|
| 176 | } THREAD_INFO, PTHREAD_INFO; | 
|---|
| 177 |  | 
|---|
| 178 | typedef struct _VM_COUNTERS_ | 
|---|
| 179 | {  ULONG PeakVirtualSize; | 
|---|
| 180 | ULONG VirtualSize; | 
|---|
| 181 | ULONG PageFaultCount; | 
|---|
| 182 | ULONG PeakWorkingSetSize; | 
|---|
| 183 | ULONG WorkingSetSize; | 
|---|
| 184 | ULONG QuotaPeakPagedPoolUsage; | 
|---|
| 185 | ULONG QuotaPagedPoolUsage; | 
|---|
| 186 | ULONG QuotaPeakNonPagedPoolUsage; | 
|---|
| 187 | ULONG QuotaNonPagedPoolUsage; | 
|---|
| 188 | ULONG PagefileUsage; | 
|---|
| 189 | ULONG PeakPagefileUsage; | 
|---|
| 190 | } VM_COUNTERS, *PVM_COUNTERS; | 
|---|
| 191 |  | 
|---|
| 192 | typedef struct _PROCESS_INFO | 
|---|
| 193 | {  DWORD    Offset;                         /* 00 offset to next PROCESS_INFO ok*/ | 
|---|
| 194 | DWORD    ThreadCount;                 /* 04 number of ThreadInfo member ok */ | 
|---|
| 195 | DWORD    Unknown1[6]; | 
|---|
| 196 | FILETIME CreationTime;                /* 20 */ | 
|---|
| 197 | DWORD    Unknown2[5]; | 
|---|
| 198 | PWCHAR      ProcessName;              /* 3c ok */ | 
|---|
| 199 | DWORD    BasePriority; | 
|---|
| 200 | DWORD    ProcessID;                   /* 44 ok*/ | 
|---|
| 201 | DWORD    ParentProcessID; | 
|---|
| 202 | DWORD    HandleCount; | 
|---|
| 203 | DWORD    Unknown3[2];                 /* 50 */ | 
|---|
| 204 | ULONG    PeakVirtualSize; | 
|---|
| 205 | ULONG    VirtualSize; | 
|---|
| 206 | ULONG    PageFaultCount; | 
|---|
| 207 | ULONG    PeakWorkingSetSize; | 
|---|
| 208 | ULONG    WorkingSetSize; | 
|---|
| 209 | ULONG    QuotaPeakPagedPoolUsage; | 
|---|
| 210 | ULONG    QuotaPagedPoolUsage; | 
|---|
| 211 | ULONG    QuotaPeakNonPagedPoolUsage; | 
|---|
| 212 | ULONG    QuotaNonPagedPoolUsage; | 
|---|
| 213 | ULONG    PagefileUsage; | 
|---|
| 214 | ULONG    PeakPagefileUsage; | 
|---|
| 215 | DWORD    PrivateBytes; | 
|---|
| 216 | DWORD    Unknown6[4]; | 
|---|
| 217 | THREAD_INFO    ati[ANYSIZE_ARRAY];    /* 94 size=0x40*/ | 
|---|
| 218 | } PROCESS_INFO, PPROCESS_INFO; | 
|---|
| 219 |  | 
|---|
| 220 | NTSTATUS WINAPI NtQuerySystemInformation( | 
|---|
| 221 | IN SYSTEM_INFORMATION_CLASS SystemInformationClass, | 
|---|
| 222 | OUT PVOID SystemInformation, | 
|---|
| 223 | IN ULONG Length, | 
|---|
| 224 | OUT PULONG ResultLength); | 
|---|
| 225 |  | 
|---|
| 226 | /* | 
|---|
| 227 | * system configuration | 
|---|
| 228 | */ | 
|---|
| 229 |  | 
|---|
| 230 |  | 
|---|
| 231 | typedef struct _SYSTEM_TIME_ADJUSTMENT | 
|---|
| 232 | { | 
|---|
| 233 | ULONG TimeAdjustment; | 
|---|
| 234 | BOOLEAN  TimeAdjustmentDisabled; | 
|---|
| 235 |  | 
|---|
| 236 | } SYSTEM_TIME_ADJUSTMENT, *PSYSTEM_TIME_ADJUSTMENT; | 
|---|
| 237 |  | 
|---|
| 238 | typedef struct _SYSTEM_CONFIGURATION_INFO | 
|---|
| 239 | { | 
|---|
| 240 | union | 
|---|
| 241 | { ULONG  OemId; | 
|---|
| 242 | struct | 
|---|
| 243 | { WORD ProcessorArchitecture; | 
|---|
| 244 | WORD Reserved; | 
|---|
| 245 | } tag1; | 
|---|
| 246 | } tag2; | 
|---|
| 247 | ULONG PageSize; | 
|---|
| 248 | PVOID MinimumApplicationAddress; | 
|---|
| 249 | PVOID MaximumApplicationAddress; | 
|---|
| 250 | ULONG ActiveProcessorMask; | 
|---|
| 251 | ULONG NumberOfProcessors; | 
|---|
| 252 | ULONG ProcessorType; | 
|---|
| 253 | ULONG AllocationGranularity; | 
|---|
| 254 | WORD  ProcessorLevel; | 
|---|
| 255 | WORD  ProcessorRevision; | 
|---|
| 256 |  | 
|---|
| 257 | } SYSTEM_CONFIGURATION_INFO, *PSYSTEM_CONFIGURATION_INFO; | 
|---|
| 258 |  | 
|---|
| 259 |  | 
|---|
| 260 | typedef struct _SYSTEM_CACHE_INFORMATION | 
|---|
| 261 | { | 
|---|
| 262 | ULONG CurrentSize; | 
|---|
| 263 | ULONG PeakSize; | 
|---|
| 264 | ULONG PageFaultCount; | 
|---|
| 265 | ULONG MinimumWorkingSet; | 
|---|
| 266 | ULONG MaximumWorkingSet; | 
|---|
| 267 | ULONG Unused[4]; | 
|---|
| 268 |  | 
|---|
| 269 | } SYSTEM_CACHE_INFORMATION; | 
|---|
| 270 |  | 
|---|
| 271 | /* | 
|---|
| 272 | * NtQueryProcessInformation | 
|---|
| 273 | */ | 
|---|
| 274 |  | 
|---|
| 275 | /* parameter ProcessInformationClass */ | 
|---|
| 276 |  | 
|---|
| 277 | typedef enum _PROCESSINFOCLASS | 
|---|
| 278 | {  ProcessBasicInformation, | 
|---|
| 279 | ProcessQuotaLimits, | 
|---|
| 280 | ProcessIoCounters, | 
|---|
| 281 | ProcessVmCounters, | 
|---|
| 282 | ProcessTimes, | 
|---|
| 283 | ProcessBasePriority, | 
|---|
| 284 | ProcessRaisePriority, | 
|---|
| 285 | ProcessDebugPort, | 
|---|
| 286 | ProcessExceptionPort, | 
|---|
| 287 | ProcessAccessToken, | 
|---|
| 288 | ProcessLdtInformation, | 
|---|
| 289 | ProcessLdtSize, | 
|---|
| 290 | ProcessDefaultHardErrorMode, | 
|---|
| 291 | ProcessIoPortHandlers, | 
|---|
| 292 | ProcessPooledUsageAndLimits, | 
|---|
| 293 | ProcessWorkingSetWatch, | 
|---|
| 294 | ProcessUserModeIOPL, | 
|---|
| 295 | ProcessEnableAlignmentFaultFixup, | 
|---|
| 296 | ProcessPriorityClass, | 
|---|
| 297 | ProcessWx86Information, | 
|---|
| 298 | ProcessHandleCount, | 
|---|
| 299 | ProcessAffinityMask, | 
|---|
| 300 | ProcessPriorityBoost, | 
|---|
| 301 | ProcessDeviceMap, | 
|---|
| 302 | ProcessSessionInformation, | 
|---|
| 303 | ProcessForegroundInformation, | 
|---|
| 304 | ProcessWow64Information, | 
|---|
| 305 | MaxProcessInfoClass | 
|---|
| 306 | } PROCESSINFOCLASS; | 
|---|
| 307 |  | 
|---|
| 308 | /* parameter ProcessInformation (depending on ProcessInformationClass) */ | 
|---|
| 309 |  | 
|---|
| 310 | typedef struct _PROCESS_BASIC_INFORMATION | 
|---|
| 311 | {  DWORD ExitStatus; | 
|---|
| 312 | DWORD PebBaseAddress; | 
|---|
| 313 | DWORD AffinityMask; | 
|---|
| 314 | DWORD BasePriority; | 
|---|
| 315 | ULONG UniqueProcessId; | 
|---|
| 316 | ULONG InheritedFromUniqueProcessId; | 
|---|
| 317 | } PROCESS_BASIC_INFORMATION; | 
|---|
| 318 |  | 
|---|
| 319 | NTSTATUS WINAPI NtQueryInformationProcess( | 
|---|
| 320 | IN HANDLE ProcessHandle, | 
|---|
| 321 | IN PROCESSINFOCLASS ProcessInformationClass, | 
|---|
| 322 | OUT PVOID ProcessInformation, | 
|---|
| 323 | IN ULONG ProcessInformationLength, | 
|---|
| 324 | OUT PULONG ReturnLength); | 
|---|
| 325 |  | 
|---|
| 326 | #define NtCurrentProcess() ( (HANDLE) -1 ) | 
|---|
| 327 |  | 
|---|
| 328 | /* | 
|---|
| 329 | * timer | 
|---|
| 330 | */ | 
|---|
| 331 |  | 
|---|
| 332 | typedef enum _TIMER_TYPE | 
|---|
| 333 | { | 
|---|
| 334 | NotificationTimer, | 
|---|
| 335 | SynchronizationTimer | 
|---|
| 336 |  | 
|---|
| 337 | } TIMER_TYPE; | 
|---|
| 338 |  | 
|---|
| 339 | /* | 
|---|
| 340 | * token functions | 
|---|
| 341 | */ | 
|---|
| 342 |  | 
|---|
| 343 | NTSTATUS WINAPI NtOpenProcessToken( | 
|---|
| 344 | HANDLE ProcessHandle, | 
|---|
| 345 | DWORD DesiredAccess, | 
|---|
| 346 | HANDLE *TokenHandle); | 
|---|
| 347 |  | 
|---|
| 348 | NTSTATUS WINAPI NtOpenThreadToken( | 
|---|
| 349 | HANDLE ThreadHandle, | 
|---|
| 350 | DWORD DesiredAccess, | 
|---|
| 351 | BOOLEAN OpenAsSelf, | 
|---|
| 352 | HANDLE *TokenHandle); | 
|---|
| 353 |  | 
|---|
| 354 | NTSTATUS WINAPI NtAdjustPrivilegesToken( | 
|---|
| 355 | IN HANDLE TokenHandle, | 
|---|
| 356 | IN BOOLEAN DisableAllPrivileges, | 
|---|
| 357 | IN PTOKEN_PRIVILEGES NewState, | 
|---|
| 358 | IN DWORD BufferLength, | 
|---|
| 359 | OUT PTOKEN_PRIVILEGES PreviousState, | 
|---|
| 360 | OUT PDWORD ReturnLength); | 
|---|
| 361 |  | 
|---|
| 362 | NTSTATUS WINAPI NtQueryInformationToken( | 
|---|
| 363 | HANDLE token, | 
|---|
| 364 | DWORD tokeninfoclass, | 
|---|
| 365 | LPVOID tokeninfo, | 
|---|
| 366 | DWORD tokeninfolength, | 
|---|
| 367 | LPDWORD retlen ); | 
|---|
| 368 |  | 
|---|
| 369 | /* | 
|---|
| 370 | * sid functions | 
|---|
| 371 | */ | 
|---|
| 372 |  | 
|---|
| 373 | BOOLEAN WINAPI RtlAllocateAndInitializeSid ( PSID_IDENTIFIER_AUTHORITY pIdentifierAuthority, | 
|---|
| 374 | BYTE nSubAuthorityCount, | 
|---|
| 375 | DWORD nSubAuthority0, | 
|---|
| 376 | DWORD nSubAuthority1, | 
|---|
| 377 | DWORD nSubAuthority2, | 
|---|
| 378 | DWORD nSubAuthority3, | 
|---|
| 379 | DWORD nSubAuthority4, | 
|---|
| 380 | DWORD nSubAuthority5, | 
|---|
| 381 | DWORD nSubAuthority6, | 
|---|
| 382 | DWORD nSubAuthority7, | 
|---|
| 383 | PSID *pSid); | 
|---|
| 384 |  | 
|---|
| 385 | BOOL WINAPI RtlEqualSid(PSID pSid1, PSID pSid2); | 
|---|
| 386 | BOOL WINAPI RtlEqualPrefixSid (PSID pSid1, PSID pSid2); | 
|---|
| 387 | BOOL WINAPI RtlValidSid( PSID pSid ); | 
|---|
| 388 | VOID* WINAPI RtlFreeSid(PSID pSid); | 
|---|
| 389 | DWORD WINAPI RtlLengthRequiredSid(DWORD nrofsubauths); | 
|---|
| 390 | DWORD WINAPI RtlLengthSid(PSID sid); | 
|---|
| 391 | DWORD WINAPI RtlInitializeSid(PSID PSID,PSID_IDENTIFIER_AUTHORITY PSIDauth, DWORD c); | 
|---|
| 392 | LPDWORD WINAPI RtlSubAuthoritySid(PSID PSID,DWORD nr); | 
|---|
| 393 | LPBYTE WINAPI RtlSubAuthorityCountSid(PSID PSID); | 
|---|
| 394 | PSID_IDENTIFIER_AUTHORITY WINAPI RtlIdentifierAuthoritySid( PSID pSid ); | 
|---|
| 395 | DWORD WINAPI RtlCopySid(DWORD len,PSID to,PSID from); | 
|---|
| 396 |  | 
|---|
| 397 | /* | 
|---|
| 398 | * security descriptor functions | 
|---|
| 399 | */ | 
|---|
| 400 |  | 
|---|
| 401 | NTSTATUS WINAPI RtlCreateSecurityDescriptor( | 
|---|
| 402 | PSECURITY_DESCRIPTOR lpsd, | 
|---|
| 403 | DWORD rev); | 
|---|
| 404 |  | 
|---|
| 405 | NTSTATUS WINAPI RtlValidSecurityDescriptor( | 
|---|
| 406 | PSECURITY_DESCRIPTOR SecurityDescriptor); | 
|---|
| 407 |  | 
|---|
| 408 | ULONG WINAPI RtlLengthSecurityDescriptor( | 
|---|
| 409 | PSECURITY_DESCRIPTOR SecurityDescriptor); | 
|---|
| 410 |  | 
|---|
| 411 | NTSTATUS WINAPI RtlGetDaclSecurityDescriptor( | 
|---|
| 412 | IN PSECURITY_DESCRIPTOR pSecurityDescriptor, | 
|---|
| 413 | OUT PBOOLEAN lpbDaclPresent, | 
|---|
| 414 | OUT PACL *pDacl, | 
|---|
| 415 | OUT PBOOLEAN lpbDaclDefaulted); | 
|---|
| 416 |  | 
|---|
| 417 | NTSTATUS WINAPI RtlSetDaclSecurityDescriptor ( | 
|---|
| 418 | PSECURITY_DESCRIPTOR lpsd, | 
|---|
| 419 | BOOLEAN daclpresent, | 
|---|
| 420 | PACL dacl, | 
|---|
| 421 | BOOLEAN dacldefaulted ); | 
|---|
| 422 |  | 
|---|
| 423 | NTSTATUS WINAPI RtlGetSaclSecurityDescriptor( | 
|---|
| 424 | IN PSECURITY_DESCRIPTOR pSecurityDescriptor, | 
|---|
| 425 | OUT PBOOLEAN lpbSaclPresent, | 
|---|
| 426 | OUT PACL *pSacl, | 
|---|
| 427 | OUT PBOOLEAN lpbSaclDefaulted); | 
|---|
| 428 |  | 
|---|
| 429 | NTSTATUS WINAPI RtlSetSaclSecurityDescriptor ( | 
|---|
| 430 | PSECURITY_DESCRIPTOR lpsd, | 
|---|
| 431 | BOOLEAN saclpresent, | 
|---|
| 432 | PACL sacl, | 
|---|
| 433 | BOOLEAN sacldefaulted); | 
|---|
| 434 |  | 
|---|
| 435 | NTSTATUS WINAPI RtlGetOwnerSecurityDescriptor( | 
|---|
| 436 | PSECURITY_DESCRIPTOR SecurityDescriptor, | 
|---|
| 437 | PSID *Owner, | 
|---|
| 438 | PBOOLEAN OwnerDefaulted); | 
|---|
| 439 |  | 
|---|
| 440 | NTSTATUS WINAPI RtlSetOwnerSecurityDescriptor( | 
|---|
| 441 | PSECURITY_DESCRIPTOR lpsd, | 
|---|
| 442 | PSID owner, | 
|---|
| 443 | BOOLEAN ownerdefaulted); | 
|---|
| 444 |  | 
|---|
| 445 | NTSTATUS WINAPI RtlSetGroupSecurityDescriptor ( | 
|---|
| 446 | PSECURITY_DESCRIPTOR lpsd, | 
|---|
| 447 | PSID group, | 
|---|
| 448 | BOOLEAN groupdefaulted); | 
|---|
| 449 |  | 
|---|
| 450 | NTSTATUS WINAPI RtlGetGroupSecurityDescriptor( | 
|---|
| 451 | PSECURITY_DESCRIPTOR SecurityDescriptor, | 
|---|
| 452 | PSID *Group, | 
|---|
| 453 | PBOOLEAN GroupDefaulted); | 
|---|
| 454 |  | 
|---|
| 455 | /* ############################## | 
|---|
| 456 | ######   ACL FUNCTIONS                ###### | 
|---|
| 457 | ############################## | 
|---|
| 458 | */ | 
|---|
| 459 |  | 
|---|
| 460 | DWORD WINAPI RtlCreateAcl(PACL acl,DWORD size,DWORD rev); | 
|---|
| 461 |  | 
|---|
| 462 | BOOLEAN WINAPI RtlFirstFreeAce( | 
|---|
| 463 | PACL acl, | 
|---|
| 464 | PACE_HEADER *x); | 
|---|
| 465 |  | 
|---|
| 466 | NTSTATUS WINAPI RtlAddAce( | 
|---|
| 467 | PACL acl, | 
|---|
| 468 | DWORD rev, | 
|---|
| 469 | DWORD xnrofaces, | 
|---|
| 470 | PACE_HEADER acestart, | 
|---|
| 471 | DWORD acelen); | 
|---|
| 472 |  | 
|---|
| 473 | DWORD WINAPI RtlAddAccessAllowedAce(DWORD x1,DWORD x2,DWORD x3,DWORD x4); | 
|---|
| 474 | DWORD WINAPI RtlGetAce(PACL pAcl,DWORD dwAceIndex,LPVOID *pAce ); | 
|---|
| 475 |  | 
|---|
| 476 | /* | 
|---|
| 477 | * string functions | 
|---|
| 478 | */ | 
|---|
| 479 |  | 
|---|
| 480 | DWORD WINAPI RtlAnsiStringToUnicodeString(PUNICODE_STRING uni,PANSI_STRING ansi,BOOLEAN doalloc); | 
|---|
| 481 | DWORD WINAPI RtlOemStringToUnicodeString(PUNICODE_STRING uni,PSTRING ansi,BOOLEAN doalloc); | 
|---|
| 482 | DWORD WINAPI RtlMultiByteToUnicodeN(LPWSTR unistr,DWORD unilen,LPDWORD reslen,LPSTR oemstr,DWORD oemlen); | 
|---|
| 483 | DWORD WINAPI RtlOemToUnicodeN(LPWSTR unistr,DWORD unilen,LPDWORD reslen,LPSTR oemstr,DWORD oemlen); | 
|---|
| 484 | VOID WINAPI RtlInitAnsiString(PANSI_STRING target,LPCSTR source); | 
|---|
| 485 | VOID WINAPI RtlInitString(PSTRING target,LPCSTR source); | 
|---|
| 486 | VOID WINAPI RtlInitUnicodeString(PUNICODE_STRING target,LPCWSTR source); | 
|---|
| 487 | VOID WINAPI RtlFreeUnicodeString(PUNICODE_STRING str); | 
|---|
| 488 | VOID WINAPI RtlFreeAnsiString(PANSI_STRING AnsiString); | 
|---|
| 489 | DWORD WINAPI RtlUnicodeToOemN(LPSTR oemstr,DWORD oemlen,LPDWORD reslen,LPWSTR unistr,DWORD unilen); | 
|---|
| 490 | DWORD WINAPI RtlUnicodeStringToOemString(PANSI_STRING oem,PUNICODE_STRING uni,BOOLEAN alloc); | 
|---|
| 491 | DWORD WINAPI RtlUnicodeStringToAnsiString(PANSI_STRING oem,PUNICODE_STRING uni,BOOLEAN alloc); | 
|---|
| 492 | DWORD WINAPI RtlEqualUnicodeString(PUNICODE_STRING s1,PUNICODE_STRING s2,DWORD x); | 
|---|
| 493 | DWORD WINAPI RtlUpcaseUnicodeString(PUNICODE_STRING dest,PUNICODE_STRING src,BOOLEAN doalloc); | 
|---|
| 494 | UINT WINAPI RtlxOemStringToUnicodeSize(PSTRING str); | 
|---|
| 495 | UINT WINAPI RtlxAnsiStringToUnicodeSize(PANSI_STRING str); | 
|---|
| 496 | DWORD WINAPI RtlIsTextUnicode(LPVOID buf, DWORD len, DWORD *pf); | 
|---|
| 497 | DWORD WINAPI RtlCompareUnicodeString(PUNICODE_STRING String1, PUNICODE_STRING String2, BOOLEAN CaseInSensitive); | 
|---|
| 498 | DWORD WINAPI RtlUpcaseUnicodeStringToOemString(PANSI_STRING oem, PUNICODE_STRING uni, BOOLEAN alloc); | 
|---|
| 499 |  | 
|---|
| 500 | /* | 
|---|
| 501 | * resource functions | 
|---|
| 502 | */ | 
|---|
| 503 |  | 
|---|
| 504 | typedef struct _RTL_RWLOCK { | 
|---|
| 505 | CRITICAL_SECTION                      rtlCS; | 
|---|
| 506 | HANDLE      hSharedReleaseSemaphore; | 
|---|
| 507 | UINT        uSharedWaiters; | 
|---|
| 508 | HANDLE      hExclusiveReleaseSemaphore; | 
|---|
| 509 | UINT        uExclusiveWaiters; | 
|---|
| 510 | INT         iNumberActive; | 
|---|
| 511 | HANDLE      hOwningThreadId; | 
|---|
| 512 | DWORD       dwTimeoutBoost; | 
|---|
| 513 | PVOID       pDebugInfo; | 
|---|
| 514 | } RTL_RWLOCK, *LPRTL_RWLOCK; | 
|---|
| 515 |  | 
|---|
| 516 | VOID   WINAPI RtlInitializeResource( | 
|---|
| 517 | LPRTL_RWLOCK); | 
|---|
| 518 |  | 
|---|
| 519 | VOID   WINAPI RtlDeleteResource( | 
|---|
| 520 | LPRTL_RWLOCK); | 
|---|
| 521 |  | 
|---|
| 522 | BYTE   WINAPI RtlAcquireResourceExclusive( | 
|---|
| 523 | LPRTL_RWLOCK, BYTE fWait); | 
|---|
| 524 |  | 
|---|
| 525 | BYTE   WINAPI RtlAcquireResourceShared( | 
|---|
| 526 | LPRTL_RWLOCK, BYTE fWait); | 
|---|
| 527 |  | 
|---|
| 528 | VOID   WINAPI RtlReleaseResource( | 
|---|
| 529 | LPRTL_RWLOCK); | 
|---|
| 530 |  | 
|---|
| 531 | VOID   WINAPI RtlDumpResource( | 
|---|
| 532 | LPRTL_RWLOCK); | 
|---|
| 533 |  | 
|---|
| 534 | /* | 
|---|
| 535 | time functions | 
|---|
| 536 | */ | 
|---|
| 537 |  | 
|---|
| 538 | typedef struct _TIME_FIELDS | 
|---|
| 539 | {   CSHORT Year; | 
|---|
| 540 | CSHORT Month; | 
|---|
| 541 | CSHORT Day; | 
|---|
| 542 | CSHORT Hour; | 
|---|
| 543 | CSHORT Minute; | 
|---|
| 544 | CSHORT Second; | 
|---|
| 545 | CSHORT Milliseconds; | 
|---|
| 546 | CSHORT Weekday; | 
|---|
| 547 | } TIME_FIELDS; | 
|---|
| 548 |  | 
|---|
| 549 | typedef TIME_FIELDS *PTIME_FIELDS; | 
|---|
| 550 |  | 
|---|
| 551 | VOID WINAPI RtlSystemTimeToLocalTime( | 
|---|
| 552 | IN  PLARGE_INTEGER SystemTime, | 
|---|
| 553 | OUT PLARGE_INTEGER LocalTime); | 
|---|
| 554 |  | 
|---|
| 555 | VOID WINAPI RtlTimeToTimeFields( | 
|---|
| 556 | PLARGE_INTEGER liTime, | 
|---|
| 557 | PTIME_FIELDS TimeFields); | 
|---|
| 558 |  | 
|---|
| 559 | BOOLEAN WINAPI RtlTimeFieldsToTime( | 
|---|
| 560 | PTIME_FIELDS tfTimeFields, | 
|---|
| 561 | PLARGE_INTEGER Time); | 
|---|
| 562 |  | 
|---|
| 563 | VOID WINAPI RtlTimeToElapsedTimeFields( | 
|---|
| 564 | PLARGE_INTEGER liTime, | 
|---|
| 565 | PTIME_FIELDS TimeFields); | 
|---|
| 566 |  | 
|---|
| 567 | BOOLEAN WINAPI RtlTimeToSecondsSince1980( | 
|---|
| 568 | LPFILETIME ft, | 
|---|
| 569 | LPDWORD timeret); | 
|---|
| 570 |  | 
|---|
| 571 | BOOLEAN WINAPI RtlTimeToSecondsSince1970( | 
|---|
| 572 | LPFILETIME ft, | 
|---|
| 573 | LPDWORD timeret); | 
|---|
| 574 |  | 
|---|
| 575 | BOOLEAN WINAPI RtlSecondsSince1970ToTime(LPFILETIME ft, LPDWORD    timeret); | 
|---|
| 576 | BOOLEAN WINAPI RtlSecondsSince1980ToTime(LPFILETIME ft, LPDWORD    timeret); | 
|---|
| 577 |  | 
|---|
| 578 |  | 
|---|
| 579 | /* | 
|---|
| 580 | heap functions | 
|---|
| 581 | */ | 
|---|
| 582 |  | 
|---|
| 583 | /* Data structure for heap definition. This includes various | 
|---|
| 584 | sizing parameters and callback routines, which, if left NULL, | 
|---|
| 585 | result in default behavior */ | 
|---|
| 586 |  | 
|---|
| 587 | typedef struct | 
|---|
| 588 | {  ULONG Length;                         /* = sizeof(RTL_HEAP_DEFINITION) */ | 
|---|
| 589 | ULONG Unknown[11]; | 
|---|
| 590 | } RTL_HEAP_DEFINITION, *PRTL_HEAP_DEFINITION; | 
|---|
| 591 |  | 
|---|
| 592 | HANDLE WINAPI RtlCreateHeap( | 
|---|
| 593 | ULONG Flags, | 
|---|
| 594 | PVOID BaseAddress, | 
|---|
| 595 | ULONG SizeToReserve, | 
|---|
| 596 | ULONG SizeToCommit, | 
|---|
| 597 | PVOID Unknown, | 
|---|
| 598 | PRTL_HEAP_DEFINITION Definition); | 
|---|
| 599 |  | 
|---|
| 600 | PVOID WINAPI RtlAllocateHeap( | 
|---|
| 601 | HANDLE Heap, | 
|---|
| 602 | ULONG Flags, | 
|---|
| 603 | ULONG Size); | 
|---|
| 604 |  | 
|---|
| 605 |  | 
|---|
| 606 | BOOLEAN WINAPI RtlFreeHeap( | 
|---|
| 607 | HANDLE Heap, | 
|---|
| 608 | ULONG Flags, | 
|---|
| 609 | PVOID Address); | 
|---|
| 610 |  | 
|---|
| 611 | /* | 
|---|
| 612 | * misc | 
|---|
| 613 | */ | 
|---|
| 614 | void __cdecl DbgPrint(LPCSTR fmt,LPVOID args); | 
|---|
| 615 | void WINAPI REGS_FUNC(DebugBreak)( CONTEXT *context ); | 
|---|
| 616 | void WINAPI RtlRaiseStatus( NTSTATUS status ); | 
|---|
| 617 | void WINAPI REGS_FUNC(NtRaiseException)( EXCEPTION_RECORD *rec, CONTEXT *ctx, BOOL first, CONTEXT *context ); | 
|---|
| 618 | //void WINAPI REGS_FUNC(RtlUnwind)( PEXCEPTION_FRAME pEndFrame, LPVOID unusedEip, PEXCEPTION_RECORD pRecord, DWORD returnEax, CONTEXT *context ); | 
|---|
| 619 | void WINAPI REGS_FUNC(RtlRaiseException)( EXCEPTION_RECORD *rec, CONTEXT *context ); | 
|---|
| 620 |  | 
|---|
| 621 | VOID WINAPI RtlAcquirePebLock(void); | 
|---|
| 622 | VOID WINAPI RtlReleasePebLock(void); | 
|---|
| 623 | DWORD WINAPI RtlAdjustPrivilege(DWORD x1,DWORD x2,DWORD x3,DWORD x4); | 
|---|
| 624 | DWORD WINAPI RtlIntegerToChar(DWORD x1,DWORD x2,DWORD x3,DWORD x4); | 
|---|
| 625 | DWORD WINAPI RtlSetEnvironmentVariable(DWORD x1,PUNICODE_STRING key,PUNICODE_STRING val); | 
|---|
| 626 | DWORD WINAPI RtlNewSecurityObject(DWORD x1,DWORD x2,DWORD x3,DWORD x4,DWORD x5,DWORD x6); | 
|---|
| 627 | DWORD WINAPI RtlDeleteSecurityObject(DWORD x1); | 
|---|
| 628 | LPVOID WINAPI RtlNormalizeProcessParams(LPVOID x); | 
|---|
| 629 | DWORD WINAPI RtlNtStatusToDosError(DWORD error); | 
|---|
| 630 | BOOLEAN WINAPI RtlGetNtProductType(LPDWORD type); | 
|---|
| 631 | INT WINAPI RtlExtendedLargeIntegerDivide(LARGE_INTEGER dividend, DWORD divisor, LPDWORD rest); | 
|---|
| 632 | LARGE_INTEGER WINAPI RtlExtendedIntegerMultiply(LARGE_INTEGER factor1,INT factor2); | 
|---|
| 633 | DWORD WINAPI RtlFormatCurrentUserKeyPath(PUNICODE_STRING pustrKeyPath); | 
|---|
| 634 | DWORD WINAPI RtlOpenCurrentUser(DWORD x1, DWORD *x2); | 
|---|
| 635 | BOOLEAN WINAPI RtlDosPathNameToNtPathName_U( LPWSTR from,PUNICODE_STRING us,DWORD x2,DWORD x3); | 
|---|
| 636 | DWORD WINAPI RtlCreateEnvironment(DWORD x1,DWORD x2); | 
|---|
| 637 | DWORD WINAPI RtlDestroyEnvironment(DWORD x); | 
|---|
| 638 | DWORD WINAPI RtlQueryEnvironmentVariable_U(DWORD x1,PUNICODE_STRING key,PUNICODE_STRING val) ; | 
|---|
| 639 |  | 
|---|
| 640 | BOOL WINAPI IsValidSid(PSID); | 
|---|
| 641 | BOOL WINAPI EqualSid(PSID,PSID); | 
|---|
| 642 | BOOL WINAPI EqualPrefixSid(PSID,PSID); | 
|---|
| 643 | DWORD  WINAPI GetSidLengthRequired(BYTE); | 
|---|
| 644 | BOOL WINAPI AllocateAndInitializeSid(PSID_IDENTIFIER_AUTHORITY,BYTE,DWORD, | 
|---|
| 645 | DWORD,DWORD,DWORD,DWORD,DWORD,DWORD, | 
|---|
| 646 | DWORD,PSID*); | 
|---|
| 647 | VOID*  WINAPI FreeSid(PSID); | 
|---|
| 648 | BOOL WINAPI InitializeSecurityDescriptor(SECURITY_DESCRIPTOR*,DWORD); | 
|---|
| 649 | BOOL WINAPI InitializeSid(PSID,PSID_IDENTIFIER_AUTHORITY,BYTE); | 
|---|
| 650 | DWORD* WINAPI GetSidSubAuthority(PSID,DWORD); | 
|---|
| 651 | BYTE * WINAPI GetSidSubAuthorityCount(PSID); | 
|---|
| 652 | DWORD  WINAPI GetLengthSid(PSID); | 
|---|
| 653 | BOOL WINAPI CopySid(DWORD,PSID,PSID); | 
|---|
| 654 | BOOL WINAPI LookupAccountSidA(LPCSTR,PSID,LPCSTR,LPDWORD,LPCSTR,LPDWORD, | 
|---|
| 655 | PSID_NAME_USE); | 
|---|
| 656 | BOOL WINAPI LookupAccountSidW(LPCWSTR,PSID,LPCWSTR,LPDWORD,LPCWSTR,LPDWORD, | 
|---|
| 657 | PSID_NAME_USE); | 
|---|
| 658 | PSID_IDENTIFIER_AUTHORITY WINAPI GetSidIdentifierAuthority(PSID); | 
|---|
| 659 |  | 
|---|
| 660 | #ifdef __cplusplus | 
|---|
| 661 | } | 
|---|
| 662 | #endif | 
|---|
| 663 |  | 
|---|
| 664 | #endif | 
|---|