范文健康探索娱乐情感热点
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

高速缓冲器(缓冲器的种类)

  高速缓冲器(缓冲器的种类)现代的操作系统将可执行文件加载后,创建了进程,进程中每一条指令和数据都被分配了一个虚拟地址,CPU获取到这个虚拟地址后,需要翻译成内存的物理地址后,才能访问指令和数据,本片文章阐述的重点就是虚拟地址翻译物理地址的流程和实践,因此分成2部分阐述
  1.虚拟地址翻译物理地址的流程?
  2.举一个例子实践下?虚拟地址翻译物理地址的流程?
  当CPU第一次访问虚拟地址时,虚拟地址所在的虚拟页不在内存中,虚拟页表项(PTE)也不在TLB中,因此需要执行的步骤比较多,如下图
  第一次访问虚拟地址
  1.处理器将虚拟地址(VA)送往MMU(内存管理单元)
  虚拟地址格式
  如上图所示,虚拟地址长度为n,虚拟页偏移量长度为p。
  2.MMU获取虚拟地址中的虚拟页号(VPN),然后将虚拟页号发送给TLB(翻译后备缓冲器),TLB根据虚拟页号从TLB映射表中查询PTE(页表项即Page Table Entry)。
  PTE(页表项)
  3.TLB(翻译后备缓冲器)将查询结果返回给MMU(内存管理单元)
  4.MMU(内存管理单元)分析查询结果是否有PTE(页表项),发现PTE为空,没有命中,因此MMU根据页表基址寄存器(PTBR)中的页表起始地址加上虚拟页号(VPN),得出虚拟页页表项的物理地址PTEA(即Page Table Entry Address),然后将这个物理地址送往高速缓冲(L1)。
  5.高速缓冲(L1)根据PTEA查询内部的缓冲映射表,发现没有找到PTEA映射的内容即PTE(页表项),然后向内存请求PTEA下的内容。
  6.内存将PTEA下的内容PTE,发送给高速缓冲(L1),高速缓冲(L1)建立了PTEA和PTE的映射关系。
  7.高速缓冲(L1)再次根据PTEA查询内部的缓冲映射表,这次找到了,然后将PTE发送给TLB。
  8~9.TLB收到了PTE后,建立了虚拟页号(VPN)和PTE的映射(8),然后将PTE发送给MMU。
  10.MMU收到了PTE后,检查PTE的有效位,看看虚拟页是否在内存中。
  11.MMU检查PTE后,发现虚拟页不在内存中,因此发送缺页中断给CPU,CPU开始执行缺页中断处理程序。
  12.缺页中断处理程序根据页面置换算法,选择出一个已经缓冲的虚拟页作为牺牲页(如果这个虚拟页发生了变化,则更新到磁盘中),将这个牺牲页的PTE的有效位设置为0,表明这个牺牲页不在内存了。
  13.缺页中断处理程序将缺少的页,从磁盘换入到空闲的物理内存中,设置缺少的虚拟页的PTE的有效位为1,更新物理号。
  14.缺页中断处理程序执行完毕,跳转到发生缺页的指令处,然后CPU重新执行该指令,重新发出虚拟地址到MMU,跳到了1,开启下一个循环。
  当CPU第二次访问同一个虚拟地址时,虚拟地址所在的虚拟页已经内存中,虚拟页表项(PTE)也在TLB中了,因此需要执行的步骤少了很多,如下图
  第二次访问虚拟地址
  1.处理器将虚拟地址(VA)送往MMU(内存管理单元)
  2.MMU获取虚拟地址中的虚拟页号(VPN),然后将虚拟页号发送给TLB(翻译后备缓冲器),TLB根据虚拟页号从TLB映射表中查询PTE(页表项即Page Table Entry)。
  3.TLB(翻译后备缓冲器)将查询结果返回给MMU(内存管理单元)
  4.MMU(内存管理单元)分析查询结果是否有PTE(页表项),发现PTE有值,命中了,然后检查PTE的有效位,发现有效位是1,因此不缺页,根据PTE中的物理号加上虚拟地址中的(VPO)计算出指令或者数据的物理地址PA,将PA发送到高速缓冲(L1)
  5.高速缓冲(L1)根据PA查询内部的缓冲映射表,发现没有找到PA映射的内容即指令或者数据,然后向内存请求PA下的内容。
  6.内存将PA下的内容,发送给高速缓冲(L1),高速缓冲(L1)建立了PA和内容的映射关系。
  7.高速缓冲(L1)再次根据PA查询内部的缓冲映射表,这次找到了,然后将代码或者指令发送到数据总线,CPU收到数据总线的数据后,感叹道,终于拿到数据了。
  当CPU第三次访问同一个虚拟地址时,与第二次不同的是,因为虚拟地址对应的物理地址的数据,已经映射到高速缓冲(L1),所以不再从内存中查询。
  好了,虚拟地址翻译物理地址的整个过程阐述完毕,下面来举个具体的例子来实践下!举一个例子实践
  上一节是虚拟地址翻译物理地址的过程,现在实践下,实践前先普及两个概念TLB和高速缓冲。
  TLB
  TLB全称叫做翻译后备缓冲器,这是一个映射表,它建立了虚拟页号(VPN)和页表项(PTE)的映射关系,每次访问虚拟地址时,都需要找这个虚拟地址对应的页表项,每次都去内存中查需要耗费几十个甚至上百个的时钟周期,虽然页表项缓冲在高速缓冲后,耗费的周期可以降到1-2个周期,但是缓冲在TLB后,几乎不用耗费时钟周期,它跟CPU几乎是同步的,类似于寄存器。
  那么,虚拟地址怎么通过TLB映射页表项(PTE)呢,先来看看TLB,我们说TLB就是一个映射表,先来看看这个映射表长什么样,如下图
  如上图所示,一个TLB由m个TLB组构成,每个TLB组下有个n个条目,每个条目里有PTE和标记位构成。
  标记位是一个数字,每个TLB组的标记位不能重复,所以一个TLB组里,可以根据这个标记位定位到某个条目。
  每个组都有一个唯一的编号叫做组号。
  因此这么看,TLB就是一个二维数组,知道了组号和标记位就可以定位到唯一的PTE(页表项)。
  虚拟地址中的虚拟页号(VPN)可以拆分成两部分即组号和标记位,假设一个n位长度的虚拟地址,如下图
  虚拟地址中的TLB部分
  由上图得知,VPN由标记位(TLBT)和组号又叫标记索引(TLBI)构成,组号占t位,标记位占了虚拟页号剩余的位。
  假如一个TLB有4组,总共有64个条目,每组就有16个条目,那么VPN中的组号就占用2位(2的2次方=4),标记位就占用4位(2的4次方=16)。
  高速缓冲
  高速缓冲通常采用SRAM(静态随机访问存储器)进行存储,它比内存DRAM(动态随机访问存储器)快上几十甚至上百倍,因此为了加速CPU获取数据的速度,最近访问的数据存储在高速缓冲中。
  高速缓冲内部有一张映射表,这张映射表建立内存物理地址PA和该内存物理地址下内容的映射关系,如下图所示
  高速缓冲映射表
  如上图所示,映射表分为m个组,每个组由标记位,有效位,和n个块组成,有效位为1表示该缓冲没过期,为0表示该缓冲过期了。
  一个物理地址由组号+标记位+块号构成,如下图所示
  物理地址的构成
  由上图得知,物理地址为m位,块号占用p位,组号占用t为,剩下的位就是标记位占用的位数。
  我们可以根据物理地址的组号定位到映射表的一个组,然后看看这个组下的有效位是不是为1,如果不为1,那么表示这一组的内容都无效了,没有必要比较下去了,因此缓冲没有命中,如果为1呢,那么比较这个组下的标记位和物理地址中标记位,如果不相等,那就是没有命中,如果相等呢,则继续根据物理地址中的块号去这个组相应的块号下找,如果找到数据,则表示命中了,否则缓冲没有命中。
  假设一个高速缓冲有16个组,每个组有4个块,那么物理地址当中组号占用的空间就是4位(2的4次方等于16),块号占用的位数就是2位(2的2次方等于4),剩余的位数就是标记位占用的位数。
  好了,概念普及完了,下面正式开始举例
  先假设
  1.内存是按字节寻址,每个字是一个字节(通常对于32位的系统一个字是4个字节)。
  2.虚拟地址长度为14位,假设页表有256个页表项,因此虚拟页号(VPN)占用位数为8,虚拟一偏移量(VPO)占用6位。
  3.物理地址长度为12位。
  4.页面大小为64个字节(P=64)
  5.TLB有4个组,每个组4个条目,总共16个条目组成
  6.高速缓冲(L1)有16个组,每个组有4个块。
  7.采用一级页表(多级页表复杂些,但原理类似)。
  先看看虚拟地址和物理地址的格式,如下图:
  虚拟地址
  由上图得知,组号(TLBI)占用2位,因为我们假设TLB有4个组,标记位占用6位。
  物理地址
  由上图得知,组号(CI)占用4位,因为我们假设高速缓冲有16个组,每个组下有4个块,因此块号(CO)占用2位,剩下的6位就是标记位(CT)。
  我们假定TLB,高速缓冲映射表如下图:
  TLB映射表
  高速缓冲映射表
  页表总共有256项,我们把前16项列出,如下图
  页表前16项
  好了,一切就绪,假设CPU访问的虚拟地址是0x03d4,它的二进制是16位即00000011 11010100,而虚拟地址只有14位,所以高2位被抛弃,如下图
  0x03d4虚拟地址分布图
  由上图得知,组号(TLBI)为11即0x03,标记位(TLBT)为000011即0x03,从TLB映射表查找,发现命中了,如下图
  TLB命中
  由上图命中了红色部分的标记位,PTE中的PPN=0x0D,有效位为1,我们根据PPN然后在加上虚拟页偏移量,如下图
  虚拟地址
  由上图,我们得知虚拟页偏移量(VPO)为010100=0x14,虚拟页偏移量(VPO)=物理页偏移量(PPO),即PPO=0x14,PPN和PPO连接起来就是物理地址PA即001101010100=0x354,如下图
  物理地址
  由上图得知,组号是0101即0x05,块号(CO)为00即0x00,标记位为001101即0x0D,通过组号+标记位+块号,可以定位到高速缓冲的数据0x36,如下图所示
  物理地址命中数据
  物理地址对应的数据找到了,返回给了CPU,当然也可能发生其他的情况,如TLB未命中,高速缓冲未命中,缺页等,这些读者可以自行实践。
  好了,虚拟地址翻译物理的过程和实践,介绍完了,谈下一个话题。

宁夏是哪个省(银川旅游景点攻略)宁夏是哪个省(银川旅游景点攻略)治区党委委员常委副书记赖蛟同志任宁夏回族自治区党委委员常委。陈雍简历陈雍,男,满族,1966年10月生,辽宁北镇人,1988年1月入党,1991年8银川必去的五大景点(银川两日游最佳方案)银川必去的五大景点(银川两日游最佳方案)银川市,简称银,是宁夏回族自治区的首府,素有塞上江南鱼米之乡的美誉。银川市及其所属各县(市)地处温带大陆性气候,主要气候特点是四季分明,春迟银川攻略(银川三日游最佳方案)银川攻略(银川三日游最佳方案)欢快的暑假即将到来,忙碌了小半年了,是时候出去放松放松了。这不给大家推荐一个好去处银川,废话不多说,赶紧上攻略。1。交通工具选择来银川之前大家可以根据营口景点(辽宁省营口市十大景点是哪些?)营口景点(辽宁省营口市十大景点是哪些?)营口是辽宁省地级市,地处辽东半岛中枢,渤海东岸。营口市西临渤海辽东湾,属暖温带大陆性季风气候。其气候特征主要是四季分明,雨热同季,气候温和,上海旅游线路(上海经典4日游旅游路线推荐)上海旅游线路(上海经典4日游旅游路线推荐)第一次去上海,想领略海派都市,想走走老街弄堂,想打卡迪士尼乐园,却一时不知道从哪里开始?别着急,一条经典线路,把你安排得明明白白,下面我们庐山旅游路线(庐山自由行路线攻略)庐山旅游路线(庐山自由行路线攻略)作为一位在江西读大学的人,自然去过江西很多景点,对它们自然有许多了解。九江是我在读大学的第二年去的一个地方,我那时候也不是很了解,不过通过九江同学呼和浩特攻略(呼和浩特五日游攻略)呼和浩特攻略(呼和浩特五日游攻略)呼和浩特是内蒙古自治区的首府,论旅行的体验,它可能没有呼伦贝尔那样知名,但是论人文,这里却是整个内蒙的代表,呼和浩特是一座有着400多年建城历史的福州旅游景点大全(福州红色旅游景点)福州旅游景点大全(福州红色旅游景点)作者氢气球好货君三坊七巷参观名人故里三坊七巷地处福州市中心,是南后街两旁从北到南依次排列的十条坊巷的概称。三坊是衣锦坊文儒坊光禄坊。七巷是杨桥巷榆林旅游景点(榆林的著名旅游景点)榆林旅游景点(榆林的著名旅游景点)提到陕西旅游,可能许多人都会想到省会城市西安,这座十三朝古都。西安有秦始皇兵马俑博物馆华清宫回民街大雁塔等著名旅游景点。但是其实陕西境内的旅游景点九龙吐珠(九龙吐珠花怎么养)九龙吐珠(九龙吐珠花怎么养)九龙吐珠(四念癀)来源产地为报春花科植物琉璃繁缕的全草。夏季采收,洗净,鲜用或晒干。生于原野田边湿地。分布于浙江福建台湾广东等地。别名海绿龙吐珠四念癀。定向运动(抗阻运动有哪些项目)定向运动(抗阻运动有哪些项目)有一项运动,它形式自由变幻莫测,让我们换个角度看自己所生活的城市,换个方式融入集体它是体力与耐力的考验趣味与益智的结合。它,就是城市定向赛。日前笔者参
股票佣金如何计算(股票佣金的计算方法)股票佣金如何计算(股票佣金的计算方法)一大早,操着湖南口音的水果大叔问小编现在买股票还来的及吗单位俩保安师傅在大门口议论着农业银行要不要再进两手楼梯间保洁员阿姨则时不时过来插话,小电脑上怎么截图按什么键(键盘哪个键是截图键)电脑上怎么截图按什么键(键盘哪个键是截图键)大家在截图时,最常用的就是QQ的截图方法。QQ可以说是聊天软件里截图功能做得最好的,截图软件里聊天功能做得最好的。其截图功能既简单又好用灌水是什么意思(网络用语灌水是什么意思)灌水是什么意思(网络用语灌水是什么意思)202107112129教育研说家二本学生发10篇sci论文对于这种话题,大家几乎每年都会听说,但同时也都会表现出很惊讶的一面。在很多人看来茯苓功效与作用(茯苓的功效与作用及食用方法)茯苓功效与作用(茯苓的功效与作用及食用方法)茯苓味甘性平,是日常中常见的一种中药,可以用来辅助治疗一些疾病,对人的身体也有着保健的作用。不过需要注意的是茯苓也是要注意一些禁忌事项,番茄酱做法(西红柿酱怎么做的)番茄酱做法(西红柿酱怎么做的)大家好,我是第一美食的阿飞,关注阿飞,有更多的家常美食供大家参考。今天为大家分享一个家常自制番茄酱的做法,番茄酱在我们日常生活中的用于非常的广泛,主要醋泡花生的做法(醋泡花生有几种泡法)醋泡花生的做法(醋泡花生有几种泡法)大家好,我是第一美食阿飞,每天都有几道美食分享给你,关注带你领略四海八荒的舌尖美味。花生是一种高营养食品,更是一味药用价值较高的保健良药,花生性外地车过户北京(外地车迁入北京需要什么条件)外地车过户北京(外地车迁入北京需要什么条件)1北京的个人摇号中标率越来越低,个人摇号难如中彩票2北京的个人指标从去年年底开始个人车牌夫妻之间过户也要婚姻存续满一年才可以3北京还有一大众出租车叫车电话(上海巴士出租电话号码)大众出租车叫车电话(上海巴士出租电话号码)雨里,他们护送老人就医奔波在路上202107261813钱江晚报钱江晚报小时新闻记者孙燕通讯员金凯俞美娟昨天(7月25日)中午,杭州和谐出上海出租车叫车电话(上海收车电话号码多少)上海出租车叫车电话(上海收车电话号码多少)年4月静宝推送的这篇文章吗超暖心!上海有个新颖打车的方式,对这些人群极为便利(附静安全点位)点击了解详情现在不仅打车点位更新了!部分点位的狼人杀九尾狐(8个狼人一般怎么安排角色)狼人杀九尾狐(8个狼人一般怎么安排角色)4游戏狗手游网狼人杀新身份牌九尾妖狐战术深度解析,九尾妖狐共有9条尾巴,每出局1个平民,失去1条尾巴每出局1个神民,失去2条尾巴狼人出局,尾灰太狼的儿子(红太狼的儿子叫什么名字)灰太狼的儿子(红太狼的儿子叫什么名字)喜羊羊与灰太狼新篇章故事来了,相信很多粉丝都已经看过了决战次时代的预告。这次的剧情非常精彩,不过主角依旧是我们熟悉的那群羊和那几匹狼。在以往的