3 * COPYRIGHT: See COPYING in the top level directory
4 * PROJECT: ReactOS kernel
5 * FILE: ntoskrnl/mm/pool.c
6 * PURPOSE: Implements the kernel memory pool
7 * PROGRAMMER: David Welch (welch@mcmail.com)
10 /* INCLUDES ****************************************************************/
12 #include <ddk/ntddk.h>
13 #include <internal/ntoskrnl.h>
14 #include <internal/pool.h>
17 #include <internal/debug.h>
19 /* GLOBALS *****************************************************************/
21 #define TAG_NONE (ULONG)(('N'<<0) + ('o'<<8) + ('n'<<16) + ('e'<<24))
23 /* FUNCTIONS ***************************************************************/
26 EiAllocatePool(POOL_TYPE PoolType,
33 if (PoolType == NonPagedPoolCacheAligned ||
34 PoolType == NonPagedPoolCacheAlignedMustS)
42 case NonPagedPoolMustSucceed:
43 case NonPagedPoolCacheAligned:
44 case NonPagedPoolCacheAlignedMustS:
46 ExAllocateNonPagedPoolWithTag(PoolType,
53 case PagedPoolCacheAligned:
54 Block = ExAllocatePagedPoolWithTag(PoolType,NumberOfBytes,Tag);
61 if ((PoolType==NonPagedPoolMustSucceed ||
62 PoolType==NonPagedPoolCacheAlignedMustS) && Block==NULL)
64 KeBugCheck(MUST_SUCCEED_POOL_EMPTY);
70 ExAllocatePool (POOL_TYPE PoolType, ULONG NumberOfBytes)
72 * FUNCTION: Allocates pool memory of a specified type and returns a pointer
73 * to the allocated block. This routine is used for general purpose allocation
77 * Specifies the type of memory to allocate which can be one
81 * NonPagedPoolMustSucceed
82 * NonPagedPoolCacheAligned
83 * NonPagedPoolCacheAlignedMustS
85 * PagedPoolCacheAligned
88 * Specifies the number of bytes to allocate
89 * RETURNS: The allocated block on success
94 Block = EiAllocatePool(PoolType,
97 (PVOID)__builtin_return_address(0));
103 ExAllocatePoolWithTag (ULONG PoolType, ULONG NumberOfBytes, ULONG Tag)
106 Block = EiAllocatePool(PoolType,
109 (PVOID)__builtin_return_address(0));
115 ExAllocatePoolWithQuota (POOL_TYPE PoolType, ULONG NumberOfBytes)
117 return(ExAllocatePoolWithQuotaTag(PoolType, NumberOfBytes, TAG_NONE));
122 ExAllocatePoolWithQuotaTag (IN POOL_TYPE PoolType,
123 IN ULONG NumberOfBytes,
128 Block = EiAllocatePool(PoolType,
131 (PVOID)__builtin_return_address(0));
138 ExFreePool(IN PVOID Block)
140 if (Block >= MmPagedPoolBase && Block < (MmPagedPoolBase + MmPagedPoolSize))
142 ExFreePagedPool(Block);
146 ExFreeNonPagedPool(Block);