青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

面對現實,超越自己
逆水行舟,不進則退
posts - 269,comments - 32,trackbacks - 0


 看了《深入理解linux內核》的中斷與異常,簡單總結了下,如果有錯誤,望指正!

一 什么是中斷和異常

  異常又叫同步中斷,是當指令執行時由cpu控制單元產生的,之所以稱之為異常,是因為只有在一條指令結束之后才發出中斷(程序執行異常或者系統調用)。

  中斷又叫異步中斷,是由其他硬件設備依照cpu時鐘信號隨機產生的。

二 高級可編程中斷控制器

APIC

  每個CPU都有一個本地的APIC,通過IIC bus鏈接到一個I/O APIC,這個I/O APIC負責處理外部IRQS,分發IRQS給本地APIC。

三 中斷與異常處理程序嵌套執行

  中斷處理程序允許被另一個中斷處理程序”中斷“,從而引起內核控制路徑嵌套執行。但是中斷處理程序是不允許發生阻塞,即任務切換的

  中斷可以搶占異常處理程序,但異常處理程序不會搶占中斷。因為中斷處理程序必定處于內核態,如果發生異常,那只能是BUG了,也就是說內核控制路徑中異常處理程序不會超過一個。

四 Linux中斷描述符

  Intel把中斷描述符分三類:任務門、中斷門、陷阱門,而Linux則分成五類:

  1. 中斷門:Intel的中斷門,DPL = 0,描述中斷處理程序,通過set_intr_gate宏設置
  2. 系統門:Intel的陷阱門,DPL = 3,用于系統調用,通過set_system_gate宏設置
  3. 系統中斷門:Intel的中斷門,DPL = 3,用于向量3的異常處理,通過set_system_intr_gate宏設置
  4. 陷阱門:Intel陷阱門,DPL = 0,大部分的異常處理,通過set_trap_gate宏設置
  5. 任務門:Intel任務門,DPL = 0,對”Double fault“異常處理,通過set_task_gate宏設置

五 異常處理

  當cpu產生異常時,會自動根據產生的異常編號在IDT中找對應的異常處理程序,異常處理程序保存大多數寄存器的值,調用異常處理的高級C函數處理該異常,然后通過調用ret_from_exception從異常處理程序退出。

六 中斷處理

  I/O中斷處理程序執行的四個基本過程:

  1. 在內核態堆棧中保存IRQ的值和寄存器的內容
  2. 給正在為IRQ線服務的PIC發送一個應答,這將允許該PIC進一步發中斷
  3. 執行共享該IRQ的所有設備的中斷服務例程(ISR)

七 IRQ數據結構

IRQ數據結構

  hw_irq_controller是對PIC進程控制的一些函數,包括應答PIC什么的。action指向的是一個irqaction鏈,每個irqaction描述一個設備的服務例程。irq_desc_t中的state字段保證了同一時刻只有一個設備會擁有該IRQ,正在處理該IRQ的CPU會禁用這條IRQ(本地),其它cpu還是可以接受該IRQ的請求,不過由于此時state的狀態為IRQ_INPROGRESS,所以新的IRQ請求會在其它的CPU上應答,但不會處理,也就是該新的IRQ處理會被延遲到處理同一個IRQ的前面一個CPU上執行。能這樣做是因為IRQ的數據結構是所有CPU所共享的

 

八 多種類型的內核棧

  如果編譯內核設置內核棧為8k,那么進程的內核棧被用于所有類型的內核控制路徑。如果內核棧為4k,則內核使用3種類型的內核棧:異常棧,用于處理異常,每個進程一個;硬中斷棧,用于處理中斷,每個cpu一個;軟中斷棧,用于出來延遲函數,每個cpu一個

九 軟中斷

1 為什么要引進軟中斷機制,用前面的中斷機制不就可以了嗎(老版本的linux就沒有軟中斷機制)?

  從前面的中斷處理中可以看出,一個中斷處理程序的幾個中斷服務例程(每個設備一個)是串行執行的,如果某個處理例程執行的時間比較長,而后面的例程又很緊急,那么會導致這個緊急的例程匯編延遲比較久的時間。所以如果能把一些服務例程中不是很緊急但又花費比較長的操作延遲到執行完該IRQ上所有中斷服務例程之后執行,那么一些緊急的,花費時間短(一般緊急的操作所需的時間都是比較短的)的例程就可以得到快速的響應。還有就是對于某個設備的中斷服務例程,如果它的服務例程服務時間過長,cpu在執行該服務例程時是會中斷本地cpu對該設備的中斷或者整個本地中斷,這樣會導致很多中斷會得不到快速的響應。

2 軟中斷使用的關鍵數據結構

  softirq_vec數組,每個數組元素類型為softirq_action,該數組總共有32個元素,目前只用了前面六個。softirq_action數據結構包含兩個字段:指向軟中斷處理函數的action指針和指向軟中斷函數需要的通用數據結構的data指針,這是cpu共享的

  每個進程描述的thread_info字段中的preempt_count字段,該字段被編碼來表示三個不同的計數器和一個標志。0-7位表示是否允許搶占內核,8-15表示是否正在處理軟中斷,16-27表示硬件中斷控制路徑嵌套數,28為是PREEMPT_ACTIVE標志。每個進程有一個

  另一個是每個cpu都有的32位掩碼,存放在irq_cpustat_t數據結構中的__softirq_pending字段,32位,每一位表示softirq_vec數組中的對應的軟中斷函數是否已激活。irq_cpustat_t存放在irq_stat數組中,每個cpu對于數組中的一個irq_cpustat_t。每個cpu一個

 

3 軟中斷可延遲函數的四個操作

  • 初始化,定義一個新的可延遲函數,并加入到softirq_vec數組中,所有cpu共享該softirq_vec
  • 激活,標記一個可延遲函數為”掛起“,通過前面描述的__softirq_pending字段。
  • 屏蔽,有選擇地屏蔽一個可延遲函數,即使它被激活。它是通過前面的preempt_count字段或者關閉本地中斷(延遲函數一般是通過中斷處理程序激活的,如果沒有中斷處理程序執行,自然也就不會有延遲函數的激活)來實現的。
  • 執行,執行一個掛起的可延遲函數和同類型的其它掛起的可延遲函數。通過do_softirq實現。

  激活和執行可延遲函數必須要在同一個cpu上,從前面激活和執行可以看出這一點。因為__softirq_pending是每個cpu一個,所有在特定cpu激活的延遲函數,只有在該cpu上的__softirq_pending標記激活,而其它cpu是不知道該函數被激活的,也就不會去執行該函數了

4 linux現有的六種軟中斷

  處理高級優先級的tasklet軟中斷HI_SOFTIRQ,在softirq_vec數組的下標為0;和時鐘中斷關聯的tasklet軟中斷TIMER_SOFTIRQ,在softirq_vec數組的下標為1;把數據包傳送到網卡軟中斷NET_TX_SOFTIRQ,在softirq_vec數組的下標為2;從網卡接收數據包的軟中斷NET_RX_SOFTIRQ,在softirq_vec數組的下標為3;SCSI命令的后天中斷處理的軟中斷SCSI_SOFTIRQ,在softirq_vec數組的下標為4;處理常規tasklet軟中斷TASKLET_SOFTIRQ,在softirq_vec數組的下標為5;它們的優先級是從高到低的。

5 檢查是否有軟中斷掛起(也叫激活)的時機

  • 內核調用local_bh_enable激活本地軟中斷
  • smp_apic_timer_interrupt處理完本地定時中斷
  • cpu處理CALL_FUNCTION_VECTOR中斷處理
  • 當一個特殊的ksoftirq/n內核線程被喚醒。

  ksoftirq/n內核線程是專門用來處理激活的軟中斷的,每個cpu有一個

十 tasklet

  tasklet是在軟中斷的基礎上實現的。正如前面說的linux現有的六種軟中斷,其中HI_SOFTIRQ和TASKLET_SOFTIRQ軟中斷就是tasklet。

  對于每種tasklet(HI_SOFTIRQ和TASKLET_SOFTIRQ),每個cpu都有一個tasklet_head類型來描述這種tasklet。tasklet_head類型指向了一個由tasklet類型組成的鏈表,而每個tasklet類型描述了該tasklet要執行的函數和函數需要的數據以及tasklet的狀態(狀態表示同類型的tasklet是否在運行等)。

  當do_softirq處理軟中斷時,如果相應的HI_SOFTIRQ和TASKLET_SOFTIRQ軟中斷被激活,就會調用對應的軟中斷函數tasklet_hi_action和tasklet_action。而這兩個函數處理的數據正是HI_SOFTIRQ和TASKLET_SOFTIRQ類型tasklet所對應的tasklet_head類型指向的tasklett鏈表。

  為了能夠寫自己的tasklet函數并加入到對應tasklet類型的tasklet_head指向的鏈表中,需要調用tasklet_init來初始化新的tasklet和調用tasklet_schedule或tasklet_hi_schedule來把我們自定義的tasklet加入到對應的tasklet_head指向的鏈表中并激活該tasklet類型所對應的軟中斷。

  所以說tasklet是在軟中斷的基礎上實現的,但不同的是軟中斷時靜態分配的(linux分配了6個軟中斷),而tasklet是可以動態加入和刪除tasklet的。

十一 工作隊列

  每個工作隊列,在每個cpu上都有一個cpu_workqueue_struct結構來描述,即對于同一個工作隊列,每個cpu都有該隊列的一個拷貝。cpu_workqueue_struct中的worklist成員指向了由work_struct結構組成的鏈表,這個鏈表描述的是該工作隊列被掛起的函數,等待工作者線程去執行。

  通過調用create_workqueue創建工作隊列。如果是smp,則每個cpu都會創建一個工作隊列和為該工作隊列工作的工作者線程。該工作者線程一直阻塞,直到有函數被加入到工作隊列中去,工作者線程執行了函數之后就把函數從工作隊列中刪除。

  可以通過queue_work函數把一個函數加入到工作隊列中去。

  由于僅僅為了一個函數就創建一個工作隊列開銷太大,所以內核預定義了一個叫events的工作隊列,為該隊列工作的工作者線程叫events/n,每個cpu一個。還有就是專門為塊設備使用的kblocked工作隊列。

十二 軟中斷與工作隊列的區別

  從上面可以看出,軟中斷和工作隊列十分的相似,都是對服務例程中某些耗時的操延后處理。主要區別在于,軟中斷的可延遲函數是在中斷上下文中執行的,而工作者隊列的函數則是在進程上下文中執行的,也就是說軟中斷的延遲函數執行期間不允許內核被搶占,而工作隊列則是可以的。

本文轉自:http://www.cnblogs.com/chengxuyuancc/p/3380922.html

posted on 2013-10-22 08:32 王海光 閱讀(599) 評論(0)  編輯 收藏 引用 所屬分類: Linux
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            免费久久99精品国产自| 国模吧视频一区| 亚洲在线一区二区三区| 中文日韩在线| 一区二区三区你懂的| 一本色道久久综合狠狠躁篇怎么玩| 亚洲国产精品va在线观看黑人 | 影音先锋久久资源网| 在线高清一区| 欧美一区二区视频在线| 欧美一区二区视频在线观看2020 | 欧美中文日韩| 免费在线视频一区| 亚洲免费成人av| 欧美亚洲一区二区三区| 欧美成人免费va影院高清| 欧美色图五月天| 在线成人h网| 亚洲香蕉网站| 欧美超级免费视 在线| 日韩一区二区久久| 性色av一区二区三区| 女生裸体视频一区二区三区| 国产精品久久99| 亚洲第一色在线| 亚洲欧美日韩精品久久久久| 欧美aa国产视频| 亚洲一区免费视频| 欧美~级网站不卡| 国产欧美在线| 亚洲视频在线观看视频| 久久综合久久综合这里只有精品| 亚洲黄网站黄| 久久高清国产| 国产精品自拍网站| 99re热这里只有精品视频| 久久久中精品2020中文| 99在线|亚洲一区二区| 久久久久久久久久久久久女国产乱| 欧美精品一区二区高清在线观看| 国产性天天综合网| 亚洲在线免费观看| 亚洲精品乱码久久久久久| 久久国产精品毛片| 国产日韩精品一区二区| 亚洲欧美日本国产有色| 妖精视频成人观看www| 欧美激情一区二区三区| 亚洲欧洲一区二区三区在线观看| 久久综合综合久久综合| 小黄鸭精品aⅴ导航网站入口| 欧美日韩中文字幕精品| 夜夜嗨一区二区三区| 亚洲电影在线免费观看| 久久在线视频在线| 狠狠久久亚洲欧美| 欧美一区二区三区在线免费观看| 99在线|亚洲一区二区| 欧美激情视频一区二区三区不卡| 在线电影一区| 久久国内精品视频| 一区二区三区日韩在线观看| 欧美三级在线| 亚洲视频一区二区免费在线观看| 国产精品高潮呻吟久久| 久久经典综合| 国产精品麻豆成人av电影艾秋| 91久久精品www人人做人人爽 | 午夜久久电影网| 亚洲毛片一区二区| 欧美日韩免费观看一区=区三区| 亚洲高清精品中出| 欧美激情中文不卡| 欧美激情中文字幕一区二区| 在线看片第一页欧美| 欧美大片在线看| 免费观看成人| 亚洲精品网址在线观看| 亚洲国产精品一区二区尤物区| 亚洲欧美在线高清| 亚洲第一天堂av| 久久av最新网址| 欧美午夜一区二区| 9人人澡人人爽人人精品| 在线日韩av片| 久久动漫亚洲| 久久午夜电影网| 国产精品久久久久久久久久免费看 | 一区二区三区自拍| 亚洲一区二区精品在线| 欧美中文字幕久久| 欧美亚洲视频在线看网址| 影音先锋另类| 亚洲欧美精品伊人久久| 免费在线播放第一区高清av| 久久字幕精品一区| 在线播放一区| 欧美日本一道本| 亚洲图片在线观看| 亚洲欧美一区二区三区极速播放| 欧美日韩视频在线观看一区二区三区 | 亚洲无亚洲人成网站77777 | 欧美精品一区在线发布| 亚洲自拍偷拍福利| 欧美系列一区| 久久手机精品视频| 欧美顶级少妇做爰| 午夜精品视频在线观看一区二区| 亚洲欧美日韩国产精品| 怡红院av一区二区三区| 亚洲美女黄色片| 国内外成人在线| 亚洲毛片网站| 一区在线免费| 一本色道久久精品| 在线观看不卡| 小嫩嫩精品导航| 日韩视频―中文字幕| 欧美一二区视频| 亚洲毛片av| 欧美中文字幕视频在线观看| 亚洲美女黄色| 久久久国产视频91| 亚洲免费一级电影| 最新亚洲视频| 欧美日韩国产成人高清视频| 国产在线国偷精品产拍免费yy| 亚洲一区二区免费| 久久久久久9999| 一道本一区二区| 久久激情一区| 小处雏高清一区二区三区| 欧美国产成人精品| 久久在线免费观看视频| 国产精品亚洲一区| 一本久道久久综合狠狠爱| 91久久嫩草影院一区二区| 欧美尤物一区| 久久精品欧美| 国产日本欧美一区二区| 中文在线不卡| 亚洲影院免费观看| 国产精品免费在线| 国产精品99久久久久久宅男| 这里只有精品电影| 欧美日韩亚洲91| 99视频精品| 亚洲午夜在线观看| 欧美午夜片在线免费观看| 一区二区欧美激情| 亚洲在线免费视频| 国产精品天天看| 欧美一级淫片aaaaaaa视频| 欧美在线视屏| 黄色成人av| 免费的成人av| 蜜乳av另类精品一区二区| 最新成人在线| 亚洲第一福利视频| 久久久久久久综合色一本| 久久久999| 国产在线精品二区| 快播亚洲色图| 最新国产拍偷乱拍精品| 中文无字幕一区二区三区| 欧美天堂亚洲电影院在线观看| 夜久久久久久| 久久久亚洲午夜电影| 在线日韩av永久免费观看| 欧美成人精品h版在线观看| 亚洲国产日韩欧美| 亚洲欧美日韩成人高清在线一区| 狠狠久久综合婷婷不卡| 猛男gaygay欧美视频| 亚洲日韩欧美视频一区| 香蕉久久夜色| 亚洲国产精品日韩| 欧美午夜精品一区| 久久精品国产一区二区三区免费看| 美女亚洲精品| 亚洲新中文字幕| 激情综合网址| 欧美三区视频| 久热精品视频在线| 一区二区三区欧美| 麻豆久久婷婷| 亚洲免费人成在线视频观看| 国内精品视频久久| 欧美日韩第一区| 久久国内精品视频| 一区二区三区导航| 欧美gay视频| 久久成人免费网| 一区二区三区精品久久久| 国产一区二区成人久久免费影院| 欧美久久久久久| 免费日韩av电影| 欧美一区国产一区| 国产精品99久久久久久有的能看| 老司机67194精品线观看|