技術問答
技術文章
iT 徵才
Tag
聊天室
2024 鐵人賽
登入/註冊
問答
文章
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
216 瀏覽
分享至
今日的行程:
辦公室: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 總結與回顧
完整目錄
尚未有邦友留言
立即登入留言
iThome鐵人賽
參賽組數
1064
組
團體組數
40
組
累計文章數
22211
篇
完賽人數
600
人
看影片追技術
看更多
{{ item.subject }}
{{ item.channelVendor }}
|
{{ formatDate(item.duration) }}
直播中
熱門tag
看更多
15th鐵人賽
16th鐵人賽
13th鐵人賽
14th鐵人賽
12th鐵人賽
11th鐵人賽
鐵人賽
2019鐵人賽
javascript
2018鐵人賽
python
2017鐵人賽
windows
php
c#
windows server
linux
css
react
vue.js
熱門問題
請教Smart IT及神網的比較
群暉NAS新增HA
如何控管現在的手機連公司wifi-因手機現在會自動變更mac位置
請問 "TWNCI.net 網路世界有限公司" 是合法還是非法網域註冊廠商?
樹莓派可以塞多大的模型?
有關AI模型的回應不一樣問題
資訊設備 電壓防護詢問
AWS主機進入休眠(已解決)
想設計一個Powershell代碼
如何遠端連線至MAC notebook
熱門回答
如何控管現在的手機連公司wifi-因手機現在會自動變更mac位置
系統開發的問題請益
如何規劃一個安全的網路管制區
群暉NAS新增HA
有關AI模型的回應不一樣問題
熱門文章
如果不試一輩子都不知道自己能走這麼遠|不知不覺寫了 1 年程式,前端工程師修煉之路
二、三天學一點點 Rust:來!那些變數們(3)
二、三天學一點點 Rust:來!那些變數們(4)
人資系統整合與資料加密機制實作
「與AI探索天文」如何藉由ChatGPT虛構天文學家的一天來學習天文知識及故事創作技巧?
IT邦幫忙
×
標記使用者
輸入對方的帳號或暱稱
Loading
找不到結果。
標記
{{ result.label }}
{{ result.account }}