計(jì)算機(jī)組成原理——虛擬存儲(chǔ)器

一. 頁(yè)式虛擬存儲(chǔ)

1.概念

(1)程序員在比實(shí)際主存大得多的邏輯地址空間中編寫程序

(2)程序執(zhí)行時(shí)幼衰,把當(dāng)前需要的程序段和數(shù)據(jù)塊掉入主存卓缰,其他暫不使用的放在磁盤上

(3)執(zhí)行指令時(shí)躲惰,通過(guò)硬件將邏輯地址轉(zhuǎn)化為物理地址奸焙。虛擬地址高位為虛頁(yè)號(hào)嫌术,低位為頁(yè)內(nèi)偏移地址

(4)當(dāng)程序發(fā)生數(shù)據(jù)訪問(wèn)或程序訪問(wèn)失效(缺頁(yè)時(shí))烫扼,由操作系統(tǒng)把信息從磁盤調(diào)入主存中

2.分頁(yè)

????(1)基本思想:

????????內(nèi)存被分成固定長(zhǎng)度且長(zhǎng)度較小的存儲(chǔ)塊(頁(yè)框曙求,實(shí)頁(yè),物理頁(yè))

????????每個(gè)進(jìn)程也被劃分為固定長(zhǎng)度的程序塊(頁(yè)映企,虛頁(yè)悟狱,邏輯頁(yè))

????????通過(guò)頁(yè)表,實(shí)現(xiàn)邏輯地址想物理地址的轉(zhuǎn)化

????(2)邏輯地址

????????程序中指令所使用的地址(進(jìn)程所在地址空間)

????(3)物理地址

????????存放指令或數(shù)據(jù)的實(shí)際內(nèi)存地址

3.“主存-磁盤”層次

(1)與“cache-主存”層次相比堰氓,頁(yè)大小遠(yuǎn)比cache的行大小要大(windows中的頁(yè)位4k)

(2)采用全相聯(lián)映射方式:磁盤中的任意一個(gè)頁(yè)能用射到內(nèi)存中的任意一個(gè)頁(yè)

????因?yàn)槿表?yè)導(dǎo)致中斷時(shí)挤渐,操作系統(tǒng)從磁盤拿數(shù)據(jù)通常要耗費(fèi)幾百萬(wàn)個(gè)時(shí)鐘周期。增大頁(yè)大小豆赏,可以減少缺頁(yè)中斷

(3)為什么讓軟件處理“缺頁(yè)”

????因?yàn)樵L問(wèn)磁盤需要好粉幾百萬(wàn)個(gè)時(shí)鐘周期挣菲,硬件即使能立刻把地址打給磁盤富稻,磁盤也不能立即響應(yīng)

(4)為什么地址轉(zhuǎn)換用硬件實(shí)現(xiàn)

????硬件實(shí)現(xiàn)地址轉(zhuǎn)換可以加快指令的執(zhí)行速度

(5)為什么頁(yè)寫會(huì)策略采用write back

????避免頻繁的慢速磁盤訪問(wèn)

4.頁(yè)表結(jié)構(gòu)

頁(yè)表的首地址放在基址寄存器。采用基址尋址方式

每個(gè)頁(yè)表項(xiàng)前面有一個(gè)虛頁(yè)號(hào):從0開(kāi)始遞增的序號(hào)白胀。頁(yè)表項(xiàng)又分為幾個(gè)結(jié)構(gòu):

(1)裝入位:該頁(yè)是否在內(nèi)存中

(2)修改位:該也在內(nèi)存中是否被修改

(3)替換控制位:用于clock算法

(4)其他

(5)實(shí)頁(yè)號(hào)(8進(jìn)制)

5.TLB

(1)一次磁盤引用需要訪問(wèn)幾次主存椭赋?2次,一次查頁(yè)表或杠,一次查物理地址哪怔。于是,把經(jīng)常查的頁(yè)表放到cache中向抢。這種在cache頁(yè)表項(xiàng)組成的頁(yè)表稱為TLB(Translation Lookside Buffer)

(2)TLB的頁(yè)表結(jié)構(gòu):tag + 主存中的頁(yè)表項(xiàng)

當(dāng)采用全相連映射時(shí)认境,tag為頁(yè)表項(xiàng)前面的虛頁(yè)號(hào)。需要把tag和虛頁(yè)號(hào)一一比較

當(dāng)采用組相聯(lián)映射時(shí)挟鸠,tag被分為tag+index叉信,虛頁(yè)號(hào)的高位為tag,虛頁(yè)號(hào)的低位為index艘希,做組內(nèi)索引(屬于組內(nèi)第幾行)

二. 段式虛擬存儲(chǔ)

????1.段式存儲(chǔ)是根據(jù)程序邏輯硼身,給程序分段。使得每段大小不同覆享。這種虛擬地址劃分方法適合程序設(shè)計(jì)

????2.段式存儲(chǔ)的虛擬地址由段號(hào)和段內(nèi)偏移地址組成佳遂。段式虛擬存儲(chǔ)器到物理地址的映射通過(guò)段表實(shí)現(xiàn)

????3.段式虛擬存儲(chǔ)會(huì)造成空頁(yè)

三. 段頁(yè)式虛擬存儲(chǔ)

????1.段頁(yè)式虛擬存儲(chǔ),先把程序按照邏輯分成段撒顿,再把每段分成固定大小的頁(yè)丑罪。

????2.程序?qū)χ鞔娴恼{(diào)入調(diào)出是按照頁(yè)面進(jìn)行的;但他有可以根據(jù)段實(shí)現(xiàn)共享和保護(hù)

????3.缺點(diǎn)是段頁(yè)式虛擬地址轉(zhuǎn)換成物理地址需要查詢2個(gè)表:段表和頁(yè)表凤壁。段表找到相應(yīng)頁(yè)表的位置吩屹,頁(yè)表找到想也頁(yè)的位置

????4.段頁(yè)式細(xì)膩地址的結(jié)構(gòu)可以為以下形式:

????????????程序地址: 用戶號(hào)(進(jìn)程pid) | 段號(hào) | 頁(yè)號(hào) | 頁(yè)內(nèi)偏移地址

eg:

(1)某計(jì)算機(jī)的cache塊工16塊,采用二路組相聯(lián)映射方式客扎,每個(gè)主存塊大小為32字節(jié)祟峦,按照字節(jié)編制罚斗。則主存129號(hào)單元的主存塊硬裝如刀cache的組號(hào)是:(C)A徙鱼、0? ? ? B、2? ? ? C针姿、4? ? ? D袱吆、6

解:二路組相聯(lián),所以每組2塊距淫,共有16/2=8組绞绒,所以組號(hào)占3位。

? ? ? 每塊32字節(jié)榕暇,所以塊內(nèi)地址占5位蓬衡。

? ? ? 129轉(zhuǎn)化為二進(jìn)制:1000 0001:前3位為組號(hào)喻杈,100:=4



(2)假設(shè)用若干個(gè)2K4位的芯片組成一個(gè)8K8位的存儲(chǔ)器,則地址0B1FH所在芯片的最小地址為:

解:用2片組成一行狰晚,共4行筒饰,所以片選地址占2位。片內(nèi)地址有2k=211壁晒,所以占11位

? ? ? 0B1FH:000|0 1|011 0001 1111 這三段為前綴瓷们,片選地址,片內(nèi)地址秒咐。

? ? ? 該片芯片的最小地址是片內(nèi)地址全0:000|0 1|000 0000 0000 = 0800H



(3)某計(jì)算機(jī)的主存地址空間大小為256MB谬晕,按字節(jié)編址,指令cache和數(shù)據(jù)cache分離携取,均有8個(gè)cache行攒钳,每行大小為64B,數(shù)據(jù)cache采用直接映射方式雷滋,現(xiàn)有兩個(gè)程序A夕玩,B對(duì)數(shù)組int a[256][256]進(jìn)行遍歷,程序A按行遍歷惊豺,程序B按列遍歷燎孟。假定int類型數(shù)據(jù)用32位補(bǔ)碼表示,數(shù)組a按行優(yōu)先方式存儲(chǔ)尸昧,其地址為320(十進(jìn)制)揩页。

問(wèn):(1) 若不考慮cache一致性維護(hù)和替換算法所需的控制位,則數(shù)據(jù)cache的總?cè)萘空级嗌伲?/p>

? ? ? (2) 數(shù)組元素a[0][31]和a[1][1]各自所在主存塊對(duì)應(yīng)的cache行號(hào)分別為多少(cache從0行開(kāi)始)烹俗?

? ? ? (3)程序A和B的數(shù)據(jù)訪問(wèn)命中率各自為多少爆侣?哪個(gè)程序的執(zhí)行時(shí)間更短?

解:(1) 因?yàn)閏ache的總?cè)萘渴莄ache每行的數(shù)據(jù)存儲(chǔ)大小+tag位+數(shù)據(jù)是否有效位+其他一致性控制位幢妄。

? ? ? ? ? 主存地址空間256MB兔仰,占28位。直接映射方式蕉鸳,8行乎赴,行號(hào)占3位。每行64B潮尝,所以塊內(nèi)地址占6位榕吼,因此,tag占28-3-6=19位

? ? ? ? ? 每行有一個(gè)數(shù)據(jù)有效位勉失。因此羹蚣,cache共(19+1+648)8 = 532字節(jié)

? ? ? (2) 因?yàn)閕nt類型占32位,所以一個(gè)int占4B乱凿。a[0][31] = 320 + 314 = 444 a1 = 320 + 4(256+1) = 1348顽素。

? ? ? ? ? 塊內(nèi)地址占6位咽弦,直接映射下行號(hào)占3位,因此444 = 110 | 111100胁出,所以行號(hào)為6

? ? ? ? ? 1348 = 10 | 101 | 000100离唬,所以行號(hào)為5

? ? ? (3) 因?yàn)?行cache占64B,每個(gè)int數(shù)占4B划鸽,所以一行有16個(gè)數(shù)输莺。第一個(gè)數(shù)會(huì)因cache缺失而不命中,然后調(diào)入cache裸诽。嫂用,使得后面的15個(gè)int訪問(wèn)全部命中。所以命中率為1516 對(duì)于程序B丈冬,每次調(diào)入16個(gè)數(shù)嘱函,小于數(shù)組每行的128個(gè)元素,因此每次都不會(huì)命中埂蕊,命中率為0

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末往弓,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子蓄氧,更是在濱河造成了極大的恐慌函似,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件喉童,死亡現(xiàn)場(chǎng)離奇詭異撇寞,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)堂氯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門蔑担,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人咽白,你說(shuō)我怎么就攤上這事啤握。” “怎么了晶框?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵排抬,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我三妈,道長(zhǎng)畜埋,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任畴蒲,我火速辦了婚禮,結(jié)果婚禮上对室,老公的妹妹穿的比我還像新娘模燥。我一直安慰自己咖祭,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布蔫骂。 她就那樣靜靜地躺著么翰,像睡著了一般。 火紅的嫁衣襯著肌膚如雪辽旋。 梳的紋絲不亂的頭發(fā)上浩嫌,一...
    開(kāi)封第一講書(shū)人閱讀 51,125評(píng)論 1 297
  • 那天,我揣著相機(jī)與錄音补胚,去河邊找鬼码耐。 笑死,一個(gè)胖子當(dāng)著我的面吹牛溶其,可吹牛的內(nèi)容都是我干的骚腥。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼瓶逃,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼束铭!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起厢绝,我...
    開(kāi)封第一講書(shū)人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤契沫,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后昔汉,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體埠褪,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年挤庇,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了钞速。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡嫡秕,死狀恐怖渴语,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情昆咽,我是刑警寧澤驾凶,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站掷酗,受9級(jí)特大地震影響调违,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜泻轰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一技肩、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧浮声,春花似錦虚婿、人聲如沸旋奢。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)至朗。三九已至,卻和暖如春剧浸,著一層夾襖步出監(jiān)牢的瞬間锹引,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工唆香, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留嫌变,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓袋马,卻偏偏與公主長(zhǎng)得像初澎,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子虑凛,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容

  • 1. 虛擬存儲(chǔ)器的基本概念 分析常規(guī)存儲(chǔ)器管理不足的原因: 1)常規(guī)存儲(chǔ)器管理方式的特征 一次性:作業(yè)在運(yùn)行前一...
    盆栽木只閱讀 1,320評(píng)論 0 0
  • 內(nèi)存的歷史 現(xiàn)代的intel處理器可以追溯到最早期的intel芯片碑宴。1.8085處理器充分利用了芯片整合技術(shù),它將...
    Mr_Bluyee閱讀 711評(píng)論 0 0
  • 前言:繼續(xù)底層一點(diǎn)的知識(shí)桑谍。 一切都要從為什么要分頁(yè)開(kāi)始 為什么要分頁(yè) 啥是頁(yè)延柠?記得我們?cè)诔绦虻逆溄又挟嫷哪莻€(gè)圖嗎?...
    madao756閱讀 1,551評(píng)論 0 3
  • 1. 虛擬存儲(chǔ)器的基本概念 分析常規(guī)存儲(chǔ)器管理不足的原因: 1)常規(guī)存儲(chǔ)器管理方式的特征 一次性:作業(yè)在運(yùn)行前一...
    Whocare_2f87閱讀 1,090評(píng)論 0 0
  • 存儲(chǔ)器的多層結(jié)構(gòu)CPU寄存器(寄存器)锣披,主存(高速緩存贞间,主存儲(chǔ)器,磁盤緩存)雹仿,輔存(固定磁盤增热,可移動(dòng)存儲(chǔ)介質(zhì))寄存...
    我好菜啊_閱讀 1,046評(píng)論 0 0