0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線(xiàn)課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

從三個(gè)方面闡述Cache

Linux閱碼場(chǎng) ? 來(lái)源:Linux閱碼場(chǎng) ? 作者:甄建勇 ? 2021-11-21 11:09 ? 次閱讀

關(guān)于cache,大概可以從三個(gè)方面進(jìn)行闡述:內(nèi)存到cache的映射方式,cache的寫(xiě)策略,cache的替換策略。

映射方式

內(nèi)存到cache的映射方式,大致可以分為三種,分別是:直接映射(directmapped),全相連(fullyassociative),組相連(setassociative)。

為了便于理解,現(xiàn)在假設(shè)一個(gè)例子,比如咱們的內(nèi)存只有16bytes,而cache只有4bytes(cacheline是1byte),那么對(duì)于分別采用三種不同的映射方式,會(huì)是什么情況呢?如下圖所示:

(direct mapped:直接映射 ; fully associative:全相連 ;set associative:組相連)

(1)directmapped

對(duì)于directmapped(直接映射),為了便于數(shù)據(jù)查找,一般規(guī)定內(nèi)存數(shù)據(jù)只能置于緩存的特定區(qū)域。對(duì)于直接匹配緩存,每一個(gè)內(nèi)存塊地址都可通過(guò)模運(yùn)算對(duì)應(yīng)到一個(gè)唯一緩存塊上。注意這是一個(gè)多對(duì)一匹配:多個(gè)內(nèi)存塊地址須共享一個(gè)緩存區(qū)域。

對(duì)于咱們這個(gè)例子來(lái)說(shuō),內(nèi)存的0地址只能映射到cache的第0個(gè)(0%4=0)cacheline,內(nèi)存的1地址只能映射到cache的第1個(gè)(1%4=1)cacheline,內(nèi)存的2地址只能映射到cache的第2個(gè)(2%4=2)cacheline,內(nèi)存的3地址只能映射到cache的第3個(gè)(3%4=3)cacheline,內(nèi)存的4地址只能映射到cache的第0個(gè)(4%4=0)cacheline,。。。。。。如此循環(huán)下去。

所以如果采用directmapped的話(huà),core在訪問(wèn)cache時(shí),根據(jù)TLB處理之后的物理地址,進(jìn)行取模(%)運(yùn)算,就可以直接確定其cache的位置,由于一個(gè)cacheline可能對(duì)應(yīng)不同的內(nèi)存地址(具有相同模運(yùn)算結(jié)果的內(nèi)存),然后將物理地址的tag部分與cache的tag部分進(jìn)行一次比較,就可以確定是cache hit,還是cachemiss。

directmapped的特點(diǎn)是,邏輯簡(jiǎn)單,延遲短(只進(jìn)行一次比較),但命中率低。

(2)fullyassociative

對(duì)于fullyassociative(全相連),這種方式,內(nèi)存中的數(shù)據(jù)塊可以被放置到cache的任意區(qū)域。這種相聯(lián)完全免去了索引的使用,而直接通過(guò)在整個(gè)緩存空間上匹配標(biāo)簽進(jìn)行查找。

對(duì)于咱們的這個(gè)例子來(lái)說(shuō),內(nèi)存的某個(gè)地址,可以映射到cache的任意個(gè)cacheline。內(nèi)存的0地址能映射到cache的第0個(gè)cacheline,也可以映射到第1個(gè)cacheline,也可以映射到第2個(gè)cache line,也可以映射到第3個(gè)cacheline。

所以如果采用fullyassociative的話(huà),core在訪問(wèn)cache時(shí),根據(jù)TLB處理之后的物理地址,要依次和所有的cacheline的tag進(jìn)行比較。

fullyassociative的特點(diǎn)是:控制復(fù)雜,查找造成的電路延遲最長(zhǎng),因此僅在特殊場(chǎng)合,如緩存極小時(shí),才會(huì)使用,命中率較高。

(3)setassociative

set associative(組相連)是directmapped 和fully associative兩種方式的一個(gè)折中。

對(duì)于咱們這個(gè)例子來(lái)說(shuō),我們將4個(gè)cacheline分成了兩組,內(nèi)存的0地址只能映射到cache的第0個(gè)組(0%2=0),但是在組內(nèi)是任意的,既可以映射到組內(nèi)的第0個(gè)cacheline,也可以映射到第1個(gè)cacheline。內(nèi)存的1地址只能映射到cache的第1個(gè)組(1%2=1),但是在組內(nèi)也是任意的,既可以映射到組內(nèi)的第0個(gè)cacheline,也可以映射到第1個(gè)cacheline。內(nèi)存的2地址只能映射到cache的第0個(gè)組(2%2=0),但是在組內(nèi)也是任意的,既可以映射到組內(nèi)的第0個(gè)cacheline,也可以映射到第1個(gè)cacheline,。。。。。。。依次類(lèi)推。

所以,如果采用setassociative的話(huà),core在訪問(wèn)cache時(shí),根據(jù)TLB處理之后的物理地址,先將物理地址取模,得到其可能的cache的組,然后再依次與組內(nèi)的所有cacheline的tag進(jìn)行比較,確定是cache hit還是cachemiss。

setassociative是折中方案,所以其特點(diǎn)就是集directmapped 和fully associative之所長(zhǎng)。是一個(gè)平衡方案。

咱們這個(gè)例子是2 way setassociative,即兩路組相連,所謂的兩路,是指每個(gè)cache組內(nèi)的cacheline的數(shù)目,不是分組的數(shù)目。比如是4路組相連,指的是每個(gè)cache組內(nèi)有4個(gè)cacheline。

對(duì)于直接映射,由于緩存字節(jié)數(shù)和緩存塊數(shù)均為2的冪,上述運(yùn)算可以由硬件通過(guò)移位極快地完成。直接匹配緩存盡管在電路邏輯上十分簡(jiǎn)單,但是存在顯著的沖突問(wèn)題。由于多個(gè)不同的內(nèi)存塊僅共享一個(gè)緩存塊,一旦發(fā)生緩存失效就必須將緩存塊的當(dāng)前內(nèi)容清除出去。這種做法不但因?yàn)轭l繁的更換緩存內(nèi)容造成了大量延遲,而且未能有效利用程序運(yùn)行期所具有的時(shí)間局部性。

組相聯(lián)(SetAssociativity)是解決這一問(wèn)題的主要辦法。使用組相聯(lián)的緩存把存儲(chǔ)空間組織成多個(gè)組,每個(gè)組有若干數(shù)據(jù)塊。通過(guò)建立內(nèi)存數(shù)據(jù)和組索引的對(duì)應(yīng)關(guān)系,一個(gè)內(nèi)存塊可以被載入到對(duì)應(yīng)組內(nèi)的任一數(shù)據(jù)塊上。

直接映射可以認(rèn)為是單路組相聯(lián)。經(jīng)驗(yàn)規(guī)則表明,在緩存小于128KB時(shí),欲達(dá)到相同失效率,一個(gè)雙路組相聯(lián)緩存僅需相當(dāng)于直接匹配緩存一半的存儲(chǔ)空間。

為了和下級(jí)存儲(chǔ)(如內(nèi)存)保持?jǐn)?shù)據(jù)一致性,就必須把數(shù)據(jù)更新適時(shí)傳播下去。這種傳播通過(guò)回寫(xiě)來(lái)完成。

寫(xiě)策略

一般有兩種回寫(xiě)策略:寫(xiě)回(Writeback)和寫(xiě)通(Writethrough)。

寫(xiě)回是指,僅當(dāng)一個(gè)緩存塊需要被替換回內(nèi)存時(shí),才將其內(nèi)容寫(xiě)入內(nèi)存。如果緩存命中,則總是不用更新內(nèi)存。為了減少內(nèi)存寫(xiě)操作,緩存塊通常還設(shè)有一個(gè)臟位(dirtybit),用以標(biāo)識(shí)該塊在被載入之后是否發(fā)生過(guò)更新。如果一個(gè)緩存塊在被置換回內(nèi)存之前從未被寫(xiě)入過(guò),則可以免去回寫(xiě)操作。

寫(xiě)回的優(yōu)點(diǎn)是節(jié)省了大量的寫(xiě)操作。這主要是因?yàn)?,?duì)一個(gè)數(shù)據(jù)塊內(nèi)不同單元的更新僅需一次寫(xiě)操作即可完成。這種內(nèi)存帶寬上的節(jié)省進(jìn)一步降低了能耗,因此頗適用于嵌入式系統(tǒng)。

寫(xiě)通是指,每當(dāng)緩存接收到寫(xiě)數(shù)據(jù)指令,都直接將數(shù)據(jù)寫(xiě)回到內(nèi)存。如果此數(shù)據(jù)地址也在緩存中,則必須同時(shí)更新緩存。由于這種設(shè)計(jì)會(huì)引發(fā)造成大量寫(xiě)內(nèi)存操作,有必要設(shè)置一個(gè)緩沖來(lái)減少硬件沖突。這個(gè)緩沖稱(chēng)作寫(xiě)緩沖器(Writebuffer),通常不超過(guò)4個(gè)緩存塊大小。不過(guò),出于同樣的目的,寫(xiě)緩沖器也可以用于寫(xiě)回型緩存。

寫(xiě)通較寫(xiě)回易于實(shí)現(xiàn),并且能更簡(jiǎn)單地維持?jǐn)?shù)據(jù)一致性。

當(dāng)發(fā)生寫(xiě)失效時(shí),緩存可有兩種處理策略,分別稱(chēng)為分配寫(xiě)(Writeallocate)和非分配寫(xiě)(No-writeallocate)。

分配寫(xiě)是指,先如處理讀失效一樣,將所需數(shù)據(jù)讀入緩存,然后再將數(shù)據(jù)寫(xiě)到被讀入的單元。非分配寫(xiě)則總是直接將數(shù)據(jù)寫(xiě)回內(nèi)存。

設(shè)計(jì)緩存時(shí)可以使用回寫(xiě)策略和分配策略的任意組合。對(duì)于不同組合,發(fā)生數(shù)據(jù)寫(xiě)操作時(shí)的行為也有所不同。

對(duì)于組相聯(lián)緩存,當(dāng)一個(gè)組的全部緩存塊都被占滿(mǎn)后,如果再次發(fā)生緩存失效,就必須選擇一個(gè)緩存塊來(lái)替換掉。存在多種策略決定哪個(gè)塊被替換。

替換策略

顯然,最理想的替換塊應(yīng)當(dāng)是距下一次被訪問(wèn)最晚的那個(gè)。這種理想策略無(wú)法真正實(shí)現(xiàn),但它為設(shè)計(jì)其他策略提供了方向。

先進(jìn)先出算法(FIFO)替換掉進(jìn)入組內(nèi)時(shí)間最長(zhǎng)的緩存塊。最久未使用算法(LRU)則跟蹤各個(gè)緩存塊的使用狀況,并根據(jù)統(tǒng)計(jì)比較出哪個(gè)塊已經(jīng)最長(zhǎng)時(shí)間未被訪問(wèn)。對(duì)于2路以上相聯(lián),這個(gè)算法的時(shí)間代價(jià)會(huì)非常高。

對(duì)最久未使用算法的一個(gè)近似是非最近使用(NMRU)。這個(gè)算法僅記錄哪一個(gè)緩存塊是最近被使用的。在替換時(shí),會(huì)隨機(jī)替換掉任何一個(gè)其他的塊。故稱(chēng)非最近使用。相比于LRU,這種算法僅需硬件為每一個(gè)緩存塊增加一個(gè)使用位(usebit)即可。

此外,也可使用純粹的隨機(jī)替換法。測(cè)試表明完全隨機(jī)替換的性能近似于LRU。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 內(nèi)存
    +關(guān)注

    關(guān)注

    8

    文章

    2966

    瀏覽量

    73814
  • Cache
    +關(guān)注

    關(guān)注

    0

    文章

    129

    瀏覽量

    28272

原文標(biāo)題:甄建勇:五分鐘搞定Cache(上)

文章出處:【微信號(hào):LinuxDev,微信公眾號(hào):Linux閱碼場(chǎng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    三個(gè)電流怎么判斷NPN還是PNP

    在判斷晶體管是NPN型還是PNP型時(shí),主要依據(jù)是其內(nèi)部半導(dǎo)體材料的排列方式以及電流在晶體管中的流動(dòng)方向。闡述如何根據(jù)三個(gè)電流(通常指的是發(fā)射極電流IE、基極電流IB和集電極電流IC)來(lái)判斷NPN和PNP晶體管。
    的頭像 發(fā)表于 09-14 15:44 ?656次閱讀

    基本理想電路元件的三個(gè)特征是什么

    基本理想電路元件是構(gòu)成電路的基本單元,它們具有三個(gè)基本特征:電壓-電流關(guān)系、能量轉(zhuǎn)換和電路參數(shù)。以下是對(duì)這三個(gè)特征的分析: 電壓-電流關(guān)系 理想電路元件的電壓-電流關(guān)系是其最基本的特征之一。這種關(guān)系
    的頭像 發(fā)表于 08-25 09:38 ?876次閱讀

    對(duì)稱(chēng)相電壓的特點(diǎn)是哪三個(gè)方面

    對(duì)稱(chēng)相電壓是電力系統(tǒng)中常見(jiàn)的一種電壓形式,它具有三個(gè)相位,每個(gè)相位之間的相位差為120度。對(duì)稱(chēng)相電壓在工業(yè)生產(chǎn)和日常生活中有著廣泛的應(yīng)用,如電動(dòng)機(jī)、變壓器、發(fā)電機(jī)等。本文將從三個(gè)
    的頭像 發(fā)表于 08-12 18:18 ?808次閱讀

    簡(jiǎn)述極管的三個(gè)工作區(qū)域

    極管的三個(gè)區(qū)域,通常指的是其在不同工作條件下的狀態(tài)區(qū)域,即截止區(qū)、放大區(qū)和飽和區(qū)。這三個(gè)區(qū)域定義了極管在不同電壓和電流條件下的行為特性,對(duì)于理解和設(shè)計(jì)電子電路至關(guān)重要。
    的頭像 發(fā)表于 07-29 10:50 ?2210次閱讀

    可調(diào)變阻器三個(gè)引腳怎么區(qū)分

    可調(diào)變阻器,也稱(chēng)為電位器或可變電阻器,是一種可以調(diào)節(jié)電阻值的電子元件。它廣泛應(yīng)用于各種電子設(shè)備中,如音頻設(shè)備、電源管理、電機(jī)控制等??烧{(diào)變阻器有三個(gè)引腳,分別是固定端、滑動(dòng)端和可調(diào)端。這三個(gè)引腳
    的頭像 發(fā)表于 07-24 11:12 ?774次閱讀

    微波測(cè)量的三個(gè)基本參量是什么

    微波測(cè)量是電子工程領(lǐng)域中的一個(gè)重要分支,它涉及到對(duì)微波信號(hào)的頻率、幅度、相位等參數(shù)的測(cè)量。在微波測(cè)量中,有三個(gè)基本參量:頻率、幅度和相位。這三個(gè)參量是微波信號(hào)的基本特征,對(duì)于微波系統(tǒng)的設(shè)計(jì)、調(diào)試
    的頭像 發(fā)表于 05-28 14:46 ?1031次閱讀

    如何判斷極管的三個(gè)極性

    極管是電子電路中的基本元件之一,其性能的好壞直接影響到整個(gè)電路的性能。而判斷極管的三個(gè)極性(基極b、發(fā)射極e、集電極c)是電路分析和設(shè)計(jì)中不可或缺的一步。下面將詳細(xì)介紹判斷極管
    的頭像 發(fā)表于 05-21 15:26 ?5338次閱讀

    個(gè)籬笆三個(gè)樁——記晶體極管的發(fā)明

    個(gè)籬笆三個(gè)樁——記晶體極管的發(fā)明
    的頭像 發(fā)表于 05-12 08:14 ?617次閱讀
    一<b class='flag-5'>個(gè)</b>籬笆<b class='flag-5'>三個(gè)</b>樁——記晶體<b class='flag-5'>三</b>極管的發(fā)明

    電能質(zhì)量包括哪三個(gè)方面 電能質(zhì)量監(jiān)測(cè)裝置作用是什么

    包括以下三個(gè)方面: 電壓質(zhì)量:電壓穩(wěn)定性是評(píng)價(jià)電能質(zhì)量的重要指標(biāo)之一。供電系統(tǒng)中的電壓波形應(yīng)該接近正弦波,且其幅值、頻率和相位應(yīng)該穩(wěn)定。電壓的波動(dòng)、閃變、諧波扭曲等問(wèn)題可能會(huì)對(duì)電力設(shè)備的正常運(yùn)行、電動(dòng)機(jī)的轉(zhuǎn)速
    的頭像 發(fā)表于 02-02 15:01 ?2716次閱讀

    飛機(jī)的三個(gè)舵面以及如何控制

    飛機(jī)通常具有三個(gè)主要的舵面,它們是方向舵(rudder)、副翼(aileron)和升降舵(elevator)。
    發(fā)表于 01-15 14:54 ?4843次閱讀
    飛機(jī)的<b class='flag-5'>三個(gè)</b>舵面以及如何控制

    使用Chiplet的三個(gè)優(yōu)勢(shì)介紹

    小芯片的第三個(gè)主要好處是,即使是首次設(shè)計(jì),它們也可以顯著加快上市時(shí)間,從而使芯片制造商能夠更快地進(jìn)入市場(chǎng)。
    的頭像 發(fā)表于 12-27 14:34 ?658次閱讀
    使用Chiplet的<b class='flag-5'>三個(gè)</b>優(yōu)勢(shì)介紹

    串聯(lián)諧振電路的三個(gè)特征

    串聯(lián)諧振電路的三個(gè)特征? 串聯(lián)諧振電路是一種重要的電路結(jié)構(gòu),具有許多特征和應(yīng)用。本文將詳細(xì)介紹串聯(lián)諧振電路的三個(gè)主要特征,并對(duì)其原理和應(yīng)用進(jìn)行詳細(xì)討論。 首先,串聯(lián)諧振電路具有共振頻率。共振頻率是指
    的頭像 發(fā)表于 12-20 14:54 ?1409次閱讀

    晶體管的三個(gè)極的電壓關(guān)系大小

    至關(guān)重要。 為了詳細(xì)、實(shí)質(zhì)地理解晶體管三個(gè)極的電壓關(guān)系的大小,我們必須晶體管的基本結(jié)構(gòu)和工作原理開(kāi)始。 晶體管由兩個(gè)PN結(jié)組成:一個(gè)是PNP型,另一
    的頭像 發(fā)表于 12-20 14:50 ?5785次閱讀

    linux關(guān)機(jī)的三個(gè)命令

    在Linux系統(tǒng)中,常用的關(guān)機(jī)命令有三個(gè):shutdown、poweroff和halt。下面是對(duì)這三個(gè)命令的詳細(xì)解釋?zhuān)?shutdown命令 shutdown命令用于在指定的時(shí)間或條件下關(guān)閉計(jì)算機(jī)
    的頭像 發(fā)表于 11-26 15:33 ?2673次閱讀

    mos管三個(gè)引腳怎么區(qū)分

    mos管三個(gè)引腳怎么區(qū)分? MOS管是一種常見(jiàn)的電子元件,它被廣泛應(yīng)用于各種電子設(shè)備中。MOS管通常具有三個(gè)引腳,即柵極(Gate)、源極(Source)和漏極(Drain)。這三個(gè)引腳在MOS管
    的頭像 發(fā)表于 11-22 16:51 ?6916次閱讀