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 ppiScrnSaver
;
16 extern PPROCESSINFO gppiInputProvider
;
18 INIT_FUNCTION NTSTATUS NTAPI
InitUserImpl(VOID
);
19 VOID FASTCALL
CleanupUserImpl(VOID
);
20 VOID FASTCALL
UserEnterShared(VOID
);
21 VOID FASTCALL
UserEnterExclusive(VOID
);
22 VOID FASTCALL
UserLeave(VOID
);
23 BOOL FASTCALL
UserIsEntered(VOID
);
24 BOOL FASTCALL
UserIsEnteredExclusive(VOID
);
27 extern HANDLE GlobalUserHeap
;
30 UserCreateHeap(OUT PSECTION_OBJECT
*SectionObject
,
31 IN OUT PVOID
*SystemBase
,
35 UserHeapAlloc(SIZE_T Bytes
)
37 return RtlAllocateHeap(GlobalUserHeap
,
43 UserHeapFree(PVOID lpMem
)
45 return RtlFreeHeap(GlobalUserHeap
,
51 UserHeapReAlloc(PVOID lpMem
,
55 /* NOTE: ntoskrnl doesn't export RtlReAllocateHeap... */
56 return RtlReAllocateHeap(GlobalUserHeap
,
64 PrevSize
= RtlSizeHeap(GlobalUserHeap
,
68 if (PrevSize
== Bytes
)
71 pNew
= RtlAllocateHeap(GlobalUserHeap
,
83 RtlFreeHeap(GlobalUserHeap
,
93 UserHeapAddressToUser(PVOID lpMem
)
95 PPROCESSINFO W32Process
= PsGetCurrentProcessWin32Process();
96 return (PVOID
)(((ULONG_PTR
)lpMem
- (ULONG_PTR
)GlobalUserHeap
) +
97 (ULONG_PTR
)W32Process
->HeapMappings
.UserMapping
);