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

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

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

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

3、整數(shù)操作最常見的應用是實現(xiàn)計數(shù)器,一般使用atomic_inc()和atomic_dec()這兩個函數(shù)。所有的標準原子整數(shù)操作見下表:原子整數(shù)操作原子整數(shù)操作描述描述ATOMIC_INIT(inti)在聲明一個atomic_t變量時,將它初始化為iintatomic_read(atomic_tv)原子地讀取整數(shù)變量vvoidatomic_set(atomic_tvinti)原子地設置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é)果是負

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)嵌匯編指令來實現(xiàn)的。在編寫代碼時,能使用原子操作的時候,就盡量不要使用復雜的加鎖機制。對多數(shù)體系結(jié)構(gòu)來講,原子操作與更復雜的同步方法相比較,給系統(tǒng)帶來的開銷小,對高速緩

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

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

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

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

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論