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

            最新評論

            Linux操作系統(tǒng)中中斷上下文中的互斥

            在Linux系統(tǒng)中,有兩種不同的上下文:進程上下文、中斷上下文。
            在中斷中沒有進程上下文,而具有中斷上下文,因此在中斷上下文中不能發(fā)生睡眠,也就是不能發(fā)生進程切換。
            這就決定了在在中斷上下文中不能采用同步原語(信號量,管程、同步變量等)和長期互斥原語(這會導(dǎo)致進程睡眠), 而只能采用短期互斥原語(例如自旋鎖)。

            曾經(jīng),中斷處理程序并不具有自己的棧。相反,它們共享所中斷進程的內(nèi)核棧。內(nèi)核棧的大小是兩頁,具體地說,在32位體系結(jié)構(gòu)上是8KB,在64位體系結(jié)構(gòu)上是16KB.
            現(xiàn)在。中斷處理程序有了自己的棧,每個處理器一個,大小為一頁。這個棧就稱為中斷棧,盡管中斷棧的大小是原先共享棧的一半,但平均可用棧空間大得多,因為中斷處理
            程序把這一整頁占為己有。

            UP(單CPU系統(tǒng))上的中斷處理
            互斥
            如果一個中斷處理程序的代碼訪問或者更新了由非中斷的代碼(通常稱為基準(zhǔn)代碼)使用的同一數(shù)據(jù)結(jié)構(gòu),那么就會出現(xiàn)競爭條件。
            幸運的是,得到允許的以內(nèi)核態(tài)執(zhí)行的進程會臨時禁止中斷。因此,只要基準(zhǔn)代碼要更新一個與中斷處理程序共享的數(shù)據(jù)結(jié)構(gòu),那么就
            首先禁止中斷,執(zhí)行臨界段,然后再重新允許中斷。禁止和允許中斷的動作就實現(xiàn)了互斥。
            在采取中斷互斥時,必須使用函數(shù)顯示地把編碼寫入算法中。

            MP(多CPU系統(tǒng))上
            在MP系統(tǒng)上,中斷可以在任何處理器上出現(xiàn)。從最低限度上來說,每個進程會接收時鐘中斷,但也可能接收I/O中斷。在MP系統(tǒng)上,例程
            SPL(禁止中斷)所提供的保護并不充分,因為它們執(zhí)行影響執(zhí)行它們的處理器上的中斷優(yōu)先級。中斷可能會在另一個處理器上出現(xiàn),如果設(shè)備驅(qū)動程序
            正在別處運行,那么會造成一個競爭條件。因為中斷處理程序代表另一個進入內(nèi)核的入口點。

            當(dāng)基準(zhǔn)驅(qū)動程序代碼和中斷處理程序之間共享數(shù)據(jù)結(jié)構(gòu)時,UP可以通過屏蔽中斷來防止出現(xiàn)競爭條件的技術(shù),在多線程MP內(nèi)核中還不充分。
            臨界段要在一個處理器上執(zhí)行,執(zhí)行屏蔽中斷例程只會屏蔽在那個處理器上出現(xiàn)的中斷。如果在別的處理器上出現(xiàn)中斷,那么立即就會有
            兩個處理器同時訪問、而且可能更新臨界資源。既然這些臨界段需要短期互斥,那么可以使用自旋鎖來對數(shù)據(jù)進行保護。

            如果不考慮中斷處理程序和基準(zhǔn)代碼之間的互斥,則Linux中的中斷處理程序是無須重入的。當(dāng)一個給定的中斷處理程序正在執(zhí)行時,相應(yīng)的中斷線
            在所有處理器上都會被屏蔽掉,以防止同一中斷線上接收另一個新的中斷。通常情況下,所有的其他中斷都是打開的,所以這些不同中斷線上的其他中斷
            都能處理,但當(dāng)前中斷線總是被禁止的。由此可以看出,同一個中斷處理程序絕不會被同時調(diào)用以處理嵌套的中斷。這極大地簡化了中斷程序的編寫。

            posted on 2013-07-08 14:01 martin_yahoo 閱讀(3416) 評論(0)  編輯 收藏 引用


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            日本高清无卡码一区二区久久| 久久精品成人影院| 久久久亚洲欧洲日产国码二区| AV无码久久久久不卡网站下载 | 久久精品国产久精国产思思| 国产情侣久久久久aⅴ免费| Xx性欧美肥妇精品久久久久久 | 久久996热精品xxxx| 亚洲精品无码久久久久去q| 99久久成人国产精品免费| 国内精品久久国产| 国产高清美女一级a毛片久久w| 久久青青草视频| 国产精品日韩深夜福利久久 | 国产激情久久久久影院老熟女| 久久精品国产乱子伦| 久久久无码精品亚洲日韩京东传媒 | 国产精品久久成人影院| 中文字幕精品无码久久久久久3D日动漫| 亚洲香蕉网久久综合影视| 无码8090精品久久一区| 99久久综合国产精品二区| 97久久天天综合色天天综合色hd| 一本久久a久久精品综合香蕉| 久久久久综合中文字幕 | 久久夜色精品国产噜噜亚洲AV| 午夜精品久久久内射近拍高清| 国产精品久久久天天影视香蕉| 久久成人影院精品777| 东京热TOKYO综合久久精品| 性欧美丰满熟妇XXXX性久久久| 午夜精品久久久久9999高清| 99久久综合国产精品二区| 久久精品免费一区二区| 久久综合伊人77777| 久久久久无码精品国产不卡| 亚洲精品美女久久777777| 久久久久久国产精品无码超碰| 久久久噜噜噜久久中文福利| 久久婷婷国产综合精品| 国产精品久久久久久搜索|