日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

OS / 总线锁和缓存一致性

發布時間:2024/10/14 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 OS / 总线锁和缓存一致性 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?隨著多核時代的到來,并發操作已經成了很正常的現象,操作系統必須要有一些機制和原語,以保證某些基本操作的原子性,比如處理器需要保證讀一個字節或寫一個字節是原子的,那么它是如何實現的呢?有兩種機制:總線鎖定、緩存一致性

我們知道,CPU 和物理內存之間的通信速度遠慢于 CPU 的處理速度,所以 CPU 有自己的內部緩存,根據一些規則將內存中的數據讀取到內部緩存中來,以加快頻繁讀取的速度。

我們假設在一臺 PC 上只有一個 CPU 和一份內部緩存,那么所有進程和線程看到的數據都是緩存里的數據,不會存在問題;但現在服務器通常是多 CPU,更普遍的是,每塊 CPU 里有多個內核,而每個內核都維護了自己的緩存,那么這時候多線程并發就會存在緩存不一致性,這會導致嚴重問題。

以 i++ 為例,i 的初始值是 0,那么在開始每塊緩存都存儲了 i 的值 0,當第一塊內核做 i++ 的時候,其緩存中的值變成了1,即使馬上回寫到主內存,那么在回寫之后第二塊內核緩存中的 i 值依然是 0,其執行 i++,回寫到內存就會覆蓋第一塊內核的操作,使得最終的結果是 1,而不是預期中的 2。

那么怎么解決整個問題呢?

操作系統提供了總線鎖定的機制。前端總線(也叫CPU總線)是所有CPU與芯片組連接的主干道,負責CPU與外界所有部件的通信,包括高速緩存、內存、北橋。其控制總線向各個部件發送控制信號、通過地址總線發送地址信號指定其要訪問的部件、通過數據總線雙向傳輸數據。在 CPU1 要做 i++ 操作的時候,其在總線上發出一個 LOCK# 信號,其他處理器就不能操作緩存了該共享變量內存地址的緩存,也就是阻塞了其他CPU,使該處理器可以獨享此共享內存。

但我們只需要對此共享變量的操作是原子就可以了,而總線鎖定把CPU和內存的通信給鎖住了,使得在鎖定期間,其他處理器不能操作其他內存地址的數據,從而開銷較大,所以后來的 CPU 都提供了緩存一致性機制,Intel 的奔騰 486 之后就提供了這種優化。

緩存一致性緩存一致性機制就整體來說,是當某塊 CPU 對緩存中的數據進行操作了之后,就通知其他 CPU 放棄儲存在它們內部的緩存,或者從主內存中重新讀取,用MESI闡述原理如下:

MESI協議是以緩存行(緩存的基本數據單位,在 Intel 的 CPU 上一般是 64 字節)的幾個狀態來命名的(全名是 ModifiedExclusiveShareInvalid)。該協議要求在每個緩存行上維護兩個狀態位,使得每個數據單位可能處于 M、E、S 和 I 這四種狀態之一,各種狀態含義如下:

  • M:被修改的。處于這一狀態的數據,只在本CPU中有緩存數據,而其他CPU中沒有。同時其狀態相對于內存中的值來說,是已經被修改的,且沒有更新到內存中。
  • E:獨占的。處于這一狀態的數據,只有在本CPU中有緩存,且其數據沒有修改,即與內存中一致。
  • S:共享的。處于這一狀態的數據在多個CPU中都有緩存,且與內存一致。
  • I:無效的。本CPU中的這份緩存已經無效。

一個處于 M 狀態的緩存行,必須時刻監聽所有試圖讀取該緩存行對應的主存地址的操作,如果監聽到,則必須在此操作執行前把其緩存行中的數據寫回 CPU。

一個處于 S 狀態的緩存行,必須時刻監聽使該緩存行無效或者獨享該緩存行的請求,如果監聽到,則必須把其緩存行狀態設置為 I 。

一個處于 E 狀態的緩存行,必須時刻監聽其他試圖讀取該緩存行對應的主存地址的操作,如果監聽到,則必須把其緩存行狀態設置為 S。

當 CPU 需要讀取數據時,如果其緩存行的狀態是 I 的,則需要從內存中讀取,并把自己狀態變成 S ,如果不是 I,則可以直接讀取緩存中的值,但在此之前,必須要等待其他CPU的監聽結果,如其他CPU也有該數據的緩存且狀態是 M,則需要等待其把緩存更新到內存之后,再讀取。

當 CPU 需要寫數據時,只有在其緩存行是 M 或者 E 的時候才能執行,否則需要發出特殊的 RFO 指令(Read Or Ownership,這是一種總線事務),通知其他 CPU 置緩存無效(i),這種情況下性能開銷是相對較大的。在寫入完成后,修改其緩存狀態為 M。

所以如果一個變量在某段時間只被一個線程頻繁地修改,則使用其內部緩存就完全可以辦到,不涉及到總線事務,如果緩存一會被這個 CPU 獨占、一會被那個 CPU 獨占,這時才會不斷產生 RFO 指令影響到并發性能。這里說的緩存頻繁被獨占并不是指線程越多越容易觸發,而是這里的CPU協調機制,這有點類似于有時多線程并不一定提高效率,原因是線程掛起、調度的開銷比執行任務的開銷還要大,這里的多CPU 也是一樣,如果在 CPU 間調度不合理,也會形成 RFO 指令的開銷比任務開銷還要大。當然,這不是編程者需要考慮的事,操作系統會有相應的內存地址的相關判斷。

? ? ? ?并非所有情況都會使用緩存一致性的,如被操作的數據不能被緩存在CPU內部或操作數據跨越多個緩存行(狀態無法標識),則處理器會調用總線鎖定;另外當 CPU 不支持緩存鎖定時,自然也只能用總線鎖定了,比如說奔騰 486 以及更老的 CPU。

?

轉載:https://blog.csdn.net/qq_35642036/article/details/82801708

?

(SAW:Game Over!)

總結

以上是生活随笔為你收集整理的OS / 总线锁和缓存一致性的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 欧美熟妇精品一区二区蜜桃视频 | 久久久久久久久精 | 久久精品无码人妻 | 国产精品视频你懂的 | 欧美日韩精品一区二区在线播放 | 国产日韩欧美精品一区二区 | 日韩av一区二区三区在线观看 | 亚洲理论在线观看 | 综合黄色 | 又紧又大又爽精品一区二区 | 黄色三级免费观看 | 日韩一卡二卡三卡四卡 | 香蕉人妻av久久久久天天 | 在线看国产 | av激情在线观看 | 波多野结衣乳巨码无在线观看 | av收藏小四郎最新地址 | 欧美亚色 | 国产精品一区二区av | 美女毛片在线 | 亚洲精品tv | 日韩欧美一区二区在线观看 | 五月天激情视频在线观看 | 人人干人人澡 | 国产成人精品无码免费看夜聊软件 | 超碰在97| 午夜啪啪福利 | 久久免费观看视频 | 欧美精品久久久久久久多人混战 | 日韩 在线 | 久久这里| 亚洲字幕av一区二区三区四区 | 阿的白色内裤hd中文 | 日本精品区 | 一区二区不卡在线 | 国产青草| 超碰天堂 | 色婷婷久久久亚洲一区二区三区 | www.日日操 | 中文字幕人妻无码系列第三区 | 日韩电影在线一区二区 | 国产乱真实合集 | 九九综合 | 成人p站在线观看 | 高清视频一区二区三区 | 91丝袜国产在线观看 | 久久小视频 | 国产精品久久久久久亚洲调教 | 久久精选 | 国产视频自拍一区 | 91大神一区二区 | 中文字幕欧美在线 | 亚洲呦呦 | 久久久久久久久久久99 | 黑人一区二区三区 | 91精品久久久久久久久久入口 | 中国二级毛片 | 视频在线一区二区三区 | 在线看片福利 | 欧美亚洲在线观看 | 久草麻豆 | 丝瓜色版 | 草青青视频 | aaa在线 | 亚洲丝袜在线观看 | 国产美女裸体无遮挡免费视频 | 99久久99久久精品免费看蜜桃 | 在线综合色 | 免费在线看黄色片 | 一区二区三区日本视频 | 99精品小视频 | 久久99精品久久久久久 | 新狠狠干 | 国产精品51 | 日本高清视频在线 | 国产精品成av人在线视午夜片 | 免费黄网在线观看 | sese亚洲 | 亚洲成a人片77777kkkk | 日韩激情文学 | 亚洲三级黄| 91porny在线| 美女视频一区 | 亚洲4p| 欧美日韩人妻精品一区 | 老熟妇仑乱一区二区视频 | 四虎最新域名 | 日本女人毛片 | 亚洲91视频 | 国产精品视屏 | xxxwww黄色| 久久中文娱乐网 | 国产精品系列在线播放 | 在线一区二区三区四区五区 | 天天操夜夜操狠狠操 | 亚洲国产精品久久精品怡红院 | 极品福利视频 | 伊人免费在线观看 | 欧洲美一区二区三区亚洲 |