加入星計劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴(kuò)散
  • 作品版權(quán)保護(hù)
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長期合作伙伴
立即加入
  • 正文
  • 推薦器件
  • 相關(guān)推薦
  • 電子產(chǎn)業(yè)圖譜
申請入駐 產(chǎn)業(yè)圖譜

Linux記一次spin_lock死鎖優(yōu)化經(jīng)驗

05/28 16:16
2024
閱讀需 5 分鐘
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點資訊討論

哈嘍,大家好,我是程序員秘書LittleG。

上篇:虹膜識別技術(shù)原理以及現(xiàn)狀和未來

前言

死鎖是很常見的一種內(nèi)核故障。最常見的,就是如果一個task在已經(jīng)持有某個鎖的情況下,再次嘗試獲取同一個鎖,就會形成死鎖局面。發(fā)生死鎖的場景有很多,常見的情況可能有,可能是在同一個task中鎖使用不當(dāng);也可能是兩個task有資源競爭和依賴,形成互鎖互等;也可能是某個task拿了鎖后又被某個中斷搶占,之后又在等拿相同的鎖。

最近剛分析和處理了一個死鎖問題,就是一個task和一個中斷拿相同鎖出現(xiàn)的死鎖問題,最后是通過替換拿鎖接口函數(shù)解決的。主要是涉及到spin_trylock_irq()?和?spin_trylock()?這兩個函數(shù)的使用場景和差別,記錄學(xué)習(xí)之。

正文

spin_trylock_irq()?和?spin_trylock()?都是Linux內(nèi)核中用于嘗試獲取自旋鎖的函數(shù),但它們在使用場景和行為上有所區(qū)別,主要體現(xiàn)在對中斷的處理上。

spin_trylock()

功能說明:

spin_trylock()?是一個非阻塞的自旋鎖獲取函數(shù),會嘗試立即獲取自旋鎖。如果鎖已被其他CPU持有,該函數(shù)會立即返回失?。ㄍǔ7祷?),而不會讓調(diào)用者進(jìn)入等待狀態(tài)。主要用于那些無法承受阻塞開銷或不適合睡眠的上下文。

中斷處理:

調(diào)用?spin_trylock()?時,當(dāng)前CPU的中斷狀態(tài)不變。也就是說,如果在中斷上下文中調(diào)用此函數(shù),中斷仍然保持禁止?fàn)顟B(tài);而在進(jìn)程上下文中調(diào)用,則中斷是啟用的。

spin_trylock_irq()

功能說明:

spin_trylock_irq()?與?spin_trylock()?類似,也是嘗試立即獲取自旋鎖,如果不能立即獲取則返回失敗。但是,它還額外包含了一層對中斷的管理。

中斷處理:

在嘗試獲取鎖之前,spin_trylock_irq()?會臨時禁用本地中斷(如果之前是啟用狀態(tài)),并在操作完成后恢復(fù)中斷的原始狀態(tài)。這意味著,無論是在中斷上下文還是進(jìn)程上下文中調(diào)用,它都會確保在嘗試獲取鎖期間中斷是被禁止的,從而避免了在獲取鎖的過程中被中斷打斷的復(fù)雜性。這樣設(shè)計實現(xiàn)顯而易見提高了鎖操作的原子性和安全性,但需要注意的是,可能會在某些對中斷響應(yīng)時間敏感的場景中引入延遲。

總結(jié)

spin_trylock_irq()?與?spin_trylock()?兩個函數(shù)都是非阻塞式的自旋鎖獲取操作,不成功即返回,都不會引起調(diào)用者睡眠。

主要區(qū)別在于對中斷的處理上。spin_trylock()?不改變當(dāng)前中斷狀態(tài),而?spin_trylock_irq()?則會在操作前臨時禁用中斷,操作后恢復(fù)中斷狀態(tài),確保了操作的原子性。

至于選擇使用哪個函數(shù)取決于具體的上下文需求

如果明確不希望在鎖獲取過程中被中斷打斷的情況下,或者處于一個可能需要明確控制中斷狀態(tài)的上下文中,則需要使用spin_trylock_irq()?。而在不需要特別處理中斷,或者明確知道當(dāng)前中斷狀態(tài)已滿足要求的情況下,以及追求性能的情況下,可以考慮使用?spin_trylock()。

推薦器件

更多器件
器件型號 數(shù)量 器件廠商 器件描述 數(shù)據(jù)手冊 ECAD模型 風(fēng)險等級 參考價格 更多信息
S25FL256SAGMFI000 1 Spansion Flash, 64MX4, PDSO16, SOIC-16
$9.11 查看
ECS-2520MV-333.3-CM-TR 1 ECS International Inc HCMOS Output Clock Oscillator,
暫無數(shù)據(jù) 查看
SN65HVD233DR 1 Texas Instruments 3.3 V CAN Transceiver with Standby Mode, Loopback 8-SOIC -40 to 125

ECAD模型

下載ECAD模型
$2.73 查看

相關(guān)推薦

電子產(chǎn)業(yè)圖譜

記錄和分享C/C++、Linux、ARM、Android、IoT相關(guān)知識。技術(shù)相伴于生活和成長,愿你我永為少年,心中有火,眼中有光,始保熱情。