关于system ptes 的问题
Windows内核
关于system ptes 的问题
neil~
2010-01-23, 16:38 下午
新手刚刚来:)
有个关于system ptes的问题有点疑惑。
从我的理解来说system ptes就是pte的一种,只不过不是用来描述process的va的,它应该负责是的kernel里面的那些会动态变化的咚咚,但是如果说一个32位的不是pae的系统,2gb的kernel因该是可以用总共2m的pte表来描述了,为什么system ptes要很大呢?
比如随便vm一下,可以看到free 的system ptes还有70121 (应该是page的单位,也就是 280mb左右)
一下子有点糊涂了。希望得到指教。谢谢。
kd> !vm 1
*** Virtual Memory Usage ***
Physical Memory: 262010 ( 1048040 Kb)
************ NO PAGING FILE *********************
Available Pages: 236223 ( 944892 Kb)
ResAvail Pages: 204046 ( 816184 Kb)
Locked IO Pages: 188 ( 752 Kb)
Free System PTEs: 70121 ( 280484 Kb)
Re: 关于system ptes 的问题
格蠹老雷
2010-01-24, 14:28 下午
下面这行
Free System PTEs: 70121 ( 280484 Kb)
应该如此解释:
系统中还有70121个系统PTE空闲,这些空闲的PTE可以映射70121个内存页,每个内存页按4KB算,也就是70121*4KB=280484KB内存。
并不是说这些PTE要占用280MB的空间,32位下每个PTE占4个字节,这么多PTE如果使用了,那么会占:
lkd> ? 0n70121*4
Evaluate expression: 280484 = 000447a4
这么多个字节,也就是200多KB,不到1MB的内存空间
Re: 关于system ptes 的问题
neil~
2010-01-24, 15:45 下午
谢谢raymond,这个也就是让我疑惑的地方,既然pte结构本身所占的空间这么少,为什么系统给我们system ptes这么不大方呢?这些1m/2m的空间,相比paged pool/non-paged pool所占用的几百兆空间,根本是微不足道的。
想不通阿,我觉得理论上32bit,不是pae系统,system ptes给个2m,不就可以来描述2gb的地址了吗?这样就不会有system pte不够的情况了。
还有,system ptes是不是也要被paged pool/non-paged pool/cache用到呢?因为我觉得既然那些是kernel 里面的VA,如果要映射到ram,不可能不通过system pte吧
Re: 关于system ptes 的问题
格蠹老雷
2010-01-24, 21:26 下午
Neil,问题是线性地址空间不够用,对于32位系统,内核态的线性地址空间只有0x80000000~0xFFFFFFFF这2GB大,无论是从paged pool、non-paged pool分出来的内存都需要占用这2GB的空间,因此PTE表项多了也没有用,因为线性空间就那么多。
Re: 关于system ptes 的问题
neil~
2010-01-25, 00:07 上午
有道理:) 谢谢raymond
对了,我还注意到一个地方有点疑惑。通过sysptes命令可以得到ending PTE和starting PTE,我想那么2个减一下然后再除以每个pte的大小,那就可以total system ptes的数量了,可是看起来不是我这么想的
kd> !sysptes
System PTE Information
Total System Ptes 269279
SysPtes list of size 1 has 393 free
SysPtes list of size 2 has 100 free
SysPtes list of size 4 has 31 free
SysPtes list of size 8 has 44 free
SysPtes list of size 16 has 32 free
starting PTE: c0218000
ending PTE: c03def78
free blocks: 2 total free: 70121 largest free block: 49713
kd> ?c03def78-c0218000
Evaluate expression: 1863544 = 001c6f78
kd> ?001c6f78/4 (我是non-pae的系统所以除以4)
Evaluate expression: 465886 = 00071bde