53 lines
2.4 KiB
Plaintext
53 lines
2.4 KiB
Plaintext
RISC-V Hart-Level Interrupt Controller (HLIC)
|
|
---------------------------------------------
|
|
|
|
RISC-V cores include Control Status Registers (CSRs) which are local to each
|
|
CPU core (HART in RISC-V terminology) and can be read or written by software.
|
|
Some of these CSRs are used to control local interrupts connected to the core.
|
|
Every interrupt is ultimately routed through a hart's HLIC before it
|
|
interrupts that hart.
|
|
|
|
The RISC-V supervisor ISA manual specifies three interrupt sources that are
|
|
attached to every HLIC: software interrupts, the timer interrupt, and external
|
|
interrupts. Software interrupts are used to send IPIs between cores. The
|
|
timer interrupt comes from an architecturally mandated real-time timer that is
|
|
controlled via Supervisor Binary Interface (SBI) calls and CSR reads. External
|
|
interrupts connect all other device interrupts to the HLIC, which are routed
|
|
via the platform-level interrupt controller (PLIC).
|
|
|
|
All RISC-V systems that conform to the supervisor ISA specification are
|
|
required to have a HLIC with these three interrupt sources present. Since the
|
|
interrupt map is defined by the ISA it's not listed in the HLIC's device tree
|
|
entry, though external interrupt controllers (like the PLIC, for example) will
|
|
need to define how their interrupts map to the relevant HLICs. This means
|
|
a PLIC interrupt property will typically list the HLICs for all present HARTs
|
|
in the system.
|
|
|
|
Required properties:
|
|
- compatible : "riscv,cpu-intc"
|
|
- #interrupt-cells : should be <1>. The interrupt sources are defined by the
|
|
RISC-V supervisor ISA manual, with only the following three interrupts being
|
|
defined for supervisor mode:
|
|
- Source 1 is the supervisor software interrupt, which can be sent by an SBI
|
|
call and is reserved for use by software.
|
|
- Source 5 is the supervisor timer interrupt, which can be configured by
|
|
SBI calls and implements a one-shot timer.
|
|
- Source 9 is the supervisor external interrupt, which chains to all other
|
|
device interrupts.
|
|
- interrupt-controller : Identifies the node as an interrupt controller
|
|
|
|
Furthermore, this interrupt-controller MUST be embedded inside the cpu
|
|
definition of the hart whose CSRs control these local interrupts.
|
|
|
|
An example device tree entry for a HLIC is show below.
|
|
|
|
cpu1: cpu@1 {
|
|
compatible = "riscv";
|
|
...
|
|
cpu1-intc: interrupt-controller {
|
|
#interrupt-cells = <1>;
|
|
compatible = "sifive,fu540-c000-cpu-intc", "riscv,cpu-intc";
|
|
interrupt-controller;
|
|
};
|
|
};
|