<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 一個(gè)簡(jiǎn)單的PCI總線(xiàn)INTx中斷實(shí)現流程

一個(gè)簡(jiǎn)單的PCI總線(xiàn)INTx中斷實(shí)現流程

作者: 時(shí)間:2018-09-03 來(lái)源:網(wǎng)絡(luò ) 收藏

  一個(gè)簡(jiǎn)單的總線(xiàn)中斷實(shí)現流程,如下圖所示。

本文引用地址:http://dyxdggzs.com/article/201809/391486.htm

  1. 首先,設備通過(guò)邊帶信號產(chǎn)生中斷請求,經(jīng)過(guò)中斷控制器(Interrupt Controller,PIC)后,轉換為INTR信號,并直接發(fā)送至CPU;

  2. CPU收到INTR信號置位后,意識到了中斷請求的發(fā)生,但是此時(shí)并不知道是什么中斷請求。于是通過(guò)一個(gè)特殊的指令來(lái)查詢(xún)中斷請求信息,該過(guò)程一般被稱(chēng)為中斷應答(Interrupt Acknowledge);

  3. 該特殊指令被發(fā)送至PIC后,PIC會(huì )返回一個(gè)8bits的中斷向量(Interrupt Vector)值給CPU。該中斷向量值與其發(fā)送的INTR請求是對應的;

  4. CPU收到來(lái)自PIC的中斷向量值后,會(huì )去其Memory中的中斷向量表(Interrupt Table)中查找對應的中斷服務(wù)程序(Interrupt Service Routines,ISR)在Memory的位置;

  5. 然后CPU讀取ISR程序,進(jìn)而處理該中斷。



  上面的例子主要是基于早期的單核CPU設計的,并沒(méi)有考慮到目前多核CPU的情況。因此,在后續的 Spec中,將PIC替換為IO APIC(Advanced Programmed Interrupt Controller)。如下圖所示:



  實(shí)際上,在PCIe總線(xiàn)中,傳統的中斷機制()已經(jīng)很少被使用,很多應用甚至直接將該功能禁止了。無(wú)論是在PCI總線(xiàn)(V2.3及以后的版本),還是PCIe總線(xiàn)中,都可以通過(guò)配置空間中的配置命令寄存器(Configuration Command Register來(lái)禁止INTx中斷機制),如下圖所示。不過(guò),需要特別注意的是,雖然該bit的名稱(chēng)為中斷禁止(Interrupt Disable),但是其只會(huì )影響INTx,對MSI/MSI-X不會(huì )造成影響。因為MSI/MSI-X的使能(或禁止)是通過(guò)配置空間中的MSI/MSI-X Capability Command Register來(lái)實(shí)現的,并且一旦使能了MSI/MSI-X,PCI總線(xiàn)/PCIe總線(xiàn)便會(huì )自動(dòng)地禁止INTx。



  并且可以通過(guò)配置狀態(tài)寄存器的中斷狀態(tài)(Interrupt Status)bit來(lái)確定當前的中斷狀態(tài),如下圖所示:



  INTx相關(guān)的寄存器在配置空間的位置如下圖所示,Interrupt Pin和Interrupt Line分別定義了中斷邊帶信號引腳號(INTA#~INTD#)和中斷向量號(IRQ0~IRQ255)。



  然而,PCIe總線(xiàn)繼承了PCI總線(xiàn)的INTx中斷機制,但是在實(shí)際的PCIe設備之間的中斷信息傳輸中使用的并非邊帶信號INTx,而是基于消息(Message)的。其中Assert_INTx消息表示INTx信號的下降沿。Dessert_INTx消息表示INTx信號的上升沿。當發(fā)送這兩種消息時(shí),PCIe設備還會(huì )將配置空間的相關(guān)中斷狀態(tài)bit的值更新。對于PCIe-PCI(X)橋設備來(lái)說(shuō),會(huì )將接收到的來(lái)自PCI/PCI-X總線(xiàn)的INTx信號轉換為消息,在往上級發(fā)送。一個(gè)簡(jiǎn)單的例子如下圖所示:



  INTx消息的格式為:



  橋設備中的INTx消息的類(lèi)型與設備號的映射關(guān)系如下圖所示:



  對應的,一個(gè)簡(jiǎn)單的例子如下:



  當多個(gè)設備使用同一個(gè)中斷信號線(xiàn)時(shí),只有先置位的設備會(huì )被中斷控制器響應。但是該中斷信號線(xiàn),并不會(huì )因為其中一個(gè)設備的中斷請求得到響應便被清除,而是會(huì )等到所有的發(fā)送請求的設備的中斷請求都得到了響應之后。如下圖所示:




關(guān)鍵詞: PCI INTx

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>