日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > > 充電吧
[導(dǎo)讀]虛擬地址VA到物理地址PA以頁page為單位。通常page的大小為4K。物理頁面成為page frame。查看應(yīng)用程序進(jìn)程的地址空間,可以看到分為很多段,比如代碼段(只讀)、數(shù)據(jù)段(讀寫)、堆、共享庫

虛擬地址VA到物理地址PA以頁page為單位。通常page的大小為4K。物理頁面成為page frame。

查看應(yīng)用程序進(jìn)程的地址空間,可以看到分為很多段,比如代碼段(只讀)、數(shù)據(jù)段(讀寫)、堆、共享庫(其中進(jìn)一步分段)、??臻g等。整個應(yīng)用程序的地址空間不會用滿4GB,因為還有一部分是內(nèi)核空間,應(yīng)用程序不能訪問。
再打開一個相同的應(yīng)用程序查看其進(jìn)程的地址空間,也是類似的,甚至是一樣的。因為采用采用了虛擬地址,經(jīng)過轉(zhuǎn)換在物理地址上還是分開的。(代碼段可能沒有分開,因為可以共用)

采用虛擬內(nèi)存的原因:
1.讓每個進(jìn)程有獨(dú)立的地址空間,一個好處是某個進(jìn)程不會破壞其他進(jìn)程,另一個好處是每個進(jìn)程都認(rèn)為有4GB地址空間,編程方便。
2.物理上分開地址空間,經(jīng)過虛擬內(nèi)存的管理,可以使得邏輯上是連續(xù)的。
3.所有進(jìn)程的虛擬內(nèi)存之和可能大于物理內(nèi)存。這是通過借用磁盤來實(shí)現(xiàn)的,將一時不用的虛擬內(nèi)存保持到磁盤。磁盤上這部分成為交換設(shè)備,可以是分區(qū),也可以是一個文件。所以系統(tǒng)中可分配的內(nèi)存總量 = 物理內(nèi)存的大小 + 交換設(shè)備的大小 。交換的過程成為頁的換入和換出,期間需要對內(nèi)存重新映射。
4.增加內(nèi)存的保護(hù)屬性,如內(nèi)核地址空間、只讀地址空間等。

虛擬地址到物理地址是一個查表的過程,但可能不只一個表,是一個多級的表。虛擬地址本身分為幾個部分,page地址和page內(nèi)地址(對于4KB的頁來說就是11bit),page地址分為多級用于查表。這個過程稱為Translation Table Walk,由硬件完成。上述所指的表,是保存在內(nèi)存上的。

page大,page table?。?br />page大,減少TLB的miss;
page大,分配memory容易造成浪費(fèi);

?

上圖給出了CPU,MMU,Cache的布局,MMU應(yīng)該包括了TLB和Translation Table Walk。TLB(Translation Lookaside Buffer)是一塊高速緩存,緩存最近查找過的VA對應(yīng)的頁表項。如果TLB中有需要查表的VA,就不用Translation Table Walk了,Translation Table Walk較慢要從內(nèi)存上讀表。

Cache的儲存單位是line,假設(shè)每個line有32bytes。為了表示某個line是屬于哪個VA的,Cache里還有TAG。最簡單的TAG就是VA的地址了(按32bytes的line對齊),Cache控制器檢查CPU給出VA和TAG是否一致,一致的話表示命中(Hit),將數(shù)據(jù)返回給CPU,否則的話靠MMU轉(zhuǎn)成PA從內(nèi)存中讀取數(shù)據(jù)。

上述這個Cache的設(shè)計稱為全相聯(lián),特點(diǎn)是一個VA可以緩存到任何line里,但問題是Cache可能有很多l(xiāng)ine,比如512個line,每次都需要一個個TAG比較過來,這樣速度較慢。
另一種Cache的設(shè)計稱為直接映射,特定的VA只能存在特定的Cache line里,映射規(guī)則為Cache line = (VA line)%(Cacle line總數(shù))。這樣的問題是Cache line里的數(shù)據(jù)進(jìn)出可能太過于平凡,導(dǎo)致命中率較低。

全相聯(lián)Cache和直接映射Cache各有優(yōu)缺點(diǎn),全相聯(lián)Cache查找很慢,但沒有抖動問題(命中率低),直接映射Cache則正相反。實(shí)際CPU的Cache設(shè)計是取兩者的折衷,把所有Cache Line分成若干個組,每一組有n條Cache Line,稱為n路組相聯(lián)Cache(n-way Set Associative Cache)。n路組相聯(lián)Cache的特點(diǎn)是特定的內(nèi)存行只能放在特定的組內(nèi),但是可以放在組內(nèi)的任意cache line上。
?? ??? ?
Cache寫回內(nèi)存有兩種模式:
Write Back:Cache Line中的數(shù)據(jù)被CPU核修改時并不立刻寫回內(nèi)存,Cache Line和內(nèi)存中的數(shù)據(jù)會暫時不一致,在Cache Line中有一個Dirty位標(biāo)記這一情況。當(dāng)一條Cache Line要被其它VA的數(shù)據(jù)替換時,如果不是Dirty的就直接替換掉,如果是Dirty的就先寫回內(nèi)存再替換。

Write Through:每當(dāng)CPU核修改Cache Line中的數(shù)據(jù)時就立刻寫回內(nèi)存,Cache Line和內(nèi)存中的數(shù)據(jù)總是一致的。如果有多個CPU或設(shè)備同時訪問內(nèi)存,例如采用雙口RAM,那么Cache中的數(shù)據(jù)和內(nèi)存保持一致就非常重要了,這時相關(guān)的內(nèi)存頁面通常配置為Write Through模式。


?? ?
?? ?page是os的概念,而cache是cpu的概念。虛擬地址和物理地址以page為單位進(jìn)行操作的,由兩部分組成:page地址和page內(nèi)地址:



??? 采用多路組聯(lián)的cache,如之前所述,這樣的Cache分為多個set(組),每個組里面又有多個line/way(行),每個line里面又有多個字節(jié)。

?

對某個page進(jìn)行操作時,會將page分配到cache里,這種分配是按照一定關(guān)系的。
?? ?
?? ?假設(shè)page的大小為4KB,考慮物理地址;
?? ?cache的大小為2M,16384個4-Way SET,32 Bytes line,即32*4*16384=2M。
?? ?執(zhí)行memset(0, 0, 4*1024)的話,這4KB內(nèi)存在cache上會放在連續(xù)的0到127set中每個set的第1個line;
?? ?執(zhí)行memset(1, 0, 4*1024)的話,這4KB內(nèi)存在cache上會放在連續(xù)的128到255set中每個set的第1個line;
?? ?...
?? ?執(zhí)行memset(128, 0, 4*1024)的話,這4KB內(nèi)存在cache上會放在連續(xù)的0到127set中每個set的第2個line;
?? ?執(zhí)行memset(129, 0, 4*1024)的話,這4KB內(nèi)存在cache上會放在連續(xù)的128到255set中每個set的第2個line;
?? ?
?? ?就是說第ith物理頁面會與第(128*j+i)th個物理頁面中Cache中占據(jù)同樣的Cache Sets。Set滿了之后,按照一定的算法 ,比如LRU算法(Least Recently Used algorithm)清除之前的數(shù)據(jù)。
?

?

??? 以上說的是現(xiàn)象,產(chǎn)生上述現(xiàn)象的原因可以用下圖來解釋:
???

?

??? 物理地址的位5-11是page中的偏移地址,7位,可以表示128個set;
?? ?物理地址的位12-31是page frame地址的,對某一個page來說是固定的,決定了上述128個set在cache中的位置。
?? ?
?? ?128個set的合集有個專用的名詞,稱為Cache Bin。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護(hù)是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機(jī)驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機(jī)驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉