• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            Dict.CN 在線詞典, 英語學(xué)習(xí), 在線翻譯

            學(xué)海苦作舟,書山勤為徑

            留下點(diǎn)回憶

            常用鏈接

            統(tǒng)計(jì)

            積分與排名

            Denoise

            English study

            Web技術(shù)

            數(shù)據(jù)壓縮

            一些連接

            最新評(píng)論

            操作系統(tǒng)的鎖如何實(shí)現(xiàn)?

            最近在看操作系統(tǒng)方面的東西,然后看到一些同步的要求,比如鎖,于是就想想它們是如何實(shí)現(xiàn)的?
            比如應(yīng)用層編碼是調(diào)用EnterCriticalSection之類的,以前就想到這里,剩下的工作就由OS去管理了,反正它能實(shí)現(xiàn);不過今天一想,它能有什么辦法呢?如果是軟件它貌似也沒有什么比應(yīng)用層強(qiáng)的方法;于是有點(diǎn)好奇,就查閱一些資料來研究一下究竟。
            一般的鎖實(shí)現(xiàn)都是通過處理器支持的原子操作來完成的,這些原子操作是不可分割的,不能被中斷。在單處理器的CPU上,單條指令可以認(rèn)為是原子操作,因?yàn)橹袛嘀荒馨l(fā)生在指令之間。但對(duì)于多處理器結(jié)構(gòu)就不一樣了,這個(gè)時(shí)候需要一些硬件的支持來保證,這嚴(yán)重依賴于不同的硬件實(shí)現(xiàn)。
            例如:x86平臺(tái)上,CPU執(zhí)行期間會(huì)對(duì)總線加鎖的手段,也就是CPU芯片上有一個(gè)HLOCK Pin,可以通過發(fā)送指令來操作,將#HLOCK pin電位拉低,并持續(xù)到這條指令執(zhí)行完畢,從而將總線鎖定,因此同一個(gè)總線的其他CPU就不能通過總線來訪存了,因此保證了這條指令在多處理器環(huán)境下的原子性。

            最開始的時(shí)候這些功能是用于CPU測(cè)試使用,但最后被操作系統(tǒng)實(shí)現(xiàn)而封裝成各種功能:關(guān)鍵代碼段、信號(hào)量等。因此在應(yīng)用層使用來說脫離了與不同硬件交互的過程。

            這里看一個(gè)X86平臺(tái)windows上的一個(gè)關(guān)鍵代碼段實(shí)現(xiàn)。
            原來代碼如下:
             1int _tmain(int argc, _TCHAR* argv[])
             2{
             3    CRITICAL_SECTION cs;
             4    InitializeCriticalSection(&cs);
             5
             6    EnterCriticalSection(&cs);
             7    int i =0;
             8    i++;
             9    LeaveCriticalSection(&cs);
            10    return 0;
            11}
            反匯編到EnterCriticalSection,可以看到如下代碼:
             177BD69D0  push        ebp  
             277BD69D1  mov         ebp,esp 
             377BD69D3  sub         esp,0Ch 
             477BD69D6  push        esi  
             577BD69D7  push        edi  
             677BD69D8  mov         edi,dword ptr [ebp+8
             777BD69DB  lea         esi,[edi+4
             877BD69DE  mov         eax,esi 
             977BD69E0  lock btr    dword ptr [eax],0 
            1077BD69E5  jae         77BE5F4B 
            1177BD69EB  mov         eax,dword ptr fs:[00000018h] 

            這里特別需要注意: lock btr dword ptr[eax], 0

            lock是一個(gè)指令前綴,Intel的手冊(cè)上對(duì)其的解釋是:

             

            Causes the processor's LOCK# signal to be asserted during execution of the accompanying instruction (turns the instruction into an atomic instruction). In a multiprocessor environment, the LOCK# signal insures that the processor has exclusive use of any shared memory while the signal is asserted.

             

            也就是說lock會(huì)使緊跟在其后面的指令變成 atomic instruction。暫時(shí)的鎖一下總線,指令執(zhí)行完了,總線就解鎖了.

            從上面可以看到其驗(yàn)證了前面所說;到這里就算是理解了操作系統(tǒng)是如何實(shí)現(xiàn)鎖機(jī)制的。





            posted on 2011-05-31 23:36 笨笨 閱讀(4413) 評(píng)論(3)  編輯 收藏 引用 所屬分類: Linux

            評(píng)論

            # re: 操作系統(tǒng)的鎖如何實(shí)現(xiàn)? 2011-06-01 10:00 ooseven

            樓主很有研究精神,知其然,知其所以然,佩服!  回復(fù)  更多評(píng)論   

            # re: 操作系統(tǒng)的鎖如何實(shí)現(xiàn)? 2011-06-01 13:31 笨笨

            @ooseven
            謝謝,最近時(shí)間比較多,就看一些基礎(chǔ)知識(shí),怕自己忘記了。。。  回復(fù)  更多評(píng)論   

            # re: 操作系統(tǒng)的鎖如何實(shí)現(xiàn)? 2011-06-20 14:13 jejer

            http://www.cnblogs.com/hustcat/archive/2009/09/29/1576535.html 看了這篇文章 最后還是要跳到內(nèi)核去wait吧?  回復(fù)  更多評(píng)論   

            奇米影视7777久久精品人人爽| 久久精品亚洲福利| 一本色道久久综合亚洲精品| 亚洲AV日韩AV天堂久久| 久久久无码精品亚洲日韩蜜臀浪潮| 国产V综合V亚洲欧美久久| 久久久久久亚洲精品不卡 | 国产一久久香蕉国产线看观看| 国产精品久久久久影院色| 久久免费视频6| 精品久久久久久久久中文字幕| 亚洲日本va午夜中文字幕久久| 久久九九精品99国产精品| 亚洲日韩欧美一区久久久久我 | 亚洲国产精品无码久久青草| 国内精品久久久久久99蜜桃| 亚洲人成网站999久久久综合 | 一本大道加勒比久久综合| 香蕉99久久国产综合精品宅男自 | 国产激情久久久久影院老熟女免费| 午夜精品久久久久久影视riav| 免费观看久久精彩视频| 亚洲综合伊人久久大杳蕉| 少妇久久久久久被弄到高潮| 久久99国产综合精品女同| 久久久久亚洲AV片无码下载蜜桃| 韩国无遮挡三级久久| 午夜精品久久久久久毛片| 欧美成a人片免费看久久| 国产精品热久久毛片| 91久久婷婷国产综合精品青草| 色偷偷偷久久伊人大杳蕉| 国产精品一区二区久久精品涩爱| 久久久国产精品| 久久精品无码一区二区三区免费| 国产精品99久久久久久www| 久久精品男人影院| 久久精品综合一区二区三区| 久久久久人妻精品一区二区三区| 精品久久久无码21p发布| 亚洲AV日韩AV天堂久久|