黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

緩存著色技術(Cache Coloring)

系統 2757 0

現代的cache設計大都采用set-association方式,即提高利用率又節省硬件。color只能提高這種cache的使用率。如果采用full-association則color沒有用處。而direct-mapped cache是set-association cache的一種特殊情況而已。

簡單說來,整個內存被分為n個cache page,每個cache page包含數量固定的cache line。
整個cache被分為m個cache way,每個cache way有相同數量的cache line。
內存中的數據依據自己在內存中的cache line索引[getCacheLineIndex(addr)]只能被放入某一個cache way中相對應的cache line里面。假設已經從地址中提取出cache line的索引i,那么硬件會同時訪問所有cache way的第i塊cache line,找出一個擁有空閑行i的cache way,隨后數據就可以放到這個空閑行中。如果m個cache way中都沒有找到空閑的地i行,則啟動淘汰策略,淘出一個空行~

比如一個cache有4個cache way(4路cache),每個cache way有16個cache line。某個數據結構的內存地址的cache line索引為2,則它只能被放入的某個cache way ( one of the 4 cache ways ) 的第2個cache line中。假使所有的cache way的第二個cache line都被使用,則必須換出某一個。

因此如果多個數據地址的cache line相同,即使cache中還有很大的空間,還是競爭激烈。

總結:
(1)多路cache(組相連cache),路間可選,路內固定
(2)對于M路N行Cache,當cache line索引為I(0<=I<N)的地址數超過M時,必然發生沖突,小于M時必然沒有沖突
(3)Cache大小一定時,路數越多,發生沖突的概率越小,但電路也越復雜


為了避免Cache替換,不同的數據結構的地址對應的cache line索引最好不要相同,否則沖突的概率增大。

【more】
而使用slab的數據結構都是分配和釋放頻繁的小的數據結構,而且數目很多,比如dentry,如果沒有color,他們在內存中相對于頁的偏移量很可能相同,則其cache line索引也相同,對于x86這種2way 的cache結構,即使cache size很大,也一樣使用率低下。color則將不同slab中的同樣的數據結構的地址進行一個偏移,因此這些數據結構的cache line索引就錯開了。從而能更好的利用cache


緩存著色技術(Cache Coloring)


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。?!

發表我的評論
最新評論 總共0條評論