作为windows驱动程序的程序员,需要比普通程序员更多的了解Windows内部的内存管理机制,并在驱动程序中有效地使用内存。在驱动程序编写中,分配和管理内存不能使用熟知的Win32 API函数,取而代之的是DDK提供的高效的内核函数。程序员必须小心地使用这些内存相关的内核函数。因为在内核模式下,操作系统不会检查内存使用的合法性,稍有不慎就可能导致操作系统的崩溃。
另外C语言和C++中大多数关于内存操作的运行时函数,大多在内核模式下是无法使用的。例如,C语言中的malloc函数、C++中的new操作符等。这里介绍Windows内存管理的有关技术,并且给出驱动程序中操作内存的一些实例。
物理内存概念(Physical Memory Address)
PC上有三条总线,分别是数据总线、地址总线和控制总线。32位的CPU的寻址能力为4GB(2的32次方)个字节。用户最多可以使用4GB的真实的物理内存。PC中会拥有很多设备,其中很多设备都提供了自己的设备内存。例如,显卡就会提供自己的显存。这部分内存会映射到PC的物理内存上,也就是读写这段物理地址,其实会读写的设备内存地址,而不会读写物理内存地址。很多情况下,会广义地认为这也是物理内存地址。图5-1就是笔者PC中显卡的显存地址,一个设备可以有好几块设备内存映射到物理内存上。