技術問答
技術文章
iT 徵才
聊天室
2026 鐵人賽
登入/註冊
問答
文章
Tag
邦友
鐵人賽
搜尋
2024 iThome 鐵人賽
DAY
26
0
自我挑戰組
上班辦公室,下班讀書室:RISC-V / ARM64 體系結構編程與實踐
系列 第
26
篇
# [鐵人賽] Day 26 ARM 第 13 章節 GIC-V2 (2)
16th鐵人賽
ycliang
團隊
晶心壯士III: ALcHemist
2024-09-26 22:32:26
456 瀏覽
分享至
今日的行程:
辦公室:10:00 - 19:30
讀書室:21:30 - 22:30
正片開始
GIC-V2
SGI (Software Generated Interrupts): IPI
PPI (Private Peripheral Interrupts): local timer
SPI (Shared Peripheral Interrupts)
中斷流程
GIC 偵測到中斷發生,會將該中斷標記為 pending
GIC 中的 dispatche 略r 會選一個 priority 最高的 pending
interrupt 到 target CPU 的 CPU interface (也是由 dispatcher 決定)
CPU interface 會決定這個 interrupt 是否可以送給 CPU (CPU 需要處在特定狀態),可以的話,送一個 interrupt 給 target CPU
target CPU 進入 interrupt handling 過程,讀取 GICC_IAR (Interrupt Acknowledge Register) 來 claim 這個 interrupt 並且得到 interrupt ID (或是 CPU ID,如果是 SGI 的話)
當 GIC 偵測到 GICC_IAR 被讀取後,如果 interrupt 是 pending 的話,會變成 active
處理完 interrupt 後,會回傳 EOI (End Of Interrupt) 給 GIC
GIC 有支援 preemptive interrupt,不過由於 linux kernel 在執行 interrupt handling 過程中是 interrupt disable 的狀態,所以不會馬上收到。
書中有附上訊號的時序圖~
GIC-V2 register
-- 略 --
結論
drivers/irqchip/irq-gic.c
RISC-V PLIC sample implementation:
drivers/irqchip/irq-sifive-plic.c
RISC-V AIA (Advanced Interrupt Architecture)
drivers/irqchip/irq-riscv-intc.c
APLIC
IMSIC
留言
追蹤
檢舉
上一篇
[鐵人賽] Day 25 ARM 第 13 章節 GIC-V2
下一篇
[鐵人賽] Day 27 RISC-V 第 18 章節 Vector extension
系列文
上班辦公室,下班讀書室:RISC-V / ARM64 體系結構編程與實踐
共
30
篇
目錄
RSS系列文
訂閱系列文
5
人訂閱
26
# [鐵人賽] Day 26 ARM 第 13 章節 GIC-V2 (2)
27
[鐵人賽] Day 27 RISC-V 第 18 章節 Vector extension
28
[鐵人賽] Day 28 RISC-V 第 18 章 Vector Extension (2)
29
[鐵人賽] Day 29 RISC-V 第 18 章 Vector Extension (3)
30
[鐵人賽] Day 30 總結與回顧
完整目錄
熱門推薦
{{ item.subject }}
{{ item.channelVendor }}
|
{{ item.webinarstarted }}
|
{{ formatDate(item.duration) }}
直播中
立即報名
尚未有邦友留言
立即登入留言
iThome鐵人賽
參賽組數
902
組
團體組數
37
組
累計文章數
19860
篇
完賽人數
528
人
看影片追技術
看更多
{{ item.subject }}
{{ item.channelVendor }}
|
{{ formatDate(item.duration) }}
直播中
熱門tag
15th鐵人賽
16th鐵人賽
13th鐵人賽
14th鐵人賽
17th鐵人賽
12th鐵人賽
11th鐵人賽
鐵人賽
2019鐵人賽
javascript
2018鐵人賽
python
2017鐵人賽
windows
php
c#
linux
windows server
css
react
熱門問題
在上海使用 Fortigate 的IPSEC VPN
請益如何關閉Windows的登入畫面?
Exchange 2016 遇到的問題 Outlook無法登入
o365 sharedmailbox 收件一問 - 轉寄去DISTRIBUTION GROUP 問題
熱門回答
在上海使用 Fortigate 的IPSEC VPN
o365 sharedmailbox 收件一問 - 轉寄去DISTRIBUTION GROUP 問題
請益如何關閉Windows的登入畫面?
Exchange 2016 遇到的問題 Outlook無法登入
熱門文章
[POG-08] 破除迷思:Prompt Orchestration Governance(POG) 常見問題 (FAQ) 大解析
AI 時代,我們為什麼比過去更需要軟體工程師?解析 Vibe Coding 的虛與實
當我的AI助手住進雲端:我的生活變了, 使用Clawdbot + Linode一周感受
【C++學習筆記】04《邏輯運算與運算子》
解決中文母語者的 Gemini 破版困擾,拯救數位強迫症
IT邦幫忙
×
標記使用者
輸入對方的帳號或暱稱
Loading
找不到結果。
標記
{{ result.label }}
{{ result.account }}