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
;
17 INIT_FUNCTION NTSTATUS NTAPI
InitUserImpl(VOID
);
18 VOID FASTCALL
CleanupUserImpl(VOID
);
19 VOID FASTCALL
UserEnterShared(VOID
);
20 VOID FASTCALL
UserEnterExclusive(VOID
);
21 VOID FASTCALL
UserLeave(VOID
);
22 BOOL FASTCALL
UserIsEntered(VOID
);
23 BOOL FASTCALL
UserIsEnteredExclusive(VOID
);
26 extern HANDLE GlobalUserHeap
;
29 UserCreateHeap(OUT PSECTION_OBJECT
*SectionObject
,
30 IN OUT PVOID
*SystemBase
,
34 UserHeapAlloc(SIZE_T Bytes
)
36 return RtlAllocateHeap(GlobalUserHeap
,
42 UserHeapFree(PVOID lpMem
)
44 return RtlFreeHeap(GlobalUserHeap
,
50 UserHeapReAlloc(PVOID lpMem
,
54 /* NOTE: ntoskrnl doesn't export RtlReAllocateHeap... */
55 return RtlReAllocateHeap(GlobalUserHeap
,
63 PrevSize
= RtlSizeHeap(GlobalUserHeap
,
67 if (PrevSize
== Bytes
)
70 pNew
= RtlAllocateHeap(GlobalUserHeap
,
82 RtlFreeHeap(GlobalUserHeap
,
92 UserHeapAddressToUser(PVOID lpMem
)
94 PPROCESSINFO W32Process
= PsGetCurrentProcessWin32Process();
95 return (PVOID
)(((ULONG_PTR
)lpMem
- (ULONG_PTR
)GlobalUserHeap
) +
96 (ULONG_PTR
)W32Process
->HeapMappings
.UserMapping
);