當(dāng)前位置:首頁 > 公眾號(hào)精選 > Linux閱碼場(chǎng)
[導(dǎo)讀]為什么要加鎖在SMP系統(tǒng)中,如果僅僅是需要串行地增加一個(gè)變量的值,那么使用原子操作的函數(shù)(API)就可以了。但現(xiàn)實(shí)中更多的場(chǎng)景并不會(huì)那么簡單,比如需要將一個(gè)結(jié)構(gòu)體A中的數(shù)據(jù)提取出來,然后格式化、解析,再添加到另一個(gè)結(jié)構(gòu)體B中,這整個(gè)的過程都要求是「原子的」,也就是完成之前,不允許...

為什么要加鎖

在SMP系統(tǒng)中,如果僅僅是需要串行地增加一個(gè)變量的值,那么使用原子操作的函數(shù)(API)就可以了。但現(xiàn)實(shí)中更多的場(chǎng)景并不會(huì)那么簡單,比如需要將一個(gè)結(jié)構(gòu)體A中的數(shù)據(jù)提取出來,然后格式化、解析,再添加到另一個(gè)結(jié)構(gòu)體B中,這整個(gè)的過程都要求是「原子的」,也就是完成之前,不允許其他的代碼來讀/寫這兩個(gè)結(jié)構(gòu)體中的任何一個(gè)。

這時(shí),相對(duì)輕量級(jí)的原子操作API就無法滿足這種應(yīng)用場(chǎng)景的需求了,我們需要一種更強(qiáng)的同步/互斥機(jī)制,那就是軟件層面的「鎖」的機(jī)制。

同步鎖的「加鎖」和「解鎖」是放在一段代碼的一前一后,成對(duì)出現(xiàn)的,這段代碼被稱為Critical Section/Region(臨界區(qū))。但鎖保護(hù)的并不是這段代碼本身,而是其中使用到的多核/多線程共享的變量,它「同步」(或者說串行化)的是對(duì)這個(gè)變量的訪問,通俗的語義就是“我有你就不能有,你有我就不會(huì)有”。

Linux中主要有兩種同步鎖,一種是spinlock,一種是mutex。spinlock和mutex都既可以在用戶進(jìn)程中使用,也可以在內(nèi)核中使用,它們的主要區(qū)別是前者不會(huì)導(dǎo)致睡眠和調(diào)度,屬于busy wait形式的鎖,而后者可能導(dǎo)致睡眠和調(diào)度,屬于sleep wait形式的鎖。

spinlock是最基礎(chǔ)的一種鎖,像后面將要介紹的rwlock(讀寫鎖),seqlock(讀寫鎖)等都是基于spinlock衍生出來的。就算是mutex,它的實(shí)現(xiàn)與spinlock也是密不可分。因此,本系列文章將首先圍繞spinlock展開介紹。

如何加鎖

Linux中spinlock機(jī)制發(fā)展到現(xiàn)在,其實(shí)現(xiàn)方式的大致有3種。

【第一種實(shí)現(xiàn) - 經(jīng)典的CAS】

最古老的一種做法是:spinlock用一個(gè)整形變量表示,其初始值為1,表示available的狀態(tài)。當(dāng)一個(gè)CPU(設(shè)為CPU A)獲得spinlock后,會(huì)將該變量的值設(shè)為0,之后其他CPU試圖獲取這個(gè)spinlock時(shí),會(huì)一直等待,直到CPU A釋放spinlock,并將該變量的值設(shè)為1。

那么其他的CPU是以何種形式等待的,如果有多個(gè)CPU一起等待,形成了競爭又該如何處理?這里要用到經(jīng)典的CAS操作(Compare And Swap)。

  • 誰和誰比較

目前,sh架構(gòu)的Linux實(shí)現(xiàn)中還保留有這種經(jīng)典的實(shí)現(xiàn)方法(相關(guān)代碼位于/arch/sh/include/asm/spinlock-cas.h)。

static inline void arch_spin_lock(arch_spinlock_t *lock)
{
while (!__sl_cas(
本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

廣告科技領(lǐng)導(dǎo)者Kira LeBlanc晉升為全球首席營銷官  蒙特利爾和多倫多2022年4月1日 /美通社/ -- 全球最大的獨(dú)立程序化數(shù)字戶外(DOOH)廣告技術(shù)公司之一Hivestack今天宣布...

關(guān)鍵字: ck

(全球TMT2022年4月1日訊)獨(dú)立程序化數(shù)字戶外(DOOH)廣告技術(shù)公司Hivestack宣布任命Kira LeBlanc為全球首席營銷官。LeBlanc于2021年初Hivestack宣布其全球擴(kuò)張計(jì)劃時(shí)加入該公...

關(guān)鍵字: ck

(全球TMT2022年3月28日訊)Super Micro Computer, Inc. (SMCI) 宣布將支持NVIDIA最新的軟件和硬件版本。Supermicro的NVIDIA認(rèn)證服務(wù)器和工作站經(jīng)過驗(yàn)證...

關(guān)鍵字: ni ic Enterprise

面向供電行業(yè)的革命性交鑰匙解決方案,可提高系統(tǒng)可靠性和電網(wǎng)彈性 伊利諾伊州博林布魯克2022年3...

關(guān)鍵字: 輸電線路 ic

2021年全年多項(xiàng)業(yè)績指標(biāo)再創(chuàng)新高; “企業(yè)數(shù)字化運(yùn)營解決方案”全年收入持續(xù)三位數(shù)同比增長; “SaaS+X”商業(yè)模式為“企業(yè)數(shù)字化運(yùn)營解決方案”的迅猛增長...

關(guān)鍵字: ic ck

(全球TMT2022年3月24日訊)Shutterstock, Inc.是一個(gè)全球領(lǐng)先的創(chuàng)意平臺(tái),為眾多品牌、企業(yè)和媒體公司提供全方位服務(wù)解決方案、高質(zhì)量內(nèi)容及創(chuàng)意工作流程解決方案。該公司宣布在其已有十年傳統(tǒng)的年度奧斯...

關(guān)鍵字: ck

在其推出年度“奧斯卡流行藝術(shù)!”活動(dòng)系列10周年之際,Shutterstock內(nèi)部創(chuàng)意團(tuán)隊(duì)立足其平臺(tái)逾4億創(chuàng)意資產(chǎn),創(chuàng)作原創(chuàng)波普藝術(shù)風(fēng)格作品...

關(guān)鍵字: ck

(全球TMT2022年3月23日訊)Super Micro Computer, Inc. (SMCI)?宣布推出擁有突破性性能的Supermicro高端服務(wù)器,將搭載采用AMD 3D V-Cache技術(shù)的第三代AMD...

關(guān)鍵字: AMD 處理器 ic

簡化客戶部署,為人工智能、機(jī)器學(xué)習(xí)和高性能計(jì)算提供極致的模塊化和定制選項(xiàng) 美國加州圣何塞2022...

關(guān)鍵字: CPU GPU ic

(全球TMT2022年3月23日訊)Super Micro Computer, Inc. (SMCI) 為宣布推出一項(xiàng)革命性技術(shù),可簡化大規(guī)模GPU部署,設(shè)計(jì)符合未來需求,甚至支持尚未公開的技術(shù)。此通用GPU...

關(guān)鍵字: CPU GPU ic

Linux閱碼場(chǎng)

174 篇文章

關(guān)注

發(fā)布文章

編輯精選

技術(shù)子站

關(guān)閉