程序运行时 磁盘 主存 Cache TLB 页表的访问关系

程序运行时申请数据发出的是该数据所在位置的虚拟地址,而要在Cache/主存中找到数据必须提供数据的物理地址(可以看到Cache和主存建立映射的时候是用主存的物理地址建立的映射)。所以在得到虚拟地址后,下一步我们需要由数据的虚拟地址查到数据的物理地址,TLB和页表就起到这个作用。

TLB可以理解为将页表中常用的部分单拿出来组织成了一个单独的查询系统,TLB和页表的关系就像Cache和主存的关系。如果在TLB中找到了相关内容,直接返回物理地址给Cache即可。

如果我们在TLB中无法查到我们提供的虚拟地址对应的物理地址的话,说明TLB尚未把页表中的这一项放入,所以这个时候我们需要去访问页表,找到该项,并更新TLB。找到后将物理地址返回给Cache。

如果页表中也没有对应内容的话,说明该部分数据此刻处在磁盘中,不在内存,所以我们需要将磁盘中的对应内容的对应页面更新至内存,并将内存中暂时不用的页面换出至磁盘。(这种情况就是缺页)在进行完页面置换、页表被更新后,我们在页表中找到对应的项,并将物理地址返回给Cache。

在Cache得到物理地址后,Cache将在自己的范围内查找数据,如果找到了则返回数据;如果没有找到,则在主存中寻找对应内容,并将主存中的对应部分的内容换入Cache。

需要注意的是,Cache和主存的关系就像是四六级核心词汇和四六级所有要掌握的词汇之间的关系一样,Cache里面有的内容一定是主存里面的,主存里没有的,Cache中一定不会有。所以发生缺页情况时,即页表未命中时,Cache一定会Miss。因为页表未命中时,我们需要的数据是刚刚从磁盘更新到内存的,Cache中此时不可能有相关数据。

TLB和页表的关系也是一样的。页表中有的,TLB中才会有。页表中没有的内容,TLB中一定没有。

  • 9
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值