• <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>

            martin

            thinking

            常用鏈接

            統(tǒng)計

            software

            最新評論

            MP操作系統(tǒng)內(nèi)核中自旋鎖(spinlock)的實現(xiàn)

            在多CPU系統(tǒng),即MP系統(tǒng)中,存在總線仲裁。

            1. 原子操作
            從CPU或者I/O設(shè)備到主存儲器的單次讀或者寫操作為原子操作。
            這樣的操作一旦開始,就不能被系統(tǒng)上來自CPU或者I/O設(shè)備的任何其他存儲操作所中斷,或者受到他們的干擾。

            原子變量

            2. 自旋鎖 (自旋鎖用于短期互斥)
            自旋鎖得名于這樣一個事實,一個進(jìn)程在等候另一個進(jìn)程正在使用的鎖時會處于忙等待(busy-wait,在一個循環(huán)中自旋)狀態(tài)。
            typedef int lock_t;
            void initlock( volatile lock_t * lock_status)
            {
               *lock_status = 0;
            }

            int
            test_and_set(volatile int *addr)
            {
                 int old_value;
                 old_value = swap_atomic(addr, 1);
                 if (old_value == 0)
                      return 0;
                 return 1;
            }

            void lock(volatile lock_t *lock_status)
            {
                while (test_and_set( lock_status) == 1)            //被鎖定時,進(jìn)程在此自旋。
                   ;
             }
            // test_and_set 如果前面的狀態(tài)不為0就返回1,否則返回0.
            //如果鎖的狀態(tài)已經(jīng)是1(鎖已經(jīng)被占用),那么test_and_set函數(shù)返回1,并且處理器在循環(huán)中自旋,直到該鎖被釋放為止。只要把鎖的狀態(tài)設(shè)置為0,就可以釋放鎖了。

            void
            unlock(volatile lock_t * lock_status)
            {
               *lock_status =0;
            }

            減少對鎖的爭用可以采用兩種辦法:
            第一、內(nèi)核針對不同的臨界資源使用不同的自旋鎖,防止處理器在沒有競爭條件威脅的時候被另一個處理器掛起。
            第二、增強lock和unlock函數(shù),在上鎖的時候屏蔽中斷。

            posted on 2013-06-08 17:04 martin_yahoo 閱讀(1769) 評論(1)  編輯 收藏 引用

            評論

            # re: MP操作系統(tǒng)內(nèi)核中自旋鎖(spinlock)的實現(xiàn)[未登錄] 2013-06-15 09:01 Korall

            減少鎖的爭用 兩種辦法,第二種是因噎廢食啊。第一種辦法遵循的是小粒度鎖的原則,能達(dá)到真正的目標(biāo)  回復(fù)  更多評論   

            久久久久久久国产免费看| 国产精品免费久久久久影院| 亚洲伊人久久精品影院| 少妇高潮惨叫久久久久久| 69久久夜色精品国产69| 久久亚洲电影| 久久久久国产精品熟女影院| 亚洲一本综合久久| 久久精品国产第一区二区三区| 国产99久久久国产精免费| 人妻精品久久无码区| 久久综合色之久久综合| 久久精品无码午夜福利理论片| 色综合合久久天天给综看| 中文精品久久久久国产网址| 性欧美丰满熟妇XXXX性久久久| 很黄很污的网站久久mimi色| 久久99精品久久只有精品| 久久热这里只有精品在线观看| 国产L精品国产亚洲区久久| 久久亚洲精品人成综合网| 青青草原综合久久大伊人| 久久久青草青青国产亚洲免观| 久久国产精品久久| 精品久久久久久久无码| 久久精品aⅴ无码中文字字幕不卡 久久精品成人欧美大片 | 91精品国产91久久| 久久人人爽人人爽人人片AV不| 久久这里只有精品首页| 亚洲精品综合久久| 伊人色综合九久久天天蜜桃 | 97精品依人久久久大香线蕉97| 久久久精品波多野结衣| 久久精品国产精品亚洲人人| 国产精品女同一区二区久久| 97精品伊人久久久大香线蕉| 精品久久久久久国产免费了| 一极黄色视频久久网站| 久久久无码精品亚洲日韩蜜臀浪潮| 国产精品久久新婚兰兰| 久久精品亚洲AV久久久无码|