讀-寫自旋鎖(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 如果寫和讀不能清楚分開的話,那么最好就使用一般的自旋鎖
|