讀-寫自旋鎖(spinlock) 鎖的用途可以明確地分為讀和寫。Linux提供了專門的讀-寫自旋鎖。這種自旋鎖為讀和寫分別提供了不同的鎖。一個或多少任務可以并發地持有讀取鎖;而寫入鎖一次最多只能被一個任務持有,而且此時不能有并發的讀操作。我們可以將讀/寫鎖分別叫做共享(并發)/排斥鎖 。 讀寫鎖的用法與一般自旋鎖的用法相似。 初始化:rwlock_t mr_rwlock = RW_LOCK_UNLOCKED; 在讀取的代碼中: read_lock(&mr_rwlock) ; /*臨界區*/ read_unlock(&mr_rwlock); 在寫入的代碼中: write_lock(&mr_rwlock); /*臨界區*/ write_unlock(&mr_rwlock); 通常情況下,讀鎖與寫鎖是分開寫的。注意不能將一個讀鎖“Update”為寫鎖,如下面的代碼將導致死鎖 read_lock(&mr_rwlock); write_lock(&mr_rwlock); 因為寫鎖要不斷自旋,等待所有的讀鎖釋放鎖,當然也就包括它自己,但是它自己處在忙循環等待中,不能釋放鎖。所以當需要寫操作時,一開始就應該請求寫鎖,要么先釋放讀鎖,然后再申請寫鎖。 Linux 提供的讀寫自旋鎖的方法如下: read_lock() 獲得指定的讀鎖 read_lock_irq() 禁止本地中斷并獲得指定的讀鎖 read_lock_irqsave()存儲本地中斷的當前狀態,禁止本地中斷并獲得指定讀鎖 read_unlock() 釋放指定的讀鎖 read_unlock_irq()釋放指定的讀鎖并激活本地中斷 read_unlock_irqrestore()釋放指定的讀鎖并將本地中斷恢復到指定的前狀態 write_lock() 獲得指定的寫鎖 write_lock_irq() 禁止本地中斷并獲得指定的寫鎖 write_lock_irqsave()存儲本地中斷的當前狀態,禁止本地中斷并獲得指定寫鎖 write_unlock() 釋放指定的寫鎖 write_unlock_irq()釋放指定的寫鎖并激活本地中斷 write_unlock_irqrestore()釋放指定的寫鎖并將本地中斷恢復到指定的前狀態 writ_trylock() 試圖獲得指定的寫鎖,如果寫鎖不可用,返回非0值 rw_lock_init()初始化指定的rwlock_t rw_is_locked() 如果指定的鎖當前已被持有,返回非0值,否則返回0 如果寫和讀不能清楚分開的話,那么最好就使用一般的自旋鎖
|