临汾山东漯河饰品美体美文
投稿投诉
美文创意
爱情通信
用品婚姻
爱好看病
美体软件
影音星座
瑜伽周边
星座办公
饰品塑形
搞笑减肥
幼儿两性
智家潮品
漯河衢州
兴义眉山
桂林阳泉
玉溪简阳
山东遂宁
永城新余
梧州洛阳
泸州温州
临汾清远
营口常熟
浙江大连
桐乡宜昌

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

11月19日 皇极城投稿
  高速缓冲器(缓冲器的种类)现代的操作系统将可执行文件加载后,创建了进程,进程中每一条指令和数据都被分配了一个虚拟地址,CPU获取到这个虚拟地址后,需要翻译成内存的物理地址后,才能访问指令和数据,本片文章阐述的重点就是虚拟地址翻译物理地址的流程和实践,因此分成2部分阐述
  1。虚拟地址翻译物理地址的流程?
  2。举一个例子实践下?虚拟地址翻译物理地址的流程?
  当CPU第一次访问虚拟地址时,虚拟地址所在的虚拟页不在内存中,虚拟页表项(PTE)也不在TLB中,因此需要执行的步骤比较多,如下图
  第一次访问虚拟地址
  1。处理器将虚拟地址(VA)送往MMU(内存管理单元)
  虚拟地址格式
  如上图所示,虚拟地址长度为n,虚拟页偏移量长度为p。
  2。MMU获取虚拟地址中的虚拟页号(VPN),然后将虚拟页号发送给TLB(翻译后备缓冲器),TLB根据虚拟页号从TLB映射表中查询PTE(页表项即PageTableEntry)。
  PTE(页表项)
  3。TLB(翻译后备缓冲器)将查询结果返回给MMU(内存管理单元)
  4。MMU(内存管理单元)分析查询结果是否有PTE(页表项),发现PTE为空,没有命中,因此MMU根据页表基址寄存器(PTBR)中的页表起始地址加上虚拟页号(VPN),得出虚拟页页表项的物理地址PTEA(即PageTableEntryAddress),然后将这个物理地址送往高速缓冲(L1)。
  5。高速缓冲(L1)根据PTEA查询内部的缓冲映射表,发现没有找到PTEA映射的内容即PTE(页表项),然后向内存请求PTEA下的内容。
  6。内存将PTEA下的内容PTE,发送给高速缓冲(L1),高速缓冲(L1)建立了PTEA和PTE的映射关系。
  7。高速缓冲(L1)再次根据PTEA查询内部的缓冲映射表,这次找到了,然后将PTE发送给TLB。
  89。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(页表项即PageTableEntry)。
  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)的映射关系,每次访问虚拟地址时,都需要找这个虚拟地址对应的页表项,每次都去内存中查需要耗费几十个甚至上百个的时钟周期,虽然页表项缓冲在高速缓冲后,耗费的周期可以降到12个周期,但是缓冲在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个字节(P64)
  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位即0000001111010100,而虚拟地址只有14位,所以高2位被抛弃,如下图
  0x03d4虚拟地址分布图
  由上图得知,组号(TLBI)为11即0x03,标记位(TLBT)为000011即0x03,从TLB映射表查找,发现命中了,如下图
  TLB命中
  由上图命中了红色部分的标记位,PTE中的PPN0x0D,有效位为1,我们根据PPN然后在加上虚拟页偏移量,如下图
  虚拟地址
  由上图,我们得知虚拟页偏移量(VPO)为0101000x14,虚拟页偏移量(VPO)物理页偏移量(PPO),即PPO0x14,PPN和PPO连接起来就是物理地址PA即0011010101000x354,如下图
  物理地址
  由上图得知,组号是0101即0x05,块号(CO)为00即0x00,标记位为001101即0x0D,通过组号标记位块号,可以定位到高速缓冲的数据0x36,如下图所示
  物理地址命中数据
  物理地址对应的数据找到了,返回给了CPU,当然也可能发生其他的情况,如TLB未命中,高速缓冲未命中,缺页等,这些读者可以自行实践。
  好了,虚拟地址翻译物理的过程和实践,介绍完了,谈下一个话题。

175是什么码(175衣服尺码对照表)175是什么码(175衣服尺码对照表)28苏冲love服装尺码标准概述服装尺码标准是在人体基本尺寸的基础上,根据不同的款式,加上合适的宽松量。服装的规格尺寸一旦确定以后,……男生戒指戴法的含义(男士钻戒的寓意)男生戒指戴法的含义(男士钻戒的寓意)戒指作为当今社会最常见的装饰品,无论男女老少,都非常适合。但是戒指的佩戴也有着许多的讲究与内涵,你知道吗?佩戴戒指意义和我们的戒……华为手机root后怎么查历史定位(免费查找对方手机位置)华为手机root后怎么查历史定位(免费查找对方手机位置)现在的社会,手机现已成为了万众随身的一种设备,它能够上网和联络朋友,能够作为人们的掌上电脑。现在的手机大多数……数学知识同旁内角的定义关于到现在同旁内角的定义这个话题相信很多小伙伴都是非常有兴趣了解的吧因为这个话题也是近期非常火热的那么既然现在大家都想要知道同旁内角的定义小编也是到网上收集了一些与同旁内角的定……端午节为什么要吃粽子(端午节吃粽子的由来?)端午节为什么要吃粽子(端午节吃粽子的由来?)在华夏,每年的农历五月初五,是传承了几千年的传统节日端午节,端午节节日习俗简单鲜明,就是大家一起休息玩一天,别再辛劳工作,同时……五邑大学怎么样(五邑大学属于什么档次)五邑大学怎么样(五邑大学属于什么档次)五邑大学名字你可以简单的理解为江门大学。原先江门就叫做四邑,后来把鹤山并进来之后就叫做五邑了,所以坐落在江门的大学自然也就叫五邑大学……高速缓冲器(缓冲器的种类)高速缓冲器(缓冲器的种类)现代的操作系统将可执行文件加载后,创建了进程,进程中每一条指令和数据都被分配了一个虚拟地址,CPU获取到这个虚拟地址后,需要翻译成内存的物理地址后,才……科普下北回归线是多少度及北回归线的地理意义关于到现在北回归线是多少度及北回归线的地理意义这个话题,相信很多小伙伴都是非常有兴趣了解的吧,因为这个话题也是近期非常火热的,那么既然现在大家都想要知道北回归线是多少度及北回归……弗洛伊德人格发展理论(弗洛伊德五个阶段性发展理论)弗洛伊德人格发展理论(弗洛伊德五个阶段性发展理论)上篇是说心理学家们关于自我的理论,武志红老师结合其工作经验总结出了自我的五个维度:自我稳定性、自我灵活度、自我的疆界、自……自制火锅底料(火锅底料怎么自制)自制火锅底料(火锅底料怎么自制)041418:30大厨江一舟价值50万的火锅底料,大厨把配方比例全部揭秘,学不会真可惜了。亲爱的好朋友们,大家好,我是大厨江一舟,今天又到了给大……贩毒多少克判死刑(买毒品多少克判刑)贩毒多少克判死刑(买毒品多少克判刑)两毒贩纠集多人共同制毒牟利,共制出毒品氯胺酮逾600公斤。近日,荆门市中级人民法院遵照最高人民法院院长签发的执行死刑命令,依法对贩卖、……只有对方手机号怎么查定位(手机位置怎么查踪迹)只有对方手机号怎么查定位(手机位置怎么查踪迹)现在的社会,手机现已成为了万众随身的一种设备,它能够上网和联络朋友,能够作为人们的掌上电脑。现在的手机大多数都是智能化……
杨紫最新短发杨紫剪短之后气质更突出了【杨紫最新短发】杨紫最近发型是越换越美了,出席活动的时候扎个小马尾很显活力满分,杨紫剪短之后气质更突出了。一起和昕薇小编看看杨紫的最新短发发型图片吧,妩媚轻熟更养眼。杨紫……欧莱雅几号盖白发好欧莱雅染发色号选择当我们长出白头发的时候,很多人都会使用染发剂将白头发染黑遮盖住,白发很显老,选择使用染发剂,能够更好的遮盖白发,欧莱雅有专门针对白发用的。欧莱雅几号盖白发好欧莱雅染发剂是……简单漂亮的马尾辫扎法夏季百变马尾增高更清爽减龄简单漂亮的马尾辫扎法都有哪些?马尾的绑法与高低决定整体造型的风格,炎热夏季扎一款好看的马尾,不但清爽显高更显脸小哦,想把马尾扎出独特的气质,一起来看看这些明星的马尾发型图片吧。……简单复古盘发教程步骤优雅盘发轻松变女神想要一个优雅又简单的盘发发型吗?可是却被复杂且多工序的盘发步骤给难倒了。没关系,小编为各位美眉精心挑选了一款简单又优雅的发型,下面就让小编带你轻松变女神。步骤一:先……经常梳头发好吗多梳头有助生发吗在我们平时生活中很多人都不喜欢梳头,其实梳头对我们的头皮有很多的好处,经常梳头可以刺激毛囊,有助于头皮血液循环,有一定的生发、防脱发的效果。经常梳头发好吗好。现代科……及肩发型回归看这些明星如何玩转百搭齐肩发【及肩发型回归看这些明星如何玩转百搭齐肩发】秋冬季节及肩发回归,不管是披着的齐肩发型,还是扎出各种款式造型的及肩发,让众明星演绎出了各种不同的风格,一起来看看这些明星是如何玩转……长发怎么扎简单好看9款冬季扎发秒变仙范长发怎么扎简单好看?对于长发的女生来说,冬季怎么扎头发简单好看?昕薇小编为你分享9款冬季扎发让你秒变仙范,一起来看看这些长发扎发图片吧。长发怎么扎简单好看:9款冬季扎发秒……高颧骨女生适合什么发型适合高颧骨女生发型推荐高颧骨的女生是需要头发来遮一下的,如果不遮的话会吧高颧骨展露的一览无遗,那么什么发型适合高颧骨女生,下面一起来看看吧。高颧骨女生适合什么发型1、初恋头中短发这款初恋……头发分叉怎么回事一头好的发质是每个女生都想要的,头发分叉是很常见的一个问题,头发分叉看起来会非常的枯燥,会影响头发质量,影响头发的健康。头发分叉怎么回事头发分叉的原因有很多,每个人头发分……不同脸型刘海搭配刘海改变脸型更决定气质【不同脸型刘海搭配】我们都知道刘海改变脸型,更能改变一个人的气质,每次剪刘海都很纠结,到底剪斜刘海还是齐刘海?自己最适合什么样的刘海呢?昕薇小编为你分享不同脸型最适合的刘海发型……女明星半丸子头扎法想不吸睛都难的半丸子头日本流行的丸子头几乎红了半边天,不但明星在扎,而且丸子头的款式多种多样,不但长发可以扎丸子头,短发也能扎丸子头,短发怎么扎丸子头?看王子文,宋茜等明星的丸子头发型图片吧,她们的……脸型与发型搭配什么脸型适合短发图片【脸型与发型搭配什么脸型适合短发图片】什么脸型适合短发?短发的流行让你是否也蠢蠢欲动,但不是流行的发型你都适合的哦,想知道你的脸型适合什么短发吗?一起和小编来看看脸型与发型搭配……
友情链接:中准网聚热点快百科快传网快生活快软网快好知文好找