3 #define DECLARE_RETURN(type) type _ret_
4 #define RETURN(value) { _ret_ = value; goto _cleanup_; }
5 #define CLEANUP /*unreachable*/ ASSERT(FALSE); _cleanup_
6 #define END_CLEANUP return _ret_;
9 #define UserEnterCo UserEnterExclusive
10 #define UserLeaveCo UserLeave
12 extern BOOL gbInitialized
;
13 extern PSERVERINFO gpsi
;
14 extern PTHREADINFO gptiCurrent
;
15 extern PPROCESSINFO gppiList
;
16 extern PPROCESSINFO ppiScrnSaver
;
17 extern PPROCESSINFO gppiInputProvider
;
18 extern PEPROCESS gpepCSRSS
;
20 INIT_FUNCTION NTSTATUS NTAPI
InitUserImpl(VOID
);
21 VOID FASTCALL
CleanupUserImpl(VOID
);
22 VOID FASTCALL
UserEnterShared(VOID
);
23 VOID FASTCALL
UserEnterExclusive(VOID
);
24 VOID FASTCALL
UserLeave(VOID
);
25 BOOL FASTCALL
UserIsEntered(VOID
);
26 BOOL FASTCALL
UserIsEnteredExclusive(VOID
);
29 extern HANDLE GlobalUserHeap
;
32 UserCreateHeap(OUT PSECTION_OBJECT
*SectionObject
,
33 IN OUT PVOID
*SystemBase
,
37 UserHeapAlloc(SIZE_T Bytes
)
39 return RtlAllocateHeap(GlobalUserHeap
,
45 UserHeapFree(PVOID lpMem
)
47 return RtlFreeHeap(GlobalUserHeap
,
53 UserHeapReAlloc(PVOID lpMem
,
57 /* NOTE: ntoskrnl doesn't export RtlReAllocateHeap... */
58 return RtlReAllocateHeap(GlobalUserHeap
,
66 PrevSize
= RtlSizeHeap(GlobalUserHeap
,
70 if (PrevSize
== Bytes
)
73 pNew
= RtlAllocateHeap(GlobalUserHeap
,
85 RtlFreeHeap(GlobalUserHeap
,
95 UserHeapAddressToUser(PVOID lpMem
)
97 PPROCESSINFO W32Process
= PsGetCurrentProcessWin32Process();
98 return (PVOID
)(((ULONG_PTR
)lpMem
- (ULONG_PTR
)GlobalUserHeap
) +
99 (ULONG_PTR
)W32Process
->HeapMappings
.UserMapping
);