<dfn id="is4kg"></dfn>
  • <ul id="is4kg"></ul>
  • <abbr id="is4kg"></abbr>
  • <ul id="is4kg"></ul>
    <bdo id="is4kg"></bdo>
    以文本方式查看主題

    -  曙海教育集團論壇  (http://www.hufushizhe.com/bbs/index.asp)
    --  Linux驅動開發  (http://www.hufushizhe.com/bbs/list.asp?boardid=33)
    ----  Linux驅動開發必看詳解神秘內核  (http://www.hufushizhe.com/bbs/dispbbs.asp?boardid=33&id=1705)

    --  作者:wangxinxin
    --  發布時間:2010-11-24 9:22:50
    --  Linux驅動開發必看詳解神秘內核

    相關閱讀:

    Fedora下內核編譯
    谷歌Android被Linux內核除名
    Linux內核十個版本性能對比
      舊的信號量接口

      互斥體接口代替了舊的信號量接口(semaphore);コ怏w接口是從-rt樹演化而來的,在2.6.16內核中被融入主線內核。

      盡管如此,但是舊的信號量仍然在內核和驅動程序中廣泛使用。信號量接口的基本用法如下:

    #include <asm/semaphore.h>  /* Architecture dependent header */

    /* Statically declare a semaphore. To dynamically
       create a semaphore, use init_MUTEX() */
    static DECLARE_MUTEX(mysem);

    down(&mysem);    /* Acquire the semaphore */

    /* ... Critical Section code ... */

    up(&mysem);      /* Release the semaphore */

      1. 案例1:進程上下文,單CPU,非搶占內核

      這種情況最為簡單,不需要加鎖,因此不再贅述。

      2. 案例2:進程和中斷上下文,單CPU,非搶占內核

      在這種情況下,為了保護臨界區,僅僅需要禁止中斷。如圖2-4所示,假定進程上下文的執行單元A、B以及中斷上下文的執行單元C都企圖進入相同的臨界區。

     

    由于執行單元C總是在中斷上下文執行,它會優先于執行單元A和B,因此,它不用擔心保護的問題。執行單元A和B也不必關心彼此會被互相打斷,因為內核是非搶占的。因此,執行單元A和B僅僅需要擔心C會在它們進入臨界區的時候強行進入。為了實現此目的,它們會在進入臨界區之前禁止中斷:

    Point A:   
      local_irq_disable();  /* Disable Interrupts in local CPU */
      /* ... Critical Section ...  */
      local_irq_enable();   /* Enable Interrupts in local CPU */

       但是,如果當執行到Point A的時候已經被禁止,local_irq_enable()將產生副作用,它會重新使能中斷,而不是恢復之前的中斷狀態?梢赃@樣修復它:

    unsigned long flags;

    Point A:
      local_irq_save(flags);     /* Disable Interrupts */
      /* ... Critical Section ... */
      local_irq_restore(flags);  /* Restore state to what it was at Point A */

      不論Point A的中斷處于什么狀態,上述代碼都將正確執行。

    相關閱讀:

    Fedora下內核編譯
    谷歌Android被Linux內核除名
    Linux內核十個版本性能對比
      3. 案例3:進程和中斷上下文,單CPU,搶占內核

      如果內核使能了搶占,僅僅禁止中斷將無法確保對臨界區的保護,因為另一個處于進程上下文的執行單元可能會進入臨界區。重新回到圖2-4,現在,除了C以外,執行單元A和B必須提防彼此。顯而易見,解決該問題的方法是在進入臨界區之前禁止內核搶占、中斷,并在退出臨界區的時候恢復內核搶占和中斷。因此,執行單元A和B使用了自旋鎖API的irq變體:

    unsigned long flags;

    Point A:
      /* Save interrupt state.
       * Disable interrupts - this implicitly disables preemption */
      spin_lock_irqsave(&mylock, flags);

      /* ... Critical Section ... */

      /* Restore interrupt state to what it was at Point A */
      spin_unlock_irqrestore(&mylock, flags);

      我們不需要在最后顯示地恢復Point A的搶占狀態,因為內核自身會通過一個名叫搶占計數器的變量維護它。在搶占被禁止時(通過調用preempt_disable()),計數器值會增加;在搶占被使能時(通過調用preempt_enable()),計數器值會減少。只有在計數器值為0的時候,搶占才發揮作用。

      4. 案例4:進程和中斷上下文,SMP機器,搶占內核

      現在假設臨界區執行于SMP機器上,而且你的內核配置了CONFIG_SMP和CONFIG_PREEMPT。

      到目前為止討論的場景中,自旋鎖原語發揮的作用僅限于使能和禁止搶占和中斷,時間的鎖功能并未被完全編譯進來。在SMP機器內,鎖邏輯被編譯進來,而且自旋鎖原語確保了SMP安全性。SMP使能的含義如下:

    unsigned long flags;

    Point A:
      /*
        - Save interrupt state on the local CPU
        - Disable interrupts on the local CPU. This implicitly disables preemption.
        - Lock the section to regulate access by other CPUs
       */
      spin_lock_irqsave(&mylock, flags);

      /* ... Critical Section ... */

      /*
        - Restore interrupt state and preemption to what it
          was at Point A for the local CPU
        - Release the lock
       */
      spin_unlock_irqrestore(&mylock, flags);

      在SMP系統上,獲取自旋鎖時,僅僅本CPU上的中斷被禁止。因此,一個進程上下文的執行單元(圖2-4中的執行單元A)在一個CPU上運行的同時,一個中斷處理函數(圖2-4中的執行單元C)可能運行在另一個CPU上。非本CPU上的中斷處理函數必須自旋等待本CPU上的進程上下文代碼退出臨界區。中斷上下文需要調用spin_lock()/spin_unlock():

    spin_lock(&mylock);

    /* ... Critical Section ... */

    spin_unlock(&mylock);

      除了有irq變體以外,自旋鎖也有底半部(BH)變體。在鎖被獲取的時候,spin_lock_bh()會禁止底半部,而spin_unlock_bh()則會在鎖被釋放時重新使能底半部。我們將在第4章討論底半部。

      -rt樹

      實時(-rt)樹,也被稱作CONFIG_PREEMPT_RT補丁集,實現了內核中一些針對低延時的修改。該補丁集可以從www.kernel.org/pub/linux/kernel/projects/rt下載,它允許內核的大部分位置可被搶占,但是用自旋鎖代替了一些互斥體。它也合并了一些高精度的定時器。數個-rt功能已經被融入了主線內核。詳細的文檔見http://rt.wiki.kernel.org/。

      為了提高性能,內核也定義了一些針對特定環境的特定的鎖原語。使能適用于代碼執行場景的互斥機制將使代碼更高效。下面來看一下這些特定的互斥機制。


    主站蜘蛛池模板: 韩国成人在线视频| 亚洲av成人无码久久精品老人| 91高清完整版在线观看| 无码天堂亚洲国产AV| 亚洲欧美国产免费综合视频| 精品久久久久久无码中文字幕| 国产欧美日韩视频在线观看一区二区| 一本大道香蕉在线影院| 无遮挡韩国成人羞羞漫画网站| 亚洲成a人片在线观看中文app | 亚洲精品美女久久久久| 精品国产一区二区三区久| 国产成人啪精品| 98精品国产综合久久| 天天操天天射天天操| 久久久久久久久国产| 日韩精品一区二区三区在线观看 | 欧美一级美片在线观看免费| 免费日产乱码卡一卡2卡三卡四| 老子影院午夜伦不卡| 国产毛片久久久久久国产毛片| Channel| 好大好深好猛好爽视频免费| 久久国产加勒比精品无码| 最好看的免费观看视频 | 亚洲欧美日韩另类精品一区二区三区| 男女一边摸一边做爽爽| 国产一卡二卡≡卡四卡无人区| 香蕉久久久久久AV成人 | 永久免费视频v片www| 午夜无遮挡羞羞漫画免费| 美女被到爽羞羞漫画| 国产在线无码精品无码| 1000部精品久久久久久久久| 国产精品视频一区二区三区四| sihu永久在线播放地址| 女人国产香蕉久久精品| 中文字幕AAV| 性芭蕾k8经典| 久久久www成人免费精品| 日本a中文字幕|