標(biāo)題: Linux內(nèi)核的同步機制之三--讀寫自旋鎖 [打印本頁]
作者: 51黑tt 時間: 2016-3-5 23:39
標(biāo)題: Linux內(nèi)核的同步機制之三--讀寫自旋鎖
讀-寫自旋鎖(spinlock)鎖的用途可以明確地分為讀和寫。Linux提供了專門的讀-寫自旋鎖。這種自旋鎖為讀和寫分別提供了不同的鎖。一個或多少任務(wù)可以并發(fā)地持有讀取鎖;而寫入鎖一次最多只能被一個任務(wù)持有,而且此時不能有并發(fā)的讀操作。我們可以將讀/寫鎖分別叫做共享(并發(fā))/排斥鎖 。
讀寫鎖的用法與一般自旋鎖的用法相似。
初始化:rwlock_t mr_rwlock = RW_LOCK_UNLOCKED;
在讀取的代碼中:
read_lock(&mr_rwlock) ;
/*臨界區(qū)*/
read_unlock(&mr_rwlock);
在寫入的代碼中:
write_lock(&mr_rwlock);
/*臨界區(qū)*/
write_unlock(&mr_rwlock);
通常情況下,讀鎖與寫鎖是分開寫的。注意不能將一個讀鎖“Update”為寫鎖,如下面的代碼將導(dǎo)致死鎖
read_lock(&mr_rwlock);
write_lock(&mr_rwlock);
因為寫鎖要不斷自旋,等待所有的讀鎖釋放鎖,當(dāng)然也就包括它自己,但是它自己處在忙循環(huán)等待中,不能釋放鎖。所以當(dāng)需要寫操作時,一開始就應(yīng)該請求寫鎖,要么先釋放讀鎖,然后再申請寫鎖。
Linux 提供的讀寫自旋鎖的方法如下:
read_lock() 獲得指定的讀鎖
read_lock_irq() 禁止本地中斷并獲得指定的讀鎖
read_lock_irqsave()存儲本地中斷的當(dāng)前狀態(tài),禁止本地中斷并獲得指定讀鎖
read_unlock() 釋放指定的讀鎖
read_unlock_irq()釋放指定的讀鎖并激活本地中斷
read_unlock_irqrestore()釋放指定的讀鎖并將本地中斷恢復(fù)到指定的前狀態(tài)
write_lock() 獲得指定的寫鎖
write_lock_irq() 禁止本地中斷并獲得指定的寫鎖
write_lock_irqsave()存儲本地中斷的當(dāng)前狀態(tài),禁止本地中斷并獲得指定寫鎖
write_unlock() 釋放指定的寫鎖
write_unlock_irq()釋放指定的寫鎖并激活本地中斷
write_unlock_irqrestore()釋放指定的寫鎖并將本地中斷恢復(fù)到指定的前狀態(tài)
writ_trylock() 試圖獲得指定的寫鎖,如果寫鎖不可用,返回非0值
rw_lock_init()初始化指定的rwlock_t
rw_is_locked() 如果指定的鎖當(dāng)前已被持有,返回非0值,否則返回0
如果寫和讀不能清楚分開的話,那么最好就使用一般的自旋鎖
歡迎光臨 (http://www.torrancerestoration.com/bbs/) |
Powered by Discuz! X3.1 |