內(nèi)核同步方法_第1頁
已閱讀1頁,還剩5頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、1、原子操作可以保證指令以原子的方式執(zhí)行——執(zhí)行過程不被打斷。內(nèi)核提供了兩組原子操作接口,一組針對整數(shù)進(jìn)行操作,一組針對單獨(dú)的位進(jìn)行操作。2、針對整數(shù)的原子操作只能對atomic_t類型的數(shù)據(jù)進(jìn)行處理。引入這個(gè)特殊數(shù)據(jù)類型主要是出于三個(gè)原因:首先,讓原子函數(shù)只接受atomic_t類型的操作數(shù)可以確保原子操作只與這種特殊類型的數(shù)據(jù)一起使用。同時(shí)這也保證了該類型的數(shù)據(jù)不會被傳遞給其他任何非原子函數(shù)。其次,使用atomic_t類型確保編譯器不

2、對相應(yīng)的值進(jìn)行訪問優(yōu)化——這點(diǎn)使得原子操作最終接收到正確的內(nèi)存地址,而不只是一個(gè)別名。最后,在不同體系結(jié)構(gòu)上實(shí)現(xiàn)原子操作的時(shí)候,使用atomic_t可以屏蔽期間的差異。3、盡管Linux支持的所有機(jī)器上的整型數(shù)據(jù)都是32位的,但是使用atomic_t的代碼只能將該類型的數(shù)據(jù)當(dāng)作24位來用。這是因?yàn)樵赟PARC體系結(jié)構(gòu)上對原子操作缺乏指令級的支持,所以32位int類型的低8位被嵌入一個(gè)鎖中,利用該鎖來避免對原子類型數(shù)據(jù)的并發(fā)訪問。4、原子

3、整數(shù)操作最常見的應(yīng)用是實(shí)現(xiàn)計(jì)數(shù)器,一般使用atomic_inc()和atomic_dec()這兩個(gè)函數(shù)。所有的標(biāo)準(zhǔn)原子整數(shù)操作見下表:原子整數(shù)操作原子整數(shù)操作描述描述ATOMIC_INIT(inti)在聲明一個(gè)atomic_t變量時(shí),將它初始化為iintatomic_read(atomic_tv)原子地讀取整數(shù)變量vvoidatomic_set(atomic_tvinti)原子地設(shè)置v值為ivoidatomic_add(intiatom

4、ic_tv)原子地給v加ivoidatomic_sub(intiatomic_tv)原子地從v減ivoidatomic_inc(atomic_tv)原子地給v加1voidatomic_dec(atomic_tv)原子地給v減1intatomic_sub__test(intiatomic_tv)原子地從v減i,若結(jié)果等于0返回真,否則返回假intatomic_add_negative(intiatomic_tv)原子地從v加i,若結(jié)果是負(fù)

5、數(shù)返回真,否則返回假intatomic_dec__test(atomic_tv)原子地從v減1,若結(jié)果等于0返回真,否則返回假intatomic_inc__test(atomic_tv)原子地從v加1,若結(jié)果等于0返回真,否則返回假5、原子操作通常是內(nèi)聯(lián)函數(shù),往往是通過內(nèi)嵌匯編指令來實(shí)現(xiàn)的。在編寫代碼時(shí),能使用原子操作的時(shí)候,就盡量不要使用復(fù)雜的加鎖機(jī)制。對多數(shù)體系結(jié)構(gòu)來講,原子操作與更復(fù)雜的同步方法相比較,給系統(tǒng)帶來的開銷小,對高速緩

6、存行的影響也小。spin_trylock()試圖獲取指定的鎖,如果未獲取則返回非0spin_is_locked()如果指定的鎖當(dāng)前正在被獲取則返回非0,否則返回0spin_lock_bh()禁止所有下半部的執(zhí)行,并獲取指定的鎖spin_unlock_bh()釋放指定的鎖,允許下半部的執(zhí)行9、當(dāng)下半部和進(jìn)程上下文共享數(shù)據(jù)時(shí),需要加鎖的同時(shí)還要禁止下半部執(zhí)行;當(dāng)中斷處理程序和下半部共享數(shù)據(jù)時(shí),需要加鎖的同時(shí)還要禁止中斷;當(dāng)數(shù)據(jù)被兩個(gè)不同種類

7、的tasklet共享或軟中斷共享時(shí),沒有必要禁止下半部。10、當(dāng)對某個(gè)數(shù)據(jù)結(jié)構(gòu)的操作可以被劃分為讀寫兩種類別時(shí),可以使用Linux專門提供的讀——寫自旋鎖。這種自旋鎖為讀和寫分別提供了不同的鎖。一個(gè)或多個(gè)讀任務(wù)可以并發(fā)的持有讀者鎖;相反,用于寫的鎖最多只能被一個(gè)寫任務(wù)持有,而且此時(shí)不能有并發(fā)的讀操作。11、通常情況下,讀鎖和寫鎖會位于完全分割開的代碼分支中,下面的代碼將會帶來死鎖:read_lock(write_lock(因?yàn)閷戞i會不斷

8、自旋,等待所有的讀鎖釋放,其中也包括它自己。當(dāng)確實(shí)需要寫操作時(shí),要在一開始就請求寫鎖。如果寫和讀不能清晰分開的話,那么就使用一般的自旋鎖。多個(gè)讀者可以安全地獲得同一個(gè)讀鎖,即使一個(gè)線程遞歸地獲得一個(gè)讀鎖也是安全的。這個(gè)特性使讀——寫自旋鎖成為一種有用并且常用的優(yōu)化手段。讀——寫鎖這種機(jī)制照顧讀要比照顧寫多一點(diǎn)。讀鎖被持有時(shí),寫鎖只能等待,但讀者卻可以繼續(xù)成功地占用鎖,大量的讀者就會使掛起的寫者處于饑餓狀態(tài)。讀——寫鎖的操作見下表:方法方

9、法描述描述read_lock()獲取指定的讀鎖read_lock_irq()禁止本地中斷并獲取指定的讀鎖read_lock_irqsave()保存本地中斷的當(dāng)前狀態(tài),禁止本地中斷并獲取指定的讀鎖read_unlock()釋放指定的讀鎖read_unlock_irq()釋放指定的讀鎖,并激活本地中斷read_unlock_irqreste()釋放指定的讀鎖,并讓本地中斷恢復(fù)到以前的狀態(tài)write_lock()獲取指定的寫鎖write_lo

溫馨提示

  • 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論