加入收藏 | 设为首页 | 会员中心 | 我要投稿 厦门网 (https://www.xiamenwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长百科 > 正文

operating-system – Windows内核模式驱动程序如何访问分页内存

发布时间:2021-01-25 15:02:38 所属栏目:站长百科 来源:网络整理
导读:1)用户模式进程具有其自己的“地址上下文”,其将用户模式虚拟地址映射到唯一的物理页面帧集合. 也就是说,当 Windows XP调度程序切换线程时,任何特定虚拟地址的含义都会随时改变. “切换线程”的部分工作是更改页表,以便它们引用传入线程的进程上下文. _ 2)Wi

1)用户模式进程具有其自己的“地址上下文”,其将用户模式虚拟地址映射到唯一的物理页面帧集合.
也就是说,当 Windows XP调度程序切换线程时,任何特定虚拟地址的含义都会随时改变.

“切换线程”的部分工作是更改页表,以便它们引用传入线程的进程上下文.

_

2)Windows内核模式驱动程序在“任意线程上下文”中执行.

驱动程序可以创建一个系统线程并在其上下文中工作……但我正在讨论当一个人没有创建系统线程时的情况.

驱动程序可以使用“ExAllocatePoolWithTag”来分配分页(内存在易失性存储中).

_

3)那么驱动程序如何在没有任何上下文的情况下访问分页内存?

如第1点所示,通过“特定于上下文”的页表访问分页内存.

当驱动程序在其他一些线程上下文运行时…即.页表条目指向线程相关的phy. mem,那么驱动程序如何才能访问他的分页内存?

PS:我在内核编程方面的努力.别生气.

解决方法

使用的概念是“用户/内核地址空间拆分”.每个进程地址空间被分成一个较低的部分(通常为2 GB),该进程在用户模式下可供进程访问,并且每个进程都有所不同,以及只能在内核模式下访问的上部(剩余地址空间),并且每个过程都是一样的.

当驱动程序分配分页内存时,它会在地址空间分割的内核端分配,因此无论当时加载哪个进程页表,它都可以被内核代码看到(因为这部分地址空间是映射到的)每个过程都是一样的).

(编辑:厦门网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读