欧美日韩一区二区高清,久久视频这里只有精品,超黄网站在线观看,成人av影院在线观看


曙海教育集團論壇Linux專區(qū)Linux驅動開發(fā) → Linux驅動開發(fā)必看詳解神秘內核


  共有9758人關注過本帖樹形打印

主題:Linux驅動開發(fā)必看詳解神秘內核

美女呀,離線,留言給我吧!
wangxinxin
  1樓 個性首頁 | 博客 | 信息 | 搜索 | 郵箱 | 主頁 | UC


加好友 發(fā)短信
等級:青蜂俠 帖子:1393 積分:14038 威望:0 精華:0 注冊:2010-11-12 11:08:23
Linux驅動開發(fā)必看詳解神秘內核  發(fā)帖心情 Post By:2010-11-24 9:22:50

相關閱讀:

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

  互斥體接口代替了舊的信號量接口(semaphore)。互斥體接口是從-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,非搶占內核

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

 

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

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

   但是,如果當執(zhí)行到Point A的時候已經(jīng)被禁止,local_irq_enable()將產生副作用,它會重新使能中斷,而不是恢復之前的中斷狀態(tài)。可以這樣修復它:

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的中斷處于什么狀態(tài),上述代碼都將正確執(zhí)行。

相關閱讀:

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

  如果內核使能了搶占,僅僅禁止中斷將無法確保對臨界區(qū)的保護,因為另一個處于進程上下文的執(zhí)行單元可能會進入臨界區(qū)。重新回到圖2-4,現(xiàn)在,除了C以外,執(zhí)行單元A和B必須提防彼此。顯而易見,解決該問題的方法是在進入臨界區(qū)之前禁止內核搶占、中斷,并在退出臨界區(qū)的時候恢復內核搶占和中斷。因此,執(zhí)行單元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的搶占狀態(tài),因為內核自身會通過一個名叫搶占計數(shù)器的變量維護它。在搶占被禁止時(通過調用preempt_disable()),計數(shù)器值會增加;在搶占被使能時(通過調用preempt_enable()),計數(shù)器值會減少。只有在計數(shù)器值為0的時候,搶占才發(fā)揮作用。

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

  現(xiàn)在假設臨界區(qū)執(zhí)行于SMP機器上,而且你的內核配置了CONFIG_SMP和CONFIG_PREEMPT。

  到目前為止討論的場景中,自旋鎖原語發(fā)揮的作用僅限于使能和禁止搶占和中斷,時間的鎖功能并未被完全編譯進來。在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系統(tǒng)上,獲取自旋鎖時,僅僅本CPU上的中斷被禁止。因此,一個進程上下文的執(zhí)行單元(圖2-4中的執(zhí)行單元A)在一個CPU上運行的同時,一個中斷處理函數(shù)(圖2-4中的執(zhí)行單元C)可能運行在另一個CPU上。非本CPU上的中斷處理函數(shù)必須自旋等待本CPU上的進程上下文代碼退出臨界區(qū)。中斷上下文需要調用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補丁集,實現(xiàn)了內核中一些針對低延時的修改。該補丁集可以從www.kernel.org/pub/linux/kernel/projects/rt下載,它允許內核的大部分位置可被搶占,但是用自旋鎖代替了一些互斥體。它也合并了一些高精度的定時器。數(shù)個-rt功能已經(jīng)被融入了主線內核。詳細的文檔見http://rt.wiki.kernel.org/。

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


支持(0中立(0反對(0單帖管理 | 引用 | 回復 回到頂部

返回版面帖子列表

Linux驅動開發(fā)必看詳解神秘內核








簽名
主站蜘蛛池模板: 阿城市| 玉门市| 孝义市| 达尔| 莫力| 汾阳市| 湘乡市| 内丘县| 静海县| 富川| 临高县| 肃宁县| 巴青县| 苏州市| 南投市| 鞍山市| 翼城县| 咸阳市| 阳山县| 屯留县| 左权县| 营口市| 花莲市| 永年县| 道真| 石阡县| 兴化市| 自治县| 堆龙德庆县| 如皋市| 大埔区| 安平县| 通山县| 普兰县| 邯郸市| 驻马店市| 观塘区| 睢宁县| 米泉市| 巍山| 宁津县|