ExAllocatePoolQuotaZero 函数 (wdm.h)
注意
Microsoft 注意到 ExAllocatePoolQuotaZero 存在一个问题,该问题可能导致Windows 10版本 1909 上的分配未归零。此问题已在 2020 年 12 月 16 日针对 Windows 10 版本 2004 的 WDK 和企业 WDK (EWDK) Windows 10中修复。 有关下载最新 WDK 的信息,请参阅 下载 Windows 驱动程序工具包 (WDK) 。
此例程是 ExAllocatePoolWithQuotaTag 的包装器,也是建议的替换选项。
ExAllocatePoolQuotaZero 分配指定类型的池内存,并返回指向已分配块的指针。 它与 ExAllocatePoolWithQuotaTag 相同,只是零初始化分配的内存。 如果不需要此操作,请改用 ExAllocatePoolQuotaUninitialized 。
语法
PVOID ExAllocatePoolQuotaZero(
__drv_strictTypeMatch(__drv_typeExpr)POOL_TYPE PoolType,
SIZE_T NumberOfBytes,
ULONG Tag
);
参数
PoolType
要分配的池内存的类型。 有关可用池内存类型的说明,请参阅 POOL_TYPE。
同样,可以通过使用) 中wdm.h
定义的POOL_COLD_ALLOCATION标志对此值进行按位 ORing 来修改 PoolType 值 (作为内核的提示,以从可能快速分页的页面分配内存。 若要尽可能减少驻留池内存量,不应频繁引用这些分配。 POOL_COLD_ALLOCATION标志只是公告标志。
NumberOfBytes
要分配的字节数。
Tag
要用于已分配内存的池标记。 将池标记指定为一到四个字符的非零字符文本,由单引号分隔 (例如 Tag1
) 。 字符串通常按反向顺序指定, (例如 1gaT
,) 。 标记中的每个 ASCII 字符必须是) 0x7E (平铺) 0x20 (空间范围内的值。 每个分配代码路径都应使用唯一的池标记来帮助调试器和验证程序识别代码路径。
返回值
ExAllocatePoolQuotaZero 返回指向已分配池的指针。
如果无法满足请求,除非指定了POOL_QUOTA_FAIL_INSTEAD_OF_RAISE,否则 ExAllocatePoolQuotaZero 将引发异常。 出于性能原因,首选使用 POOL_QUOTA_FAIL_INSTEAD_OF_RAISE。
注解
若要在 Windows 10 版本 2004 之前的 Windows 版本上运行,驱动程序必须在调用此函数之前定义 POOL_ZERO_DOWN_LEVEL_SUPPORT并调用 ExInitializeDriverRuntime。
此例程由分配内存以满足最初发出 I/O 请求的进程上下文中的请求的最高级别驱动程序调用。 较低级别的驱动程序改为调用 ExAllocatePoolZero 。
有关其他指南,请参阅 ExAllocatePoolWithQuotaTag 的“备注”部分。
要求
要求 | 值 |
---|---|
最低受支持的客户端 | Windows 10版本 2004 需要 WDK。 面向 Windows 操作系统的 Windows 7 及更高版本。 |
目标平台 | 通用 |
标头 | wdm.h(包括 Wdm.h、Ntddk.h、Ntifs.h) |
Library | NtosKrnl.lib |
DLL | NtosKrnl.exe |
IRQL | <= DISPATCH_LEVEL (请参阅备注部分) |
DDI 符合性规则 | HwStorPortProhibitedDDI、SpNoWait、StorPortStartIo |