0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

淺析硬中斷和軟中斷的區(qū)別

Q4MP_gh_c472c21 ? 來源:未知 ? 作者:胡薇 ? 2018-10-30 14:34 ? 次閱讀

從本質(zhì)上來講,中斷是一種電信號,當設(shè)備有某種事件發(fā)生時,它就會產(chǎn)生中斷,通過總線把電信號發(fā)送給中斷控制器。

如果中斷的線是激活的,中斷控制器就把電信號發(fā)送給處理器的某個特定引腳。處理器于是立即停止自己正在做的事,

跳到中斷處理程序的入口點,進行中斷處理。

硬中斷

由與系統(tǒng)相連的外設(shè)(比如網(wǎng)卡、硬盤)自動產(chǎn)生的。主要是用來通知操作系統(tǒng)系統(tǒng)外設(shè)狀態(tài)的變化。比如當網(wǎng)卡收到數(shù)據(jù)包的時候,就會發(fā)出一個中斷。我們通常所說的中斷指的是硬中斷(hardirq)。

硬中斷是由硬件產(chǎn)生的,比如,像磁盤,網(wǎng)卡,鍵盤,時鐘等。每個設(shè)備或設(shè)備集都有它自己的IRQ(中斷請求)?;贗RQ,CPU可以將相應(yīng)的請求分發(fā)到對應(yīng)的硬件驅(qū)動上(注:硬件驅(qū)動通常是內(nèi)核中的一個子程序,而不是一個獨立的進程)。

處理中斷的驅(qū)動是需要運行在CPU上的,因此,當中斷產(chǎn)生的時候,CPU會中斷當前正在運行的任務(wù),來處理中斷。在有多核心的系統(tǒng)上,一個中斷通常只能中斷一顆CPU(也有一種特殊的情況,就是在大型主機上是有硬件通道的,它可以在沒有主CPU的支持下,可以同時處理多個中斷。)。

硬中斷可以直接中斷CPU。它會引起內(nèi)核中相關(guān)的代碼被觸發(fā)。對于那些需要花費一些時間去處理的進程,中斷代碼本身也可以被其他的硬中斷中斷。

對于時鐘中斷,內(nèi)核調(diào)度代碼會將當前正在運行的進程掛起,從而讓其他的進程來運行。它的存在是為了讓調(diào)度代碼(或稱為調(diào)度器)可以調(diào)度多任務(wù)。

軟中斷

為了滿足實時系統(tǒng)的要求,中斷處理應(yīng)該是越快越好。linux為了實現(xiàn)這個特點,當中斷發(fā)生的時候,硬中斷處理那些短時間就可以完成的工作,而將那些處理事件比較長的工作,放到中斷之后來完成,也就是軟中斷(softirq)來完成。

軟中斷的處理非常像硬中斷。然而,它們僅僅是由當前正在運行的進程所產(chǎn)生的。

通常,軟中斷是一些對I/O的請求。這些請求會調(diào)用內(nèi)核中可以調(diào)度I/O發(fā)生的程序。對于某些設(shè)備,I/O請求需要被立即處理,而磁盤I/O請求通常可以排隊并且可以稍后處理。根據(jù)I/O模型的不同,進程或許會被掛起直到I/O完成,此時內(nèi)核調(diào)度器就會選擇另一個進程去運行。I/O可以在進程之間產(chǎn)生并且調(diào)度過程通常和磁盤I/O的方式是相同。

軟中斷僅與內(nèi)核相聯(lián)系。而內(nèi)核主要負責對需要運行的任何其他的進程進行調(diào)度。一些內(nèi)核允許設(shè)備驅(qū)動的一些部分存在于用戶空間,并且當需要的時候內(nèi)核也會調(diào)度這個進程去運行。

軟中斷并不會直接中斷CPU。也只有當前正在運行的代碼(或進程)才會產(chǎn)生軟中斷。這種中斷是一種需要內(nèi)核為正在運行的進程去做一些事情(通常為I/O)的請求。有一個特殊的軟中斷是Yield調(diào)用,它的作用是請求內(nèi)核調(diào)度器去查看是否有一些其他的進程可以運行。

中斷嵌套

Linux下硬中斷是可以嵌套的,但是沒有優(yōu)先級的概念,也就是說任何一個新的中斷都可以打斷正在執(zhí)行的中斷,但同種中斷除外。軟中斷不能嵌套,但相同類型的軟中斷可以在不同CPU上并行執(zhí)行。

軟中斷指令

int是軟中斷指令。

中斷向量表是中斷號和中斷處理函數(shù)地址的對應(yīng)表。

int n - 觸發(fā)軟中斷n。相應(yīng)的中斷處理函數(shù)的地址為:中斷向量表地址 + 4 * n。

硬中斷和軟中斷的區(qū)別

軟中斷是執(zhí)行中斷指令產(chǎn)生的,而硬中斷是由外設(shè)引發(fā)的。

硬中斷的中斷號是由中斷控制器提供的,軟中斷的中斷號由指令直接指出,無需使用中斷控制器。

硬中斷是可屏蔽的,軟中斷不可屏蔽。

硬中斷處理程序要確保它能快速地完成任務(wù),這樣程序執(zhí)行時才不會等待較長時間,稱為上半部。

軟中斷處理硬中斷未完成的工作,是一種推后執(zhí)行的機制,屬于下半部。

開關(guān)

(1) 硬中斷的開關(guān)

簡單禁止和激活當前處理器上的本地中斷:

local_irq_disable();

local_irq_enable();

保存本地中斷系統(tǒng)狀態(tài)下的禁止和激活:

unsigned long flags;

local_irq_save(flags);

local_irq_restore(flags);

(2) 軟中斷的開關(guān)

禁止下半部,如softirq、tasklet和workqueue等:

local_bh_disable();

local_bh_enable();

需要注意的是,禁止下半部時仍然可以被硬中斷搶占。

(3) 判斷中斷狀態(tài)

#define in_interrupt() (irq_count())// 是否處于中斷狀態(tài)(硬中斷或軟中斷)

#define in_irq()(hardirq_count()) // 是否處于硬中斷

#define in_softirq() (softirq_count()) // 是否處于軟中斷

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 總線
    +關(guān)注

    關(guān)注

    10

    文章

    2817

    瀏覽量

    87702
  • 中斷控制器
    +關(guān)注

    關(guān)注

    0

    文章

    59

    瀏覽量

    9411

原文標題:硬中斷與軟中斷是怎么回事?

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    NXP的ARM7帶ucos中中斷中斷響應(yīng)詳細分析

    NXP的ARM7帶ucos中中斷中斷響應(yīng)詳細分析一.帶UCOS系統(tǒng)的中斷響應(yīng)過程 11.
    發(fā)表于 12-02 17:32

    請問一下中斷的問題如何解決

    我想讓程序運行到某一行時產(chǎn)生一個中斷,是不是用中斷的方式及調(diào)用EXTI_GenerateSWInterrupt()這個函數(shù),還有什么其他的方法沒有。如果只用
    發(fā)表于 05-25 09:51

    什么是中斷以及中斷

    同步中斷,是指CPU內(nèi)部出現(xiàn)的中斷,即在CPU執(zhí)行特定指令時出現(xiàn)的非法情況,因此只有在一條指令執(zhí)行后才會發(fā)出中斷,不可能在指令執(zhí)行期間發(fā)生異常。
    發(fā)表于 01-10 07:26

    面向嵌入式Linux系統(tǒng)的中斷設(shè)計與實現(xiàn)

    本文在分析標準Linux 內(nèi)核的中斷機制的演化以及實現(xiàn)原理的基礎(chǔ)上,提出并實現(xiàn)了一個面前嵌入式Linux 系統(tǒng)的中斷技術(shù)。該技術(shù)為嵌入式系統(tǒng)開發(fā)提供一個統(tǒng)一的
    發(fā)表于 08-03 11:20 ?16次下載

    液晶屏和屏的區(qū)別

    液晶屏和屏的區(qū)別:現(xiàn)在的液晶電視市場中流傳著 “屏”和“屏”的說法,通常來說,屏是指I
    發(fā)表于 07-16 11:48 ?6415次閱讀
    液晶<b class='flag-5'>硬</b>屏和<b class='flag-5'>軟</b>屏的<b class='flag-5'>區(qū)別</b>

    中斷程序設(shè)計

    實 驗 五  中斷程序設(shè)計 一、實驗?zāi)康?nbsp;   通過對中斷程序的編寫和調(diào)試,掌握IBM-PC系列機的
    發(fā)表于 09-28 23:26 ?2658次閱讀
    <b class='flag-5'>軟</b><b class='flag-5'>中斷</b>程序設(shè)計

    壓縮與壓縮的區(qū)別

    壓縮與壓縮的區(qū)別 目前市面上流行的硬盤錄象卡主要有壓縮硬盤錄象卡與壓縮硬盤錄象卡兩大類。 1)
    發(fā)表于 12-29 14:00 ?2035次閱讀

    Linux 2.4.x內(nèi)核中斷機制

    情況下,中斷和信號有些類似,同時,中斷又是和中斷相對應(yīng)的,
    發(fā)表于 11-02 11:01 ?0次下載

    探究中斷中斷的原理和區(qū)別

    從本質(zhì)上來講,中斷是一種電信號,當設(shè)備有某種事件發(fā)生時,它就會產(chǎn)生中斷,通過總線把電信號發(fā)送給中斷控制器。
    的頭像 發(fā)表于 01-17 09:38 ?1.1w次閱讀
    探究<b class='flag-5'>硬</b><b class='flag-5'>中斷</b>和<b class='flag-5'>軟</b><b class='flag-5'>中斷</b>的原理和<b class='flag-5'>區(qū)別</b>

    你了解中斷中斷區(qū)別?

    從本質(zhì)上來講,中斷是一種電信號,當設(shè)備有某種事件發(fā)生時,它就會產(chǎn)生中斷,通過總線把電信號發(fā)送給中斷控制器。
    發(fā)表于 05-05 11:48 ?1.8w次閱讀

    微機原理——8086中斷類型以及中斷向量表、中斷響應(yīng)、中斷返回

    這里寫目錄標題先驗知識回顧控制寄存器回顧1、8086中斷類型1、外部可屏蔽中斷2、外部不可屏蔽中斷3、除法錯中斷4、單步中斷5、斷點
    發(fā)表于 11-24 16:51 ?16次下載
    微機原理——8086<b class='flag-5'>中斷</b>類型以及<b class='flag-5'>中斷</b>向量表、<b class='flag-5'>中斷</b>響應(yīng)、<b class='flag-5'>中斷</b>返回

    中斷中斷是怎么回事?

    立即停止自己正在做的事, 跳到中斷處理程序的入口點,進行中斷處理。 中斷 由與系統(tǒng)相連的外設(shè)(比如網(wǎng)卡、硬盤)自動產(chǎn)生的。主要是用來通知操作系統(tǒng)系統(tǒng)外設(shè)狀態(tài)的變化。比如當網(wǎng)卡收到數(shù)
    發(fā)表于 02-10 12:02 ?0次下載
    <b class='flag-5'>硬</b><b class='flag-5'>中斷</b>與<b class='flag-5'>軟</b><b class='flag-5'>中斷</b>是怎么回事?

    中斷中斷介紹

    ? 中斷是由外部事件引起的因此具有隨機性和突發(fā)性;中斷是否可以嵌套的,是否有優(yōu)先級(由硬件設(shè)計體系決定)。 ?
    的頭像 發(fā)表于 11-07 17:02 ?740次閱讀

    什么是LInux 操作系統(tǒng)中斷

    進程來持有CPU進行需要的操作! 有了中斷之后,提升了操作系統(tǒng)的性能!可以異步并行處理很多任務(wù)! 中斷(80中斷) 由CPU產(chǎn)生的;CPU檢查到程序代碼段發(fā)生異常會切換到內(nèi)核態(tài);
    的頭像 發(fā)表于 11-10 11:29 ?485次閱讀
    什么是LInux 操作系統(tǒng)<b class='flag-5'>中斷</b>

    LInux 操作系統(tǒng)中斷介紹

    進程來持有CPU進行需要的操作! 有了中斷之后,提升了操作系統(tǒng)的性能!可以異步并行處理很多任務(wù)! 中斷(80中斷) 由CPU產(chǎn)生的;CPU檢查到程序代碼段發(fā)生異常會切換到內(nèi)核態(tài);
    的頭像 發(fā)表于 11-13 11:36 ?750次閱讀
    LInux 操作系統(tǒng)<b class='flag-5'>中斷</b>介紹