win64 驱动内存基本操作
Posted 心有猛虎,细嗅蔷薇
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了win64 驱动内存基本操作相关的知识,希望对你有一定的参考价值。
1.基本函数及其原型
PVOID
ExAllocatePool(
IN POOL_TYPE PoolType,
IN SIZE_T NumberOfBytes
);
VOID RtlMoveMemory( IN VOID UNALIGNED *Destination, IN CONST VOID UNALIGNED *Source, IN SIZE_T Length );
VOID RtlFillMemory( IN VOID UNALIGNED *Destination, IN SIZE_T Length, IN UCHAR Fill );
VOID
ExFreePool(
IN PVOID P
);
2.内存类型
PagedPool 和NonPagedPool
前者可以被置换到硬盘中,一般存储数据, 如打开一个大文件, 数据结构.
后者不能被置换到硬盘中,驻留在内存中,一般用来存储代码.
如果执行代码到PagedPool的内存中去了,很有可能导致蓝屏
此外,在内核空间中所有内存都是可读可写可执行,故没有类似用户态下的VirtualProtect改变内存属性的函数
但是并不意味着可以随意执行和改写内存中的代码.要满足2个条件: 一个是关闭内存写保护, 二个是提升IRQL级别.(防止执行出错)
对于关闭内存写保护通过操作cr0寄存器,后者使用KeRaiseIrqlToDpcLevel 和KeLowerIrql 实现
//关闭内存写保护和提升IRQL
KIRQL irql=KeRaiseIrqlToDpcLevel();
UINT64 cr0=__readcr0();
cr0 &= 0xfffffffffffeffff;
__writecr0(cr0);
_disable();
还原:
UINT64 cr0=__readcr0(); cr0 |= 0x10000; _enable(); __writecr0(cr0); KeLowerIrql(irql);
未完待续.......
以上是关于win64 驱动内存基本操作的主要内容,如果未能解决你的问题,请参考以下文章
在ESXi 4.1中装了个64位的Win7,为啥这么卡呢?配置:dell optiplex 755, 8G内存,2T硬盘。