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