ソフト割り込み
Rev.4を表示中。最新版はこちら。
1.割り込みの種類
Linuxではソフトウェアで行う割り込み処理に様々な種類がある。すでに無くなっているものも含めて以下に示す。1.1 BH (Bottom Half)
Linux初期の頃からある割り込み処理形式。
登録数は32まで。
マルチプロセッサのシステムでも複数実行は不可(常に1つしか実行されない)。
Kernel 2.4の実装としては高優先度タスクレットとして登録され実行されている。
Kernel 2.6では削除された。
登録数は32まで。
マルチプロセッサのシステムでも複数実行は不可(常に1つしか実行されない)。
Kernel 2.4の実装としては高優先度タスクレットとして登録され実行されている。
Kernel 2.6では削除された。
1.2 タスクキュー
BHの拡張。
一つのBHに複数のハンドラを登録できるようにして、BHの数の制限を回避している。
タスクキューはBHの中で処理される。
Kernel 2.6では削除された。
タスクキューの例:
tq_immediate 即実行用タスクキュー
tq_timer タイマ用タスクキュー
一つのBHに複数のハンドラを登録できるようにして、BHの数の制限を回避している。
タスクキューはBHの中で処理される。
Kernel 2.6では削除された。
タスクキューの例:
tq_immediate 即実行用タスクキュー
tq_timer タイマ用タスクキュー
1.3 ソフト割り込み
マルチプロセッサの場合、各プロセッサで同じ割り込みが動作可能。1.4 タスクレット
ソフト割り込みの一つ。複数のハンドラを登録できる。
複数のCPUで同時実行できるが同じタスクレットは同時実行できない。
2.実装関連
softirq_vec[]
+--------------+
| | HI_SOFTIRQ:tasklet_hi_action()
+--------------+
| | NET_TX_SOFTIRQ
+--------------+
| | NET_RX_SOFTIRQ
+--------------+
| | TASKLET_SOFTIRQ:tasklet_action()
+--------------+
:
+--------------+
| |
+--------------+
ソフト割り込みのハンドラが登録される。
open_softirq()で登録する。
raise_softirq()でスケジュールする
(pendingフラグを立ててksoftirqd()をWakeupする)
tasklet_vec[] (HI_SOFTIRQ用にtasklet_hi_vec[]もある)
+--------------+
| CPU#0 | --> tasklet_struct -> tasklet_struct ->
+--------------+
| CPU#1 |
+--------------+
:
タスクレットのハンドラを登録する。
tasklet_init()でtasklet_structを初期化して、
tasklet_schedule()によってtasklet_structをチェーンして、
TASKLET_SOFTIRQをスケジュールする
Kernel2.6ではソフト割り込みとタスクレットのみとなった。
また、新規の割り込みはタスクレットとして実装するように
linux/interrupt.hに記されている。