windows规定有些虚拟内存页面是可以交换到文件中的,这类内存被称为分页内存。还有一些虚拟内存是永远不会交换到文件中,这类内存被称为非分页内存。当程序的中断请求级别在DISPATCH_LEVEL之上的时候(包括DISPATCH_LEVEL层)。程序只能使用非分页内存,否则会导致蓝屏
我们可以指定某个例程和某个全局变量是载入分页内存还是非分页内存。需要做如下的定义
#pragma PAGEDCODE
VOID SomeFunc()
{
PAGED_CODE();
}
其中PAGED_CODE()是DDK的一个宏。他只在check版本中生效。他会检测这个函数是否运行在低于DISPATCH_LEVEL的中断请求级。如果高于或者等于这个中断请求级。他将产生一个断言。
PAGED_CODE宏定义如下:
#define PAGED_CODE() { \
if (KeGetCurrentIrql() > APC_LEVEL) { \
KdPrint(("EX: Pageable code called at IRQL %d\n", KeGetCurrentIrql())); \
PAGED_ASSERT(FALSE); \
} \
}
如果让函数加载到非分页内存。需要在函数的实现中加入如下东西
#pragma LOCKEDCODE
VOID SomeFunc()
{
PAGED_CODE();
}
其中事先做如下定义:
#define PAGEDCODE code_seg("PAGE")
#define LOCKEDCODE code_seg()
#define INITCODE code_seg("INIT")
#define PAGEDDATA data_seg("PAGE")
#define LOCKEDDATA data_seg()
#define INITDATA data_seg("INIT")
#pragma INITCODE的作用是初始化的时候载入内存,然后就可以从内存中卸载掉了