00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 typedef struct _REGION_SEGMENT_HEADER {
00009     struct _REGION_SEGMENT_HEADER *
NextSegment;
00010     PVOID 
Reserved;
00011 } 
REGION_SEGMENT_HEADER, *
PREGION_SEGMENT_HEADER;
00012 
00013 typedef struct _REGION_HEADER {
00014     SLIST_HEADER ListHead;
00015     PREGION_SEGMENT_HEADER FirstSegment;
00016     ULONG 
BlockSize;
00017     ULONG 
TotalSize;
00018 } 
REGION_HEADER, *
PREGION_HEADER;
00019 
00020 
NTKERNELAPI
00021 
VOID
00022 
ExInitializeRegion(
00023     IN PREGION_HEADER Region,
00024     IN ULONG BlockSize,
00025     IN PVOID Segment,
00026     IN ULONG SegmentSize
00027     );
00028 
00029 
NTKERNELAPI
00030 
VOID
00031 
ExInterlockedExtendRegion(
00032     IN PREGION_HEADER Region,
00033     IN PVOID Segment,
00034     IN ULONG SegmentSize,
00035     IN PKSPIN_LOCK Lock
00036     );
00037 
00038 
00039 
00040 
00041 
00042 
00043 
00044 
00045 
00046 
00047 
00048 
00049 
00050 
00051 
00052 
00053 
00054 
00055 
00056 
00057 
00058 
00059 
00060 
00061 
00062 
00063 
#if defined(_ALPHA_) || defined(_MIPS_) || defined(_X86_)
00064 
00065 
#define ExInterlockedAllocateFromRegion(Region, Lock) \
00066 
    (PVOID)ExInterlockedPopEntrySList(&(Region)->ListHead, Lock)
00067 
00068 
#else
00069 
00070 #define ExInterlockedAllocateFromRegion(Region, Lock) \
00071 
    (PVOID)ExInterlockedPopEntryList((PSINGLE_LIST_ENTRY)&(Region)->ListHead.Next, Lock)
00072 
00073 
#endif
00074 
00075 
00076 
00077 
00078 
00079 
00080 
00081 
00082 
00083 
00084 
00085 
00086 
00087 
00088 
00089 
00090 
00091 
00092 
00093 
00094 
00095 
00096 
00097 
00098 
00099 
00100 
00101 
00102 
00103 
00104 
00105 
00106 
#if defined(_ALPHA_) || defined(_MIPS_) || defined(_X86_)
00107 
00108 
#define ExInterlockedFreeToRegion(Region, Block, Lock) \
00109 
    ExInterlockedPushEntrySList(&(Region)->ListHead, ((PSINGLE_LIST_ENTRY)(Block)), Lock)
00110 
00111 
#else
00112 
00113 #define ExInterlockedFreeToRegion(Region, Block, Lock) \
00114 
    ExInterlockedPushEntryList((PSINGLE_LIST_ENTRY)&(Region)->ListHead.Next, ((PSINGLE_LIST_ENTRY)(Block)), Lock)
00115 
00116 
#endif
00117 
00118 
00119 
00120 
00121 
00122 
00123 
00124 
00125 
00126 
00127 
00128 
00129 
00130 
00131 
00132 
00133 
00134 
00135 
00136 
00137 
00138 
00139 
00140 #define ExIsFullRegion(Region) \
00141 
    ((Region)->ListHead.Next == (PSINGLE_LIST_ENTRY)NULL)
00142 
00143 
00144 
00145 
00146 
00147 
00148 
00149 
00150 
00151 
00152 
00153 
00154 
00155 
00156 
00157 
00158 
00159 
00160 
00161 
00162 
00163 
00164 
00165 
00166 
00167 
00168 #define ExIsObjectInFirstRegionSegment(Region, Object) ((BOOLEAN)   \
00169 
    (((PUCHAR)(Object) >= ((PUCHAR)((Region)->FirstSegment) + sizeof(REGION_SEGMENT_HEADER))) &&        \
00170 
     ((PUCHAR)(Object) < ((PUCHAR)((Region)->FirstSegment) + (Region)->TotalSize + sizeof(REGION_SEGMENT_HEADER)))))
00171