Fixed Rtl* string functions for proper MBCS/codepage support. Added a
[wine] / include / ntddk.h
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 "winreg.h"
12 #include "winbase.h"    /* fixme: should be taken out sometimes */
13
14 #include "pshpack1.h"
15
16 #ifdef __cplusplus
17 extern "C" {
18 #endif
19
20 /****************** 
21  * asynchronous I/O 
22  */
23 #undef Status   /* conflict with X11-includes*/
24
25 typedef struct _IO_STATUS_BLOCK 
26 {
27         union {
28           NTSTATUS Status;
29           PVOID Pointer;
30         } DUMMYUNIONNAME;
31         ULONG_PTR Information;
32 } IO_STATUS_BLOCK, *PIO_STATUS_BLOCK;    
33
34 typedef VOID NTAPI (*PIO_APC_ROUTINE) ( PVOID ApcContext, PIO_STATUS_BLOCK IoStatusBlock, ULONG Reserved );
35
36 /*
37         registry 
38  */
39
40  /* key information */
41 typedef struct _KEY_BASIC_INFORMATION {
42         FILETIME        LastWriteTime;
43         ULONG           TitleIndex;
44         ULONG           NameLength;
45         WCHAR           Name[1];
46 } KEY_BASIC_INFORMATION, *PKEY_BASIC_INFORMATION;
47
48 typedef struct _KEY_NODE_INFORMATION 
49 {
50         FILETIME        LastWriteTime;
51         ULONG           TitleIndex;
52         ULONG           ClassOffset;
53         ULONG           ClassLength;
54         ULONG           NameLength;
55         WCHAR           Name[1];
56 /*      Class[1]; */
57 } KEY_NODE_INFORMATION, *PKEY_NODE_INFORMATION;
58
59 typedef struct _KEY_FULL_INFORMATION 
60 {
61         FILETIME        LastWriteTime;
62         ULONG           TitleIndex;
63         ULONG           ClassOffset;
64         ULONG           ClassLength;
65         ULONG           SubKeys;
66         ULONG           MaxNameLen;
67         ULONG           MaxClassLen;
68         ULONG           Values;
69         ULONG           MaxValueNameLen;
70         ULONG           MaxValueDataLen;
71         WCHAR           Class[1];
72 } KEY_FULL_INFORMATION, *PKEY_FULL_INFORMATION;
73
74 typedef enum _KEY_INFORMATION_CLASS 
75 {
76         KeyBasicInformation,
77         KeyNodeInformation,
78         KeyFullInformation
79 } KEY_INFORMATION_CLASS;
80
81 typedef struct _KEY_VALUE_ENTRY 
82 {
83         PUNICODE_STRING ValueName;
84         ULONG           DataLength;
85         ULONG           DataOffset;
86         ULONG           Type;
87 } KEY_VALUE_ENTRY, *PKEY_VALUE_ENTRY;
88
89 /* value information */
90 typedef struct _KEY_VALUE_BASIC_INFORMATION 
91 {
92         ULONG   TitleIndex;
93         ULONG   Type;
94         ULONG   NameLength;
95         WCHAR   Name[1];
96 } KEY_VALUE_BASIC_INFORMATION, *PKEY_VALUE_BASIC_INFORMATION;
97
98 typedef struct _KEY_VALUE_FULL_INFORMATION 
99 {
100         ULONG   TitleIndex;
101         ULONG   Type;
102         ULONG   DataOffset;
103         ULONG   DataLength;
104         ULONG   NameLength;
105         WCHAR   Name[1];
106 /*      UCHAR   Data[1];*/
107 } KEY_VALUE_FULL_INFORMATION, *PKEY_VALUE_FULL_INFORMATION;
108
109 typedef struct _KEY_VALUE_PARTIAL_INFORMATION 
110 {
111         ULONG   TitleIndex;
112         ULONG   Type;
113         ULONG   DataLength;
114         UCHAR   Data[1];
115 } KEY_VALUE_PARTIAL_INFORMATION, *PKEY_VALUE_PARTIAL_INFORMATION;
116
117 typedef enum _KEY_VALUE_INFORMATION_CLASS 
118 {
119         KeyValueBasicInformation,
120         KeyValueFullInformation,
121         KeyValuePartialInformation,
122         KeyValueFullInformationAlign64,
123         KeyValuePartialInformationAlign64
124 } KEY_VALUE_INFORMATION_CLASS;
125
126 NTSTATUS WINAPI RtlFormatCurrentUserKeyPath(
127         PUNICODE_STRING KeyPath);
128
129 /*      thread information */
130
131 typedef enum _THREADINFOCLASS 
132 {       ThreadBasicInformation,
133         ThreadTimes,
134         ThreadPriority,
135         ThreadBasePriority,
136         ThreadAffinityMask,
137         ThreadImpersonationToken,
138         ThreadDescriptorTableEntry,
139         ThreadEnableAlignmentFaultFixup,
140         ThreadEventPair_Reusable,
141         ThreadQuerySetWin32StartAddress,
142         ThreadZeroTlsCell,
143         ThreadPerformanceCount,
144         ThreadAmILastThread,
145         ThreadIdealProcessor,
146         ThreadPriorityBoost,
147         ThreadSetTlsArrayAddress,
148         ThreadIsIoPending,
149         MaxThreadInfoClass
150 } THREADINFOCLASS;
151
152 /*      file information */
153
154 typedef enum _FILE_INFORMATION_CLASS {
155         FileDirectoryInformation = 1,
156         FileFullDirectoryInformation,
157         FileBothDirectoryInformation,
158         FileBasicInformation,
159         FileStandardInformation,
160         FileInternalInformation,
161         FileEaInformation,
162         FileAccessInformation,
163         FileNameInformation,
164         FileRenameInformation,
165         FileLinkInformation,
166         FileNamesInformation,
167         FileDispositionInformation,
168         FilePositionInformation,
169         FileFullEaInformation,
170         FileModeInformation,
171         FileAlignmentInformation,
172         FileAllInformation,
173         FileAllocationInformation,
174         FileEndOfFileInformation,
175         FileAlternateNameInformation,
176         FileStreamInformation,
177         FilePipeInformation,
178         FilePipeLocalInformation,
179         FilePipeRemoteInformation,
180         FileMailslotQueryInformation,
181         FileMailslotSetInformation,
182         FileCompressionInformation,
183         FileObjectIdInformation,
184         FileCompletionInformation,
185         FileMoveClusterInformation,
186         FileQuotaInformation,
187         FileReparsePointInformation,
188         FileNetworkOpenInformation,
189         FileAttributeTagInformation,
190         FileTrackingInformation,
191         FileMaximumInformation
192 } FILE_INFORMATION_CLASS, *PFILE_INFORMATION_CLASS;
193
194 typedef enum _FSINFOCLASS {
195         FileFsVolumeInformation = 1,
196         FileFsLabelInformation,
197         FileFsSizeInformation,
198         FileFsDeviceInformation,
199         FileFsAttributeInformation,
200         FileFsControlInformation,
201         FileFsFullSizeInformation,
202         FileFsObjectIdInformation,
203         FileFsMaximumInformation
204 } FS_INFORMATION_CLASS, *PFS_INFORMATION_CLASS;
205
206 typedef enum _SECTION_INHERIT 
207 {
208         ViewShare = 1,
209         ViewUnmap = 2
210
211 } SECTION_INHERIT;
212  
213 /*      object information */
214
215 typedef enum _OBJECT_INFORMATION_CLASS
216 {
217         DunnoTheConstants1
218
219 } OBJECT_INFORMATION_CLASS, *POBJECT_INFORMATION_CLASS;
220
221
222 /*      system information */
223
224 typedef enum SYSTEM_INFORMATION_CLASS
225 {       Unknown1 = 1,
226         Unknown2,
227         Unknown3,
228         Unknown4,
229         SystemPerformanceInformation
230 } SYSTEM_INFORMATION_CLASS, *PSYSTEM_INFORMATION_CLASS;
231
232 /* reading coffee grounds... */
233 typedef struct _THREAD_INFO
234 {       DWORD   Unknown1[6];
235         DWORD   ThreadID;
236         DWORD   Unknown2[3];
237         DWORD   Status;
238         DWORD   WaitReason;
239         DWORD   Unknown3[4];
240 } THREAD_INFO, PTHREAD_INFO;
241
242 typedef struct _VM_COUNTERS_
243 {       ULONG PeakVirtualSize;
244         ULONG VirtualSize;
245         ULONG PageFaultCount;
246         ULONG PeakWorkingSetSize;
247         ULONG WorkingSetSize;
248         ULONG QuotaPeakPagedPoolUsage;
249         ULONG QuotaPagedPoolUsage;
250         ULONG QuotaPeakNonPagedPoolUsage;
251         ULONG QuotaNonPagedPoolUsage;
252         ULONG PagefileUsage;
253         ULONG PeakPagefileUsage;
254 } VM_COUNTERS, *PVM_COUNTERS;
255
256 /* process information */
257
258 typedef struct _PROCESS_INFO
259 {       DWORD           Offset;         /* 00 offset to next PROCESS_INFO ok*/
260         DWORD           ThreadCount;    /* 04 number of ThreadInfo member ok */
261         DWORD           Unknown1[6];
262         FILETIME        CreationTime;   /* 20 */
263         DWORD           Unknown2[5];
264         PWCHAR          ProcessName;    /* 3c ok */
265         DWORD           BasePriority;
266         DWORD           ProcessID;      /* 44 ok*/
267         DWORD           ParentProcessID;
268         DWORD           HandleCount;
269         DWORD           Unknown3[2];    /* 50 */
270         ULONG           PeakVirtualSize;
271         ULONG           VirtualSize;
272         ULONG           PageFaultCount;
273         ULONG           PeakWorkingSetSize;
274         ULONG           WorkingSetSize;
275         ULONG           QuotaPeakPagedPoolUsage;
276         ULONG           QuotaPagedPoolUsage;
277         ULONG           QuotaPeakNonPagedPoolUsage;
278         ULONG           QuotaNonPagedPoolUsage;
279         ULONG           PagefileUsage;
280         ULONG           PeakPagefileUsage;
281         DWORD           PrivateBytes;
282         DWORD           Unknown6[4];
283         THREAD_INFO     ati[ANYSIZE_ARRAY];     /* 94 size=0x40*/
284 } PROCESS_INFO, PPROCESS_INFO;
285
286 NTSTATUS WINAPI NtQuerySystemInformation(
287         IN SYSTEM_INFORMATION_CLASS SystemInformationClass,
288         OUT PVOID SystemInformation,
289         IN ULONG Length,
290         OUT PULONG ResultLength);
291
292 /*
293  *      system configuration
294  */
295
296
297 typedef struct _SYSTEM_TIME_ADJUSTMENT
298 {
299         ULONG   TimeAdjustment;
300         BOOLEAN TimeAdjustmentDisabled;
301
302 } SYSTEM_TIME_ADJUSTMENT, *PSYSTEM_TIME_ADJUSTMENT;
303
304 typedef struct _SYSTEM_CONFIGURATION_INFO 
305 {
306         union 
307         { ULONG OemId;
308           struct 
309           { WORD        ProcessorArchitecture;
310             WORD        Reserved;
311           } tag1;
312         } tag2;
313         ULONG   PageSize;
314         PVOID   MinimumApplicationAddress;
315         PVOID   MaximumApplicationAddress;
316         ULONG   ActiveProcessorMask;
317         ULONG   NumberOfProcessors;
318         ULONG   ProcessorType;
319         ULONG   AllocationGranularity;
320         WORD    ProcessorLevel;
321         WORD    ProcessorRevision;
322
323 } SYSTEM_CONFIGURATION_INFO, *PSYSTEM_CONFIGURATION_INFO;
324
325
326 typedef struct _SYSTEM_CACHE_INFORMATION 
327 {
328         ULONG   CurrentSize;
329         ULONG   PeakSize;
330         ULONG   PageFaultCount;
331         ULONG   MinimumWorkingSet;
332         ULONG   MaximumWorkingSet;
333         ULONG   Unused[4];
334
335 } SYSTEM_CACHE_INFORMATION;
336
337 /*
338  *      NtQueryProcessInformation
339  */
340
341 /* parameter ProcessInformationClass */
342
343 typedef enum _PROCESSINFOCLASS 
344 {       ProcessBasicInformation,
345         ProcessQuotaLimits,
346         ProcessIoCounters,
347         ProcessVmCounters,
348         ProcessTimes,
349         ProcessBasePriority,
350         ProcessRaisePriority,
351         ProcessDebugPort,
352         ProcessExceptionPort,
353         ProcessAccessToken,
354         ProcessLdtInformation,
355         ProcessLdtSize,
356         ProcessDefaultHardErrorMode,
357         ProcessIoPortHandlers,
358         ProcessPooledUsageAndLimits,
359         ProcessWorkingSetWatch,
360         ProcessUserModeIOPL,
361         ProcessEnableAlignmentFaultFixup,
362         ProcessPriorityClass,
363         ProcessWx86Information,
364         ProcessHandleCount,
365         ProcessAffinityMask,
366         ProcessPriorityBoost,
367         ProcessDeviceMap,
368         ProcessSessionInformation,
369         ProcessForegroundInformation,
370         ProcessWow64Information,
371         MaxProcessInfoClass
372 } PROCESSINFOCLASS;
373
374 /* parameter ProcessInformation (depending on ProcessInformationClass) */
375
376 typedef struct _PROCESS_BASIC_INFORMATION 
377 {       DWORD   ExitStatus;
378         DWORD   PebBaseAddress;
379         DWORD   AffinityMask;
380         DWORD   BasePriority;
381         ULONG   UniqueProcessId;
382         ULONG   InheritedFromUniqueProcessId;
383 } PROCESS_BASIC_INFORMATION;
384
385 NTSTATUS WINAPI NtQueryInformationProcess(
386         IN HANDLE ProcessHandle,
387         IN PROCESSINFOCLASS ProcessInformationClass,
388         OUT PVOID ProcessInformation,
389         IN ULONG ProcessInformationLength,
390         OUT PULONG ReturnLength);
391
392 #define NtCurrentProcess() ( (HANDLE) -1 )
393
394 /*
395  *      timer
396  */
397
398 typedef enum _TIMER_TYPE 
399 {
400         NotificationTimer,
401         SynchronizationTimer
402
403 } TIMER_TYPE;
404
405 /*      token functions */
406  
407 NTSTATUS WINAPI NtOpenProcessToken(
408         HANDLE ProcessHandle,
409         DWORD DesiredAccess, 
410         HANDLE *TokenHandle);
411         
412 NTSTATUS WINAPI NtOpenThreadToken(
413         HANDLE ThreadHandle,
414         DWORD DesiredAccess, 
415         BOOLEAN OpenAsSelf,
416         HANDLE *TokenHandle);
417
418 NTSTATUS WINAPI NtAdjustPrivilegesToken(
419         IN HANDLE TokenHandle,
420         IN BOOLEAN DisableAllPrivileges,
421         IN PTOKEN_PRIVILEGES NewState,
422         IN DWORD BufferLength,
423         OUT PTOKEN_PRIVILEGES PreviousState,
424         OUT PDWORD ReturnLength);
425
426 NTSTATUS WINAPI NtQueryInformationToken(
427         HANDLE token,
428         DWORD tokeninfoclass, 
429         LPVOID tokeninfo,
430         DWORD tokeninfolength,
431         LPDWORD retlen );
432
433 /*      sid functions */
434
435 BOOLEAN WINAPI RtlAllocateAndInitializeSid (
436         PSID_IDENTIFIER_AUTHORITY pIdentifierAuthority,
437         BYTE nSubAuthorityCount,
438         DWORD nSubAuthority0, DWORD nSubAuthority1,
439         DWORD nSubAuthority2, DWORD nSubAuthority3,
440         DWORD nSubAuthority4, DWORD nSubAuthority5,
441         DWORD nSubAuthority6, DWORD nSubAuthority7,
442         PSID *pSid );
443         
444 BOOL WINAPI RtlInitializeSid(
445         PSID pSid,
446         PSID_IDENTIFIER_AUTHORITY pIdentifierAuthority,
447         BYTE nSubAuthorityCount);
448         
449 DWORD WINAPI RtlFreeSid(
450         PSID pSid);
451
452 BOOL WINAPI RtlEqualSid(
453         PSID pSid1,
454         PSID pSid2 );
455         
456 DWORD WINAPI RtlLengthRequiredSid(
457         DWORD nrofsubauths);
458
459 DWORD WINAPI RtlLengthSid(
460         PSID sid);
461
462 LPDWORD WINAPI RtlSubAuthoritySid(
463         PSID PSID,
464         DWORD nr);
465
466 LPBYTE WINAPI RtlSubAuthorityCountSid(
467         PSID pSid);
468
469 DWORD WINAPI RtlCopySid(
470         DWORD len,
471         PSID to,
472         PSID from);
473         
474 BOOL WINAPI RtlValidSid(
475         PSID pSid);
476
477 BOOL WINAPI RtlEqualPrefixSid(
478         PSID pSid1,
479         PSID pSid2);
480
481 PSID_IDENTIFIER_AUTHORITY WINAPI RtlIdentifierAuthoritySid(
482         PSID pSid );
483
484 /*      security descriptor functions */
485
486 NTSTATUS WINAPI RtlCreateSecurityDescriptor(
487         PSECURITY_DESCRIPTOR lpsd,
488         DWORD rev);
489
490 NTSTATUS WINAPI RtlValidSecurityDescriptor(
491         PSECURITY_DESCRIPTOR SecurityDescriptor);
492
493 ULONG WINAPI RtlLengthSecurityDescriptor(
494         PSECURITY_DESCRIPTOR SecurityDescriptor);
495
496 NTSTATUS WINAPI RtlGetDaclSecurityDescriptor(
497         IN PSECURITY_DESCRIPTOR pSecurityDescriptor,
498         OUT PBOOLEAN lpbDaclPresent,
499         OUT PACL *pDacl,
500         OUT PBOOLEAN lpbDaclDefaulted);
501
502 NTSTATUS WINAPI RtlSetDaclSecurityDescriptor (
503         PSECURITY_DESCRIPTOR lpsd,
504         BOOLEAN daclpresent,
505         PACL dacl,
506         BOOLEAN dacldefaulted );
507
508 NTSTATUS WINAPI RtlGetSaclSecurityDescriptor(
509         IN PSECURITY_DESCRIPTOR pSecurityDescriptor,
510         OUT PBOOLEAN lpbSaclPresent,
511         OUT PACL *pSacl,
512         OUT PBOOLEAN lpbSaclDefaulted);
513
514 NTSTATUS WINAPI RtlSetSaclSecurityDescriptor (
515         PSECURITY_DESCRIPTOR lpsd,
516         BOOLEAN saclpresent,
517         PACL sacl,
518         BOOLEAN sacldefaulted);
519
520 NTSTATUS WINAPI RtlGetOwnerSecurityDescriptor(
521         PSECURITY_DESCRIPTOR SecurityDescriptor,
522         PSID *Owner,
523         PBOOLEAN OwnerDefaulted);
524
525 NTSTATUS WINAPI RtlSetOwnerSecurityDescriptor(
526         PSECURITY_DESCRIPTOR lpsd,
527         PSID owner,
528         BOOLEAN ownerdefaulted);
529
530 NTSTATUS WINAPI RtlSetGroupSecurityDescriptor (
531         PSECURITY_DESCRIPTOR lpsd,
532         PSID group,
533         BOOLEAN groupdefaulted);
534
535 NTSTATUS WINAPI RtlGetGroupSecurityDescriptor(
536         PSECURITY_DESCRIPTOR SecurityDescriptor,
537         PSID *Group,
538         PBOOLEAN GroupDefaulted);
539
540 NTSTATUS WINAPI RtlMakeSelfRelativeSD(
541         IN PSECURITY_DESCRIPTOR pAbsoluteSecurityDescriptor,
542         IN PSECURITY_DESCRIPTOR pSelfRelativeSecurityDescriptor,
543         IN OUT LPDWORD lpdwBufferLength);
544
545 NTSTATUS WINAPI RtlGetControlSecurityDescriptor(
546         PSECURITY_DESCRIPTOR  pSecurityDescriptor,
547         PSECURITY_DESCRIPTOR_CONTROL pControl,
548         LPDWORD lpdwRevision);
549
550 /*      acl functions */
551
552 NTSTATUS WINAPI RtlCreateAcl(
553         PACL acl,
554         DWORD size,
555         DWORD rev);
556
557 BOOLEAN WINAPI RtlFirstFreeAce(
558         PACL acl,
559         PACE_HEADER *x);
560
561 NTSTATUS WINAPI RtlAddAce(
562         PACL acl,
563         DWORD rev,
564         DWORD xnrofaces,
565         PACE_HEADER acestart,
566         DWORD acelen);
567         
568 BOOL WINAPI RtlAddAccessAllowedAce(
569         IN OUT PACL pAcl,
570         IN DWORD dwAceRevision,
571         IN DWORD AccessMask,
572         IN PSID pSid);
573
574 BOOL WINAPI AddAccessAllowedAceEx(
575         IN OUT PACL pAcl,
576         IN DWORD dwAceRevision,
577         IN DWORD AceFlags,
578         IN DWORD AccessMask,
579         IN PSID pSid);
580
581 DWORD WINAPI RtlGetAce(
582         PACL pAcl,
583         DWORD dwAceIndex,
584         LPVOID *pAce );
585
586 /*      string functions */
587
588 DWORD       WINAPI RtlAnsiStringToUnicodeSize(PSTRING);
589 NTSTATUS    WINAPI RtlAnsiStringToUnicodeString(UNICODE_STRING*,const STRING *,BOOLEAN);
590 NTSTATUS    WINAPI RtlAppendAsciizToString(STRING*,LPCSTR);
591 NTSTATUS    WINAPI RtlAppendStringToString(STRING*,const STRING*);
592 NTSTATUS    WINAPI RtlAppendUnicodeStringToString(UNICODE_STRING*,const UNICODE_STRING*);
593 NTSTATUS    WINAPI RtlAppendUnicodeToString(UNICODE_STRING*,LPCWSTR);
594 LONG        WINAPI RtlCompareString(const STRING*,const STRING*,BOOLEAN);
595 LONG        WINAPI RtlCompareUnicodeString(const UNICODE_STRING*,const UNICODE_STRING*,BOOLEAN);
596 void        WINAPI RtlCopyString(STRING*,const STRING*);
597 void        WINAPI RtlCopyUnicodeString(UNICODE_STRING*,const UNICODE_STRING*);
598 BOOLEAN     WINAPI RtlCreateUnicodeString(PUNICODE_STRING,LPCWSTR);
599 BOOLEAN     WINAPI RtlCreateUnicodeStringFromAsciiz(PUNICODE_STRING,LPCSTR);
600 void        WINAPI RtlEraseUnicodeString(UNICODE_STRING*);
601 BOOLEAN     WINAPI RtlEqualString(const STRING*,const STRING*,BOOLEAN);
602 BOOLEAN     WINAPI RtlEqualUnicodeString(const UNICODE_STRING*,const UNICODE_STRING*,BOOLEAN);
603 void        WINAPI RtlFreeAnsiString(PSTRING);
604 void        WINAPI RtlFreeOemString(PSTRING);
605 void        WINAPI RtlFreeUnicodeString(PUNICODE_STRING);
606 void        WINAPI RtlInitAnsiString(PSTRING,LPCSTR);
607 void        WINAPI RtlInitString(PSTRING,LPCSTR);
608 void        WINAPI RtlInitUnicodeString(PUNICODE_STRING,LPCWSTR);
609 NTSTATUS    WINAPI RtlMultiByteToUnicodeN(LPWSTR,DWORD,LPDWORD,LPCSTR,DWORD);
610 NTSTATUS    WINAPI RtlMultiByteToUnicodeSize(DWORD*,LPCSTR,UINT);
611 UINT        WINAPI RtlOemStringToUnicodeSize(PSTRING);
612 NTSTATUS    WINAPI RtlOemStringToUnicodeString(UNICODE_STRING*,const STRING*,BOOLEAN);
613 NTSTATUS    WINAPI RtlOemToUnicodeN(LPWSTR,DWORD,LPDWORD,LPCSTR,DWORD);
614 BOOLEAN     WINAPI RtlPrefixString(const STRING*,const STRING*,BOOLEAN);
615 BOOLEAN     WINAPI RtlPrefixUnicodeString(const UNICODE_STRING*,const UNICODE_STRING*,BOOLEAN);
616 DWORD       WINAPI RtlUnicodeStringToAnsiSize(const UNICODE_STRING*);
617 NTSTATUS    WINAPI RtlUnicodeStringToAnsiString(STRING*,const UNICODE_STRING*,BOOLEAN);
618 DWORD       WINAPI RtlUnicodeStringToOemSize(const UNICODE_STRING*);
619 NTSTATUS    WINAPI RtlUnicodeStringToOemString(STRING*,const UNICODE_STRING*,BOOLEAN);
620 NTSTATUS    WINAPI RtlUnicodeToMultiByteN(LPSTR,DWORD,LPDWORD,LPCWSTR,DWORD);
621 NTSTATUS    WINAPI RtlUnicodeToMultiByteSize(DWORD*,LPCWSTR,UINT);
622 NTSTATUS    WINAPI RtlUnicodeToOemN(LPSTR,DWORD,LPDWORD,LPCWSTR,DWORD);
623 NTSTATUS    WINAPI RtlUpcaseUnicodeString(UNICODE_STRING*,const UNICODE_STRING *,BOOLEAN);
624 NTSTATUS    WINAPI RtlUpcaseUnicodeStringToAnsiString(STRING*,const UNICODE_STRING*,BOOLEAN);
625 NTSTATUS    WINAPI RtlUpcaseUnicodeStringToOemString(STRING*,const UNICODE_STRING*,BOOLEAN);
626 NTSTATUS    WINAPI RtlUpcaseUnicodeToMultiByteN(LPSTR,DWORD,LPDWORD,LPCWSTR,DWORD);
627 NTSTATUS    WINAPI RtlUpcaseUnicodeToOemN(LPSTR,DWORD,LPDWORD,LPCWSTR,DWORD);
628
629 DWORD WINAPI RtlIsTextUnicode(
630         LPVOID buf,
631         DWORD len,
632         DWORD *pf);
633
634 /*      resource functions */
635
636 typedef struct _RTL_RWLOCK {
637         CRITICAL_SECTION        rtlCS;
638         HANDLE          hSharedReleaseSemaphore;
639         UINT                    uSharedWaiters;
640         HANDLE          hExclusiveReleaseSemaphore;
641         UINT                    uExclusiveWaiters;
642         INT                     iNumberActive;
643         HANDLE          hOwningThreadId;
644         DWORD                   dwTimeoutBoost;
645         PVOID                   pDebugInfo;
646 } RTL_RWLOCK, *LPRTL_RWLOCK;
647
648 VOID   WINAPI RtlInitializeResource(
649         LPRTL_RWLOCK);
650         
651 VOID   WINAPI RtlDeleteResource(
652         LPRTL_RWLOCK);
653         
654 BYTE   WINAPI RtlAcquireResourceExclusive(
655         LPRTL_RWLOCK, BYTE fWait);
656         
657 BYTE   WINAPI RtlAcquireResourceShared(
658         LPRTL_RWLOCK, BYTE fWait);
659         
660 VOID   WINAPI RtlReleaseResource(
661         LPRTL_RWLOCK);
662         
663 VOID   WINAPI RtlDumpResource(
664         LPRTL_RWLOCK);
665
666 /*      time functions */
667
668 typedef struct _TIME_FIELDS 
669 {   CSHORT Year;
670     CSHORT Month;
671     CSHORT Day;
672     CSHORT Hour;
673     CSHORT Minute;
674     CSHORT Second;
675     CSHORT Milliseconds;
676     CSHORT Weekday;
677 } TIME_FIELDS;
678
679 typedef TIME_FIELDS *PTIME_FIELDS;
680
681 VOID WINAPI RtlSystemTimeToLocalTime(
682         IN  PLARGE_INTEGER SystemTime,
683         OUT PLARGE_INTEGER LocalTime);
684
685 VOID WINAPI RtlTimeToTimeFields(
686         PLARGE_INTEGER liTime,
687         PTIME_FIELDS TimeFields);
688
689 BOOLEAN WINAPI RtlTimeFieldsToTime(
690         PTIME_FIELDS tfTimeFields,
691         PLARGE_INTEGER Time);
692         
693 VOID WINAPI RtlTimeToElapsedTimeFields(
694         PLARGE_INTEGER liTime,
695         PTIME_FIELDS TimeFields);
696         
697 BOOLEAN WINAPI RtlTimeToSecondsSince1980(
698         LPFILETIME ft,
699         LPDWORD timeret);
700
701 BOOLEAN WINAPI RtlTimeToSecondsSince1970(
702         LPFILETIME ft,
703         LPDWORD timeret);
704
705 void WINAPI RtlSecondsSince1970ToTime( DWORD time, LPFILETIME ft );
706 void WINAPI RtlSecondsSince1980ToTime( DWORD time, LPFILETIME ft );
707
708 /*      heap functions */
709
710 /* Data structure for heap definition. This includes various
711    sizing parameters and callback routines, which, if left NULL,
712    result in default behavior */
713
714 typedef struct
715 {       ULONG   Length;         /* = sizeof(RTL_HEAP_DEFINITION) */
716         ULONG   Unknown[11];
717 } RTL_HEAP_DEFINITION, *PRTL_HEAP_DEFINITION;
718
719 HANDLE WINAPI RtlCreateHeap(
720         ULONG Flags,
721         PVOID BaseAddress,
722         ULONG SizeToReserve,
723         ULONG SizeToCommit,
724         PVOID Unknown,
725         PRTL_HEAP_DEFINITION Definition);
726
727 PVOID WINAPI RtlAllocateHeap(
728         HANDLE Heap,
729         ULONG Flags,
730         ULONG Size);
731
732
733 BOOLEAN WINAPI RtlFreeHeap(
734         HANDLE Heap,
735         ULONG Flags,
736         PVOID Address);
737
738 /*      exception */
739
740 void WINAPI NtRaiseException(
741         PEXCEPTION_RECORD,PCONTEXT,BOOL);
742
743 void WINAPI RtlRaiseException(
744         PEXCEPTION_RECORD);
745
746 void WINAPI RtlRaiseStatus(
747         NTSTATUS);
748
749 void WINAPI RtlUnwind(
750         PEXCEPTION_FRAME,
751         LPVOID,
752         PEXCEPTION_RECORD,DWORD);
753
754 /*      process environment block  */
755 VOID WINAPI RtlAcquirePebLock(void);
756 VOID WINAPI RtlReleasePebLock(void);
757
758 /*      mathematics */
759 INT WINAPI RtlExtendedLargeIntegerDivide(
760         LARGE_INTEGER dividend,
761         DWORD divisor,
762         LPDWORD rest);
763
764 LARGE_INTEGER WINAPI RtlExtendedIntegerMultiply(
765         LARGE_INTEGER factor1,
766         INT factor2);
767
768 /*      environment */
769 DWORD WINAPI RtlCreateEnvironment(
770         DWORD x1,
771         DWORD x2);
772
773 DWORD WINAPI RtlDestroyEnvironment(
774         DWORD x);
775
776 DWORD WINAPI RtlQueryEnvironmentVariable_U(
777         DWORD x1,
778         PUNICODE_STRING key,
779         PUNICODE_STRING val) ;
780
781 DWORD WINAPI RtlSetEnvironmentVariable(
782         DWORD x1,
783         PUNICODE_STRING key,
784         PUNICODE_STRING val);
785
786 /*      object security */
787
788 DWORD WINAPI RtlNewSecurityObject(
789         DWORD x1,
790         DWORD x2,
791         DWORD x3,
792         DWORD x4,
793         DWORD x5,
794         DWORD x6);
795
796 DWORD WINAPI RtlDeleteSecurityObject(
797         DWORD x1);
798         
799 NTSTATUS WINAPI 
800 NtQuerySecurityObject(
801         IN HANDLE Object,
802         IN SECURITY_INFORMATION RequestedInformation,
803         OUT PSECURITY_DESCRIPTOR pSecurityDesriptor,
804         IN ULONG Length,
805         OUT PULONG ResultLength);
806
807 NTSTATUS WINAPI
808 NtSetSecurityObject(
809         IN HANDLE Handle,
810         IN SECURITY_INFORMATION SecurityInformation,
811         IN PSECURITY_DESCRIPTOR SecurityDescriptor);
812
813 /*      registry functions */
814
815 NTSTATUS WINAPI NtCreateKey(
816         PHANDLE KeyHandle,
817         ACCESS_MASK DesiredAccess,
818         POBJECT_ATTRIBUTES ObjectAttributes,
819         ULONG TitleIndex,
820         PUNICODE_STRING Class,
821         ULONG CreateOptions,
822         PULONG Disposition);
823
824 NTSTATUS WINAPI NtOpenKey(
825         PHANDLE KeyHandle,
826         ACCESS_MASK DesiredAccess,
827         POBJECT_ATTRIBUTES ObjectAttributes);
828
829 NTSTATUS WINAPI NtDeleteKey(HANDLE KeyHandle);
830
831 NTSTATUS WINAPI NtDeleteValueKey(
832         IN HANDLE KeyHandle,
833         IN PUNICODE_STRING ValueName);
834
835 NTSTATUS WINAPI NtEnumerateKey(
836         HANDLE KeyHandle,
837         ULONG Index,
838         KEY_INFORMATION_CLASS KeyInformationClass,
839         PVOID KeyInformation,
840         ULONG Length,
841         PULONG ResultLength);
842
843 NTSTATUS WINAPI NtQueryKey(
844         HANDLE KeyHandle,
845         KEY_INFORMATION_CLASS KeyInformationClass,
846         PVOID KeyInformation,
847         ULONG Length,
848         PULONG ResultLength);
849
850 NTSTATUS WINAPI NtEnumerateValueKey(
851         HANDLE KeyHandle,
852         ULONG Index,
853         KEY_VALUE_INFORMATION_CLASS KeyInformationClass,
854         PVOID KeyInformation,
855         ULONG Length,
856         PULONG ResultLength);
857
858 NTSTATUS WINAPI NtFlushKey(HANDLE KeyHandle);
859
860 NTSTATUS WINAPI NtLoadKey(
861         PHANDLE KeyHandle,
862         POBJECT_ATTRIBUTES ObjectAttributes);
863
864 NTSTATUS WINAPI NtNotifyChangeKey(
865         IN HANDLE KeyHandle,
866         IN HANDLE Event,
867         IN PIO_APC_ROUTINE ApcRoutine OPTIONAL,
868         IN PVOID ApcContext OPTIONAL,
869         OUT PIO_STATUS_BLOCK IoStatusBlock,
870         IN ULONG CompletionFilter,
871         IN BOOLEAN Asynchroneous,
872         OUT PVOID ChangeBuffer,
873         IN ULONG Length,
874         IN BOOLEAN WatchSubtree);
875
876 NTSTATUS WINAPI NtQueryMultipleValueKey(
877         HANDLE KeyHandle,
878         PVALENTW ListOfValuesToQuery,
879         ULONG NumberOfItems,
880         PVOID MultipleValueInformation,
881         ULONG Length,
882         PULONG  ReturnLength);
883
884 NTSTATUS WINAPI NtQueryValueKey(
885         IN HANDLE KeyHandle,
886         IN PUNICODE_STRING ValueName,
887         IN KEY_VALUE_INFORMATION_CLASS KeyValueInformationClass,
888         OUT PVOID KeyValueInformation,
889         IN ULONG Length,
890         OUT PULONG ResultLength);
891
892 NTSTATUS WINAPI NtReplaceKey(
893         IN POBJECT_ATTRIBUTES ObjectAttributes,
894         IN HANDLE Key,
895         IN POBJECT_ATTRIBUTES ReplacedObjectAttributes);
896
897 NTSTATUS WINAPI NtRestoreKey(
898         HANDLE KeyHandle,
899         HANDLE FileHandle,
900         ULONG RestoreFlags);
901
902 NTSTATUS WINAPI NtSaveKey(
903         IN HANDLE KeyHandle,
904         IN HANDLE FileHandle);
905
906 NTSTATUS WINAPI NtSetInformationKey(
907         IN HANDLE KeyHandle,
908         IN const int KeyInformationClass,
909         IN PVOID KeyInformation,
910         IN ULONG KeyInformationLength);
911
912 NTSTATUS WINAPI NtSetValueKey(
913         HANDLE KeyHandle,
914         PUNICODE_STRING ValueName,
915         ULONG TitleIndex,
916         ULONG Type,
917         PVOID Data,
918         ULONG DataSize);
919
920 NTSTATUS WINAPI NtUnloadKey(
921         IN HANDLE KeyHandle);
922
923 NTSTATUS WINAPI NtClose(
924         HANDLE Handle);
925
926 NTSTATUS WINAPI NtTerminateProcess( HANDLE handle, LONG exit_code );
927
928 NTSTATUS WINAPI NtCreateSemaphore( OUT PHANDLE SemaphoreHandle,
929                                    IN ACCESS_MASK DesiredAccess,
930                                    IN POBJECT_ATTRIBUTES ObjectAttributes OPTIONAL,
931                                    IN ULONG InitialCount,
932                                    IN ULONG MaximumCount);
933 NTSTATUS WINAPI NtReleaseSemaphore( IN HANDLE SemaphoreHandle,
934                                     IN ULONG ReleaseCount,
935                                     IN PULONG PreviousCount);
936
937
938 /* string functions */
939 extern LPSTR _strlwr( LPSTR str );
940 extern LPSTR _strupr( LPSTR str );
941
942 /*      misc */
943
944 #if defined(__i386__) && defined(__GNUC__)
945 static inline void WINAPI DbgBreakPoint(void) { __asm__ __volatile__("int3"); }
946 static inline void WINAPI DbgUserBreakPoint(void) { __asm__ __volatile__("int3"); }
947 #else  /* __i386__ && __GNUC__ */
948 void WINAPI DbgBreakPoint(void);
949 void WINAPI DbgUserBreakPoint(void);
950 #endif  /* __i386__ && __GNUC__ */
951 void WINAPIV DbgPrint(LPCSTR fmt, ...);
952
953 DWORD WINAPI RtlAdjustPrivilege(DWORD x1,DWORD x2,DWORD x3,DWORD x4);
954 DWORD WINAPI RtlIntegerToChar(DWORD x1,DWORD x2,DWORD x3,DWORD x4);
955 LPVOID WINAPI RtlNormalizeProcessParams(LPVOID x);
956 DWORD WINAPI RtlNtStatusToDosError(DWORD error);
957 BOOLEAN WINAPI RtlGetNtProductType(LPDWORD type);
958 PIMAGE_NT_HEADERS WINAPI RtlImageNtHeader(HMODULE hModule);
959
960 DWORD WINAPI RtlOpenCurrentUser(
961         IN ACCESS_MASK DesiredAccess,
962         OUT PHANDLE KeyHandle);
963
964 BOOLEAN WINAPI RtlDosPathNameToNtPathName_U( LPWSTR from,PUNICODE_STRING us,DWORD x2,DWORD x3);
965 BOOL WINAPI RtlImpersonateSelf(SECURITY_IMPERSONATION_LEVEL ImpersonationLevel);
966
967 NTSTATUS WINAPI 
968 NtAccessCheck(
969         IN PSECURITY_DESCRIPTOR SecurityDescriptor,
970         IN HANDLE ClientToken,
971         IN ACCESS_MASK DesiredAccess,
972         IN PGENERIC_MAPPING GenericMapping,
973         OUT PPRIVILEGE_SET PrivilegeSet,
974         OUT PULONG ReturnLength,
975         OUT PULONG GrantedAccess,
976         OUT PBOOLEAN AccessStatus);
977
978 #ifdef __cplusplus
979 }
980 #endif
981
982 #include "poppack.h"
983
984 #endif