精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

對于Linux內核中的內存屏障的總結

系統 Linux
之前讀了關于順序一致性和緩存一致性討論的文章,感覺豁然開朗。對linux內核中出現的種種同步和屏障,想做一點總結。

Linux內核中的內存屏障

前言

之前讀了關于順序一致性和緩存一致性討論的文章,感覺豁然開朗。對linux內核中出現的種種同步和屏障,想做一點總結。

緩存一致性

之前一直認為linux中很多東西是用來保證緩存一致性的,其實不是。緩存一致性絕大部分是靠硬件機制實現的,只有在帶lock前綴的指令執行時才與cache有一點關系。(這話說得絕對,但我目前看來就是這樣)我們更多的時候是為了保證順序一致性。

-

所謂緩存一致性,就是在多處理器系統中,每個cpu都有自己的L1 cache。很可能兩個不同cpu的L1 cache中緩存的是同一片內存的內容,如果一個cpu更改了自己被緩存的內容,它要保證另一個cpu讀這塊數據時也要讀到這個***的。不過你不要擔心,這個復雜的工作完全是由硬件來完成的,通過實現一種MESI協議,硬件可以輕松的完成緩存一致性的工作。不要說一個讀一個寫,就是多個同時寫都沒問題。一個cpu讀時總能讀入***的數據,不管它是在自己的cache中,還是在其它cpu的cache中,還是在內存中,這就是緩存一致性。

順序一致性

所謂順序一致性,說的則是與緩存一致性完全不同的概念,雖然它們都是處理器發展的產物。因為編譯器的技術不斷發展,它可能為了優化你的代碼,而將某些操作的順序更改執行。處理器中也早就有了多發射、亂序執行的概念。這樣的結果,就是實際執行的指令順序會與編程時代碼的執行順序略有不同。這在單處理器下當然沒什么,畢竟只要自己的代碼不過問,就沒人過問,編譯器和處理器就是在保證自己的代碼發現不了的情況下打亂執行順序的。但多處理器不是這樣,可能一個處理器上指令的完成順序,會對其它處理器上執行的代碼造成很大影響。所以就有了順序一致性的概念,即保證一個處理器上線程的執行順序,在其它的處理器上的線程看來,都是一樣的。這個問題的解決不是光靠處理器或者編譯器就能解決的,需要軟件的干預。

內存屏障

軟件干預的方式也非常簡單,那就是插入內存屏障(memory barrier)。其實內存屏障這個詞,是由搞處理器的人造的,弄得我們很不好理解。內存屏障,很容易讓我們串到緩存一致性去,乃至懷疑是否這樣做才能讓其它cpu看到被修改過的cache,這樣想就錯了。所謂內存屏障,從處理器角度來說,是用來串行化讀寫操作的,從軟件角度來講,就是用來解決順序一致性問題的。編譯器不是要打亂代碼執行順序嗎,處理器不是要亂序執行嗎,你插入一個內存屏障,就相當于告訴編譯器,屏障前后的指令順序不能顛倒,告訴處理器,只有等屏障前的指令執行完了,屏障后的指令才能開始執行。當然,內存屏障能阻擋編譯器亂來,但處理器還是有辦法。處理器中不是有多發射、亂序執行、順序完成的概念嗎,它在內存屏障時只要保證前面指令的讀寫操作,一定在后面指令的讀寫操作完成之前完成,就可以了。所以內存屏障才會對應有讀屏障、寫屏障和讀寫屏障三類。如x86之前保證寫操作都是順序完成的,所以不需要寫屏障,但現在也有部分ia32處理器的寫操作變成亂序完成,所以也需要寫屏障。

其實,除了專門的讀寫屏障指令,還有很多指令的執行是帶有讀寫屏障功能的,比如帶lock前綴的指令。在專門的讀寫屏障指令出現之前,linux就是靠lock熬過來的。

至于在那里插入讀寫屏障,要視軟件的需求而定。讀寫屏障無法完全實現順序一致性,但多處理器上的線程也不會一直盯著你的執行順序看,只要保證在它看過來的時候,認為你符合順序一致性,執行不會出現你代碼中沒有預料到的情況。所謂預料外的情況,舉例而言,你的線程是先給變量a賦值,再給變量b賦值,結果別的處理器上運行的線程看過來,發現b賦值了,a卻沒有賦值,(注意這種不一致不是由緩存不一致造成的,而是處理器寫操作完成的順序不一致造成的),這時就要在a賦值與b賦值之間,加一個寫屏障。

多處理器間同步

有了SMP之后,線程就開始同時在多個處理器上運行。只要是線程就有通信和同步的要求。幸好SMP系統是共享內存的,也就是所有處理器看到的內存內容都一樣,雖然有獨立的L1 cache,但還是由硬件完成了緩存一致性處理的問題。那不同處理器上的線程要訪問同一數據,需要臨界區,需要同步。靠什么同步?之前在UP系統中,我們上靠信號量,下靠關中斷和讀修改寫指令。現在在SMP系統中,關中斷已經廢了,雖然為了同步同一處理器上的線程還是需要的,但只靠它已經不行了。讀修改寫指令?也不行了。在你指令中讀操作完成寫操作還沒進行時,就可能有另外的處理器進行了讀操作或者寫操作。緩存一致性協議是先進,但還沒有先進到預測這條讀操作是哪種指令發出來的。所以x86又發明了帶lock前綴的指令。在此指令執行時,會將所有包含指令中讀寫地址的cache line失效,并鎖定內存總線。這樣別的處理器要想對同樣的地址或者同一個cache line上的地址讀寫,既無法從cache中進行(cache中相關line已經失效了),也無法從內存總線上進行(整個內存總線都鎖了),終于達到了原子性執行的目的。當然,從P6處理器開始,如果帶lock前綴指令 要訪問的地址本來就在cache中,就無需鎖內存總線,也能完成原子性操作了(雖然我懷疑這是因為加了多處理器內部公共的L2 cache的緣故)。

因為會鎖內存總線,所以帶lock前綴指令執行前,也會先將未完成的讀寫操作完成,也起到內存屏障的功能。

現在多處理器間線程的同步,上用自旋鎖,下用這種帶了lock前綴的讀修改寫指令。當然,實際的同步還有加上禁止本處理器任務調度的,有加上任務關中斷的,還會在外面加上信號量的外衣。linux中對這種自旋鎖的實現,已歷經四代發展,變得愈發高效強大。

內存屏障的實現

  1. #ifdef CONFIG_SMP 
  2.  
  3. #define smp_mb() mb() 
  4.  
  5. #define smp_rmb() rmb() 
  6.  
  7. #define smp_wmb() wmb() 
  8.  
  9. #else 
  10.  
  11. #define smp_mb() barrier() 
  12.  
  13. #define smp_rmb() barrier() 
  14.  
  15. #define smp_wmb() barrier() 
  16.  
  17. #endif 

CONFIG_SMP就是用來支持多處理器的。如果是UP(uniprocessor)系統,就會翻譯成barrier()。

  1. #define barrier() __asm__ __volatile__("": : :"memory"

barrier()的作用,就是告訴編譯器,內存的變量值都改變了,之前存在寄存器里的變量副本無效,要訪問變量還需再訪問內存。這樣做足以滿足UP中所有的內存屏障。

  1. #ifdef CONFIG_X86_32 
  2.  
  3. /* 
  4.  
  5. Some non-Intel clones support out of order store. wmb() ceases to be a 
  6.  
  7. * nop for these. 
  8.  
  9. */ 
  10.  
  11. #define mb() alternative("lock; addl $0,0(%%esp)""mfence", X86_FEATURE_XMM2) 
  12.  
  13. #define rmb() alternative("lock; addl $0,0(%%esp)""lfence", X86_FEATURE_XMM2) 
  14.  
  15. #define wmb() alternative("lock; addl $0,0(%%esp)""sfence", X86_FEATURE_XMM) 
  16.  
  17. #else 
  18.  
  19. #define mb() asm volatile("mfence":::"memory"
  20.  
  21. #define rmb() asm volatile("lfence":::"memory"
  22.  
  23. #define wmb() asm volatile("sfence" ::: "memory"
  24.  
  25. #endif 

如果是SMP系統,內存屏障就會翻譯成對應的mb()、rmb()和wmb()。這里CONFIG_X86_32的意思是說這是一個32位x86系統,否則就是64位的x86系統。現在的linux內核將32位x86和64位x86融合在同一個x86目錄,所以需要增加這個配置選項。

可以看到,如果是64位x86,肯定有mfence、lfence和sfence三條指令,而32位的x86系統則不一定,所以需要進一步查看cpu是否支持這三條新的指令,不行則用加鎖的方式來增加內存屏障。

SFENCE,LFENCE,MFENCE指令提供了高效的方式來保證讀寫內存的排序,這種操作發生在產生弱排序數據的程序和讀取這個數據的程序之間。

SFENCE——串行化發生在SFENCE指令之前的寫操作但是不影響讀操作。

LFENCE——串行化發生在SFENCE指令之前的讀操作但是不影響寫操作。

MFENCE——串行化發生在MFENCE指令之前的讀寫操作。

sfence:在sfence指令前的寫操作當必須在sfence指令后的寫操作前完成。

lfence:在lfence指令前的讀操作當必須在lfence指令后的讀操作前完成。

mfence:在mfence指令前的讀寫操作當必須在mfence指令后的讀寫操作前完成。

至于帶lock的內存操作,會在鎖內存總線之前,就把之前的讀寫操作結束,功能相當于mfence,當然執行效率上要差一些。

說起來,現在寫點底層代碼真不容易,既要注意SMP問題,又要注意cpu亂序讀寫問題,還要注意cache問題,還有設備DMA問題,等等。 

責任編輯:龐桂玉 來源: 嵌入式Linux中文站
相關推薦

2025-03-21 00:00:00

2010-09-17 10:00:38

SIP優點

2009-10-29 09:41:01

Linux內核DeviceMappe

2025-03-27 09:14:51

2019-12-10 14:51:00

CPU緩存內存

2025-01-02 11:06:22

2025-09-18 09:17:46

2011-01-14 13:50:37

2023-05-15 08:58:41

塊設備驅動Linux

2009-09-28 10:09:09

Linux內核Linux循環鏈表

2021-03-08 08:55:41

Linux內存命令

2013-12-18 15:54:21

2018-05-18 09:07:43

Linux內核內存

2012-08-16 10:00:35

SQL Server內存管理

2025-03-28 08:35:00

2009-12-25 15:24:16

內存管理

2016-12-26 08:56:09

LinuxDTraceBPF

2023-05-12 07:27:24

Linux內核網絡設備驅動

2017-08-01 17:34:47

Linux內核驅動文件讀寫

2009-12-29 10:24:51

Linux內核循環鏈表
點贊
收藏

51CTO技術棧公眾號

国产精品美女免费看| 日韩激情片免费| 国产一二三四五| 亚洲色成人www永久网站| 区一区二视频| 亚洲二区在线播放视频| 天天操天天爽天天射| 日本片在线观看| 久久色视频免费观看| 91精品在线播放| 欧美日韩乱国产| 亚洲色图国产| 一区二区三区视频免费在线观看| 国产欧美精品aaaaaa片| 人成网站在线观看| 日韩成人dvd| 久久久久久国产精品美女| 免费看的黄色网| 牛牛视频精品一区二区不卡| 欧美日韩国产一级| 免费看国产一级片| 蜜桃av在线免费观看| 99九九99九九九视频精品| 国产有码一区二区| 日韩熟女一区二区| 黄色亚洲免费| 操91在线视频| 色撸撸在线视频| 秋霞影视一区二区三区| 欧美一区二区三区公司| av无码精品一区二区三区| 美足av综合网| 综合久久综合久久| 午夜精品电影在线观看| 手机福利小视频在线播放| 国产精品18久久久久久久久久久久| 久久九九国产精品怡红院| 亚洲最大成人网站| 日韩高清一级| 亚洲电影中文字幕| 国产精品偷伦视频免费观看了| 国产福利视频在线| 中文字幕免费观看一区| 免费精品视频一区| 四虎影视2018在线播放alocalhost| 国产一区成人| 久久久久在线观看| 中文字幕影音先锋| 色天天久久综合婷婷女18| 一区二区三区四区在线观看视频| 最新天堂在线视频| 成人在线视频免费看| 91黄色免费网站| 欧美日韩激情视频在线观看| 国产传媒av在线| 亚洲成人免费视| 国产妇女馒头高清泬20p多| wwww亚洲| 疯狂做受xxxx高潮欧美日本| 奇米影视亚洲色图| 91九色国产在线播放| 亚洲午夜精品17c| 日韩黄色短视频| heyzo高清在线| 亚洲成av人**亚洲成av**| 日本精品久久久久久久久久| av在线播放资源| 欧美日韩视频在线| 91av俱乐部| 四虎永久精品在线| 日韩欧美精品在线| 污污污www精品国产网站| 丝袜美腿一区二区三区动态图| 制服.丝袜.亚洲.中文.综合| 手机看片国产精品| 黄色欧美在线| 一夜七次郎国产精品亚洲| 长河落日免费高清观看| 欧美影视一区| 91成人在线播放| 亚洲 国产 日韩 欧美| 精品综合免费视频观看| 成人免费视频a| 男人天堂一区二区| 国产女人18毛片水真多成人如厕 | 丝袜连裤袜欧美激情日韩| 日韩精品在线免费播放| 日本欧美一区二区三区不卡视频| 国偷自产av一区二区三区| 亚洲国产高清高潮精品美女| 精品成人av一区二区三区| 欧美大黑bbbbbbbbb在线| 欧美黄色片在线观看| 中文字幕在线观看视频网站| 美女爽到高潮91| 成人午夜影院在线观看| 美国一级片在线免费观看视频 | 91禁男男在线观看| 重囗味另类老妇506070| 日本精品视频在线| 国内毛片毛片毛片毛片| 久久亚洲精华国产精华液| 中文字幕在线观看一区二区三区| av网站在线免费播放| 一卡二卡欧美日韩| 爱情岛论坛亚洲首页入口章节| 女生影院久久| 日韩一级片在线观看| 免费黄色在线视频| 欧美激情综合色综合啪啪| 日本在线观看天堂男亚洲| 成人1区2区3区| 亚洲欧洲一区二区三区| 久久婷婷五月综合色国产香蕉| www在线观看黄色| 欧美日韩国产欧美日美国产精品| 国产精品久久久毛片| 伦理一区二区| 久久精品青青大伊人av| 波多野结衣啪啪| 成人av在线资源| 日韩视频在线免费播放| 日韩免费小视频| 日韩电影中文字幕av| 玖玖爱免费视频| 精品午夜久久福利影院| 日韩精品一区二区三区丰满| 僵尸再翻生在线观看| 精品欧美一区二区三区精品久久| yy1111111| 欧美日韩国产高清| 亚洲999一在线观看www| 欧美日本一道| 欧美日产国产精品| 国产欧美一区二区三区在线观看视频| 中日韩免视频上线全都免费| 国产丝袜精品视频| 日本一区二区三区四区五区| 国产aⅴ精品一区二区三区色成熟| 超碰97人人人人人蜜桃| 91在线网址| 欧美色手机在线观看| 男人的天堂av网| 欧美aⅴ一区二区三区视频| 精品一区二区视频| 蜜桃av.网站在线观看| 亚洲成人久久电影| 日韩激情在线播放| 成人h版在线观看| 国产精品裸体瑜伽视频| 青青久久av| 国产97在线|日韩| 国产小视频免费在线观看| 在线观看中文字幕不卡| 无码人妻丰满熟妇啪啪欧美| 三级在线观看一区二区| 欧美日韩一区二区三区在线视频| 欧美激情黑人| 日韩欧美一区二区免费| 久久久久黄色片| 99久久精品免费看| 国产亚洲精品网站| 国产区精品区| 成人美女av在线直播| 直接在线观看的三级网址| 日韩欧美国产一二三区| 日本熟妇毛茸茸丰满| 337p粉嫩大胆噜噜噜噜噜91av | 国产原创精品视频| 91精品国产乱码久久蜜臀| 校园春色 亚洲| 97se亚洲国产综合自在线不卡| 国产精品亚洲天堂| 中文字幕一区二区三区日韩精品| 国产亚洲成av人片在线观看桃| 欧美精品一级片| 成人精品视频网站| 欧美成人免费高清视频| 97精品在线| 不卡一区二区三区视频| 一本大道色婷婷在线| 色爱av美腿丝袜综合粉嫩av| aaa一区二区三区| 精品久久在线播放| 91麻豆精品久久毛片一级| 国产成人在线网站| 亚洲精品乱码久久久久久自慰| 理论片一区二区在线| 国产成+人+综合+亚洲欧美丁香花| 日韩在线观看视频一区| 在线观看91视频| 老司机成人免费视频| av亚洲精华国产精华精华| 亚洲欧美另类动漫| 亚洲图片在线| 日韩福利一区二区三区| 一区二区三区在线资源| 国产精品高清免费在线观看| 在线看三级电影| 国产一区二区黄| 人妻视频一区二区三区| 制服丝袜激情欧洲亚洲| 亚洲欧美另类在线视频| 亚洲精品久久嫩草网站秘色| 中文字幕免费视频| 粉嫩绯色av一区二区在线观看| 日韩极品视频在线观看| 成人网18免费网站| 精品一卡二卡三卡四卡日本乱码 | xxxxxx黄色| 九九九久久久精品| 欧美日韩一区二区在线免费观看| 亚洲欧洲免费| 99一区二区| 亚洲人成网站在线在线观看| 欧美最顶级丰满的aⅴ艳星| а√中文在线8| 这里只有精品久久| 免费av在线电影| 日韩电影中文字幕在线| 精品人妻午夜一区二区三区四区| 一二三区精品视频| 国产又黄又粗又猛又爽的| 91色视频在线| 日本少妇xxxx| 成av人片一区二区| 一区二区三区人妻| 韩国av一区二区三区四区| 别急慢慢来1978如如2| 亚洲一区二区成人| 日韩欧美不卡在线| 伊人久久婷婷| 黄色三级中文字幕| 中文字幕免费一区二区| 伊人久久大香线蕉av一区| 热久久天天拍国产| 欧洲一区二区日韩在线视频观看免费 | 国产一线在线观看| 国产成人精品免费网站| 国产男女无遮挡猛进猛出| 毛片av中文字幕一区二区| 久久久久久久片| 免费中文字幕日韩欧美| 国产免费黄视频| 亚洲少妇自拍| 国产在线观看福利| 国产手机视频一区二区| 免费看一级大黄情大片| 一区二区三区高清视频在线观看| 亚洲精品二区| 欧美综合另类| 一区二区三区四区视频在线观看| 黄色美女久久久| 久久99精品国产99久久| 久久九九热re6这里有精品| 国产一区二区三区免费不卡| 久久综合另类图片小说| 久久影视中文粉嫩av| 九九久久婷婷| 亚洲一区二区精品在线| 亚洲国产老妈| 久激情内射婷内射蜜桃| 亚洲一区二区三区四区五区午夜| 日韩中文字幕在线不卡| 欧美视频亚洲视频| 成人免费观看cn| 国产一区成人| 日本不卡一区二区在线观看| 国产精品一区不卡| 一本加勒比波多野结衣| 久久久精品免费免费| 欧美一区二区三区观看| 亚洲欧美另类小说视频| xxxxxx国产| 在线精品视频免费播放| aaa级黄色片| 国产丝袜精品第一页| av在线资源站| 欧美国产一区二区三区| 在线成人av观看| 亚洲va国产va欧美va观看| 久久99久久久久久| 久久精品中文| 伊人精品视频在线观看| 26uuu成人网一区二区三区| 免费看一级黄色| 亚洲成av人片在线| 依依成人在线视频| 精品第一国产综合精品aⅴ| 国产在线色视频| 欧美成人精品在线观看| 在线免费看h| 亚洲a在线播放| 久草成人在线| 激情成人开心网| 视频一区视频二区在线观看| 久国产精品视频| 久久免费视频色| 青青草精品在线视频| 日本高清不卡在线观看| 亚洲成人第一区| 日韩在线国产精品| 欧亚av在线| 3d蒂法精品啪啪一区二区免费| 色综合视频一区二区三区44| 成人性色av| 日本欧美视频| 欧美三级一级片| 国产精品白丝jk黑袜喷水| 亚洲v国产v欧美v久久久久久| 久久精品一二三| 亚洲国产精品成人无久久精品| 亚洲综合另类小说| 影音先锋国产资源| 亚洲欧美一区二区三区在线| 性欧美ⅴideo另类hd| 国产免费一区二区三区在线观看| 91精品国产色综合久久不卡粉嫩| 成人亚洲综合色就1024| 欧美人妖在线| 精品久久一二三| 成人激情免费网站| 国产大学生自拍| 5566中文字幕一区二区电影| av在线天堂播放| 国产精品久在线观看| 国产一区二区亚洲| 97国产精东麻豆人妻电影| 国产99久久久精品| 青春草免费视频| 日韩欧美123| caopon在线免费视频| 91精品久久久久久久久| 成人精品亚洲| 国产一级做a爰片久久| 久久精品一区二区三区不卡 | 2019av中文字幕| 2023国产精华国产精品| 亚洲国产精品影视| 久草精品在线观看| 四虎影院中文字幕| 7777精品伊人久久久大香线蕉超级流畅| 午夜老司机福利| 久久国产精彩视频| 99综合久久| 超级碰在线观看| 粉嫩蜜臀av国产精品网站| 国产精品第108页| 亚洲国产另类 国产精品国产免费| 成年人在线观看| 国产精品丝袜高跟| 日韩欧美视频在线播放| 污视频网址在线观看| 18欧美乱大交hd1984| 国产成人毛毛毛片| 久久久久国产一区二区三区| 国产厕拍一区| 欧美极品欧美精品欧美图片| 久久色视频免费观看| 中文区中文字幕免费看| 久久精品99久久香蕉国产色戒| 亚洲欧洲自拍| 日本不卡一区| 精品在线播放午夜| 久草网在线观看| 国产视频久久久久久久| 国产毛片精品久久| 国产在线拍揄自揄拍无码| 丁香激情综合五月| 亚洲天堂一区在线观看| 中文字幕亚洲国产| 久久9999免费视频| 日韩在线综合网| 国产精品人妖ts系列视频| 国产情侣一区二区| 国内精品久久久久| 欧美日韩一区二区综合| 欧美在线a视频| 欧美日韩国产综合新一区| av在线免费观看网站| 亚洲va国产va天堂va久久| 国产日韩欧美一区| 亚洲欧美另类日本| 精品美女一区二区| 日韩中文影院| 韩日视频在线观看| 国产精品女人毛片| 污污网站免费在线观看| 国产日本欧美一区二区三区| 国内精品福利| 91社区视频在线观看| 精品福利一二区| 亚洲伦理一区二区| 国产肥臀一区二区福利视频| 日韩美女久久久| 日夜干在线视频| 91国产丝袜在线放| 麻豆精品国产传媒mv男同| 日韩欧美a级片| 久久精品国产一区二区电影|