下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
第第頁Linux內(nèi)核鎖的那點(diǎn)事
在(Linux)設(shè)備驅(qū)動中,我們必須要解決的一個問題是:多個進(jìn)程對共享資源的并發(fā)訪問,并發(fā)的訪問會導(dǎo)致競態(tài)。
1、并發(fā)和競態(tài)
并發(fā)(Concurrency):指的是多個執(zhí)行單元同時、并行的被執(zhí)行。
競態(tài)(RaceCondi(ti)ons):并發(fā)執(zhí)行的單元對共享資源的訪問,容易導(dǎo)致競態(tài)。
共享資源:(硬件)資源和軟件上的全局變量、靜態(tài)變量等。
解決競態(tài)的途徑是:保證對共享資源的互斥訪問。
互斥訪問:一個執(zhí)行單元在訪問共享資源的時候,其他執(zhí)行單元被禁止訪問。
臨界區(qū)(CriticalSections):訪問共享資源的代碼區(qū)域成為臨界區(qū)。臨界區(qū)需要以某種互斥機(jī)制加以保護(hù)。
常見的互斥機(jī)制包括:中斷屏蔽,原子操作,自旋鎖,(信號)量,互斥體等。
2、競態(tài)發(fā)生的場合
image-20230511140139520
多對稱(處理器)(SMP)的多個(CPU)之間多個CPU使用共同的系統(tǒng)總線,可以訪問共同的外設(shè)和存儲器。在SMP的情況下,多核(CPU0、CPU1)的競態(tài)可能發(fā)生于:
CPU0的進(jìn)程和CPU1的進(jìn)程之間CPU0的進(jìn)程和CPU1的中斷之間CPU0的中斷和CPU1的中斷之間單CPU內(nèi),該進(jìn)程與搶占它的進(jìn)程之間在單CPU內(nèi),多個進(jìn)程并發(fā)執(zhí)行,當(dāng)一個進(jìn)程執(zhí)行的時間片耗盡,也有可能被另一個高優(yōu)先級進(jìn)程打斷,會發(fā)生競態(tài)。
中斷(軟中斷、硬中斷、Tasklet、底半部)與進(jìn)程之間當(dāng)一個進(jìn)程正在執(zhí)行,一個外部/內(nèi)部中斷(軟中斷、硬中斷、Tasklet等)將其打斷,會導(dǎo)致競態(tài)發(fā)生。
3、編譯亂序和執(zhí)行亂序
除了并發(fā)訪問導(dǎo)致的競態(tài)外,還需要了解編譯器和處理器的一些特點(diǎn)所引發(fā)的一些問題。
3.1編譯亂序
現(xiàn)代的高性能編譯器在目標(biāo)代碼優(yōu)化上都具有亂序優(yōu)化的能力,編譯器為了盡量提高Cache命中率以及CPU的Lo(ad)/St(or)e單元的工作效率,可以對訪存的指令進(jìn)行亂序,減少邏輯上不必要的訪存。
因此,在打開編譯器優(yōu)化后,生成的(匯編)碼并沒有嚴(yán)格按照代碼的邏輯順序執(zhí)行,這是正常的。
為了解決編譯亂序的問題,可以加入barrier()編譯屏障,
該屏障可以阻擋編譯器的優(yōu)化。設(shè)置屏障的前后,可以保證執(zhí)行的語句不亂。
加入barrier()編譯屏障,即可保證正確的執(zhí)行順序。
例子:
#definebarrier()__asm____volatile__("":::"memory")intmain(intargc,char*argv[]){inta=0,b,c,d[4096],e;e=d[4095];barrier();b=a;c=a;return0;}3.2執(zhí)行亂序
編譯亂序是編譯器的行為,而執(zhí)行亂序就是處理器運(yùn)行時的行為。
高級的CPU往往會根據(jù)自身的緩存特性,將訪存指令重新排序執(zhí)行!這樣就導(dǎo)致了多個順序的指令,后發(fā)的指令仍有可能先執(zhí)行完畢。
這種執(zhí)行亂序,在多個CPU之間,以及單個CPU內(nèi)部,都是非常常見的。
3.2.1多CPU之間處理器為了解決多核之間,一個CPU的行為對另一個CPU可見的情況,(ARM)處理器引入了內(nèi)存屏障指令:
DMB(數(shù)據(jù)內(nèi)存屏障),保證在該指令前的所有指令,內(nèi)存訪問完成,再去訪問該指令之后的訪存動作DSB(數(shù)據(jù)同步屏障),保證在該指令前的所有訪存指令執(zhí)行完畢(訪存,緩存,跳轉(zhuǎn)預(yù)測,TLB維護(hù)等)完成ISB(指令同步屏障),F(xiàn)lush流水線,保證所有在ISB之后執(zhí)行的指令都是從緩存或者內(nèi)存中獲得。3.2.2單CPU內(nèi)部在單CPU中,我們常遇到訪問外設(shè)(寄存器)時,某些外設(shè)寄存器就對讀寫順序有很高的要求,為了避免執(zhí)行亂序的發(fā)生,這時候就需要CPU的一些內(nèi)存屏障指令了。
CPU內(nèi)部,為了解決這種問題,CPU提供了一些內(nèi)存屏障指令:
可以參考Documentation/memory-devices.txt和Documentation/io_ordering.txt
讀寫屏障:mb()讀屏障:rmb()寫屏障:wmb()寄存器讀屏障__iormb()__寄存器寫屏障__iowmb()__#definewri(te)b_relaxed(v,c)__raw_writeb(v,c)#definewritew_relaxed(v,c)__raw_writew((__forceu16)cpu_to_le16(v),c)#definewritel_relaxed(v,c)__raw_writel((__forceu32)cpu_to_le32(v),c)#definereadb(c)({u8__v=readb_relaxed(c);__iormb();__v;})#definereadw(c)({u16__v=readw_relaxed(c);__iormb();__v;})#definereadl(c)({u32__v=readl_relaxed(c);__iormb();__v;})#definewriteb(v,c)({__iowmb();writeb_relaxed(v,c);})#definewritew(v,c)({__iowmb();writew_relaxed(v,c);})#definewritel(v,c)({__iowmb();writel_relaxed(v,c);})writel與writel_relaxed的區(qū)別就在于有無屏障。
4、總結(jié)
由上文可知,為了
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024版樣機(jī)試制合作協(xié)議
- 2024年出租車租車合同模板
- 懷孕期間夫妻分手協(xié)議
- 城市軌道交通工程建筑信息模型(BIM)分類與編碼標(biāo)準(zhǔn)
- 建筑行業(yè)標(biāo)準(zhǔn)腳手架租賃合同
- 2024項目投資合同撰寫要點(diǎn)
- 購買混凝土合同范本
- 生物中圖版自主訓(xùn)練:第三單元第一章第一節(jié)遺傳物質(zhì)的發(fā)現(xiàn)
- 簡單的賠償協(xié)議書2024年
- 2024屆畢業(yè)生就業(yè)協(xié)議書樣本
- 小學(xué)語文人教三年級上冊 群文閱讀《奇妙的中心句》
- 大數(shù)據(jù)和人工智能知識考試題庫600題(含答案)
- 2023年上海機(jī)場集團(tuán)有限公司校園招聘筆試題庫及答案解析
- 鏡頭的角度和方位課件
- 污水處理常用藥劑簡介知識講解課件
- 五年級上冊英語課件-Unit 1《My future》第1課時牛津上海版(三起) (共28張PPT)
- 光交接箱施工規(guī)范方案
- 氣溫和降水學(xué)案
- 普及人民代表大會制度知識競賽試題庫(1000題和答案)
- 國家電網(wǎng)公司施工項目部標(biāo)準(zhǔn)化管理手冊(2021年版)線路工程分冊
- 《汽車低壓線束設(shè)計規(guī)范》
評論
0/150
提交評論