Lines Matching +full:riscv +full:- +full:isa +full:- +full:manual
1 # SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
4 ---
5 $id: http://devicetree.org/schemas/interrupt-controller/sifive,plic-1.0.0.yaml#
6 $schema: http://devicetree.org/meta-schemas/core.yaml#
8 title: SiFive Platform-Level Interrupt Controller (PLIC)
11 SiFive SoCs and other RISC-V SoCs include an implementation of the
12 Platform-Level Interrupt Controller (PLIC) high-level specification in
13 the RISC-V Privileged Architecture specification. The PLIC connects all
18 in an 4 core system with 2-way SMT, you have 8 harts and probably at least two
21 Each interrupt can be enabled on per-context basis. Any context can claim
29 The PLIC supports both edge-triggered and level-triggered interrupts. For
30 edge-triggered interrupts, the RISC-V PLIC spec allows two responses to edges
36 RZ/Five SoC (AX45MP AndesCore with a NCEPLIC100) and the T-HEAD C900 PLIC.
38 While the RISC-V ISA doesn't specify a memory layout for the PLIC, the
39 "sifive,plic-1.0.0" device is a concrete implementation of the PLIC that
41 SiFive U5 Coreplex Series Manual <https://static.dev.sifive.com/U54-MC-RVCoreIP.pdf>.
43 The thead,c900-plic is different from sifive,plic-1.0.0 in opensbi, the
44 T-HEAD PLIC implementation requires setting a delegation bit to allow access
45 from S-mode. So add thead,c900-plic to distinguish them.
48 - Paul Walmsley <paul.walmsley@sifive.com>
49 - Palmer Dabbelt <palmer@dabbelt.com>
54 - items:
55 - enum:
56 - renesas,r9a07g043-plic
57 - const: andestech,nceplic100
58 - items:
59 - enum:
60 - canaan,k210-plic
61 - sifive,fu540-c000-plic
62 - starfive,jh7100-plic
63 - starfive,jh7110-plic
64 - const: sifive,plic-1.0.0
65 - items:
66 - enum:
67 - allwinner,sun20i-d1-plic
68 - thead,th1520-plic
69 - const: thead,c900-plic
70 - items:
71 - const: sifive,plic-1.0.0
72 - const: riscv,plic0
79 '#address-cells':
82 '#interrupt-cells': true
84 interrupt-controller: true
86 interrupts-extended:
90 Specifies which contexts are connected to the PLIC, with "-1" specifying
92 riscv,cpu-intc node, which has a riscv node as parent.
94 riscv,ndev:
101 power-domains: true
106 - compatible
107 - '#address-cells'
108 - '#interrupt-cells'
109 - interrupt-controller
110 - reg
111 - interrupts-extended
112 - riscv,ndev
115 - if:
120 - andestech,nceplic100
121 - thead,c900-plic
125 '#interrupt-cells':
130 '#interrupt-cells':
133 - if:
137 const: renesas,r9a07g043-plic
144 power-domains:
151 - clocks
152 - power-domains
153 - resets
158 - |
159 plic: interrupt-controller@c000000 {
160 #address-cells = <0>;
161 #interrupt-cells = <1>;
162 compatible = "sifive,fu540-c000-plic", "sifive,plic-1.0.0";
163 interrupt-controller;
164 interrupts-extended = <&cpu0_intc 11>,
170 riscv,ndev = <10>;