bak*_*kra 3 operating-system kernel window driver wdm
1)用户模式进程具有其自己的"地址上下文",其将用户模式虚拟地址映射到唯一的物理页面帧集合.也就是说,当Windows XP调度程序切换线程时,任何特定虚拟地址的含义都会随时改变.
"切换线程"的部分工作是更改页表,以便它们引用传入线程的进程上下文.
_
2)Windows内核模式驱动程序在"任意线程上下文"中执行.
驱动程序可以创建一个系统线程并在其上下文中工作......但我正在讨论当一个人没有创建系统线程时的情况.
驱动程序可以使用"ExAllocatePoolWithTag"来分配分页(内存在易失性存储中).
_
3)那么驱动程序如何在没有任何上下文的情况下访问分页内存?
如第1点所示,通过"特定于上下文"的页表访问分页内存.
当驱动程序在一些其他线程上下文中运行时...即页表条目指向线程相关的phy.mem,那么驱动程序如何才能访问他的分页内存?
PS:我在内核编程方面的努力.别生气.
使用的概念是"用户/内核地址空间拆分".每个进程地址空间被分成一个较低的部分(通常为2 GB),该进程在用户模式下可供进程访问,并且每个进程都有所不同,以及只能在内核模式下访问的上部(剩余地址空间),并且每个过程都是一样的.
当驱动程序分配分页内存时,它会在地址空间分割的内核端分配,因此无论当时加载哪个进程页表,它都可以被内核代码看到(因为这部分地址空间是映射到的)每个过程都是一样的).