blob: c9f04999c9cf7da8190ee971f5c414b32b3b3d50 [file] [log] [blame]
Tom Rini53633a82024-02-29 12:33:36 -05001# SPDX-License-Identifier: GPL-2.0
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/pci/hisilicon,kirin-pcie.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: HiSilicon Kirin SoCs PCIe host DT description
8
9maintainers:
10 - Xiaowei Song <songxiaowei@hisilicon.com>
11 - Binghui Wang <wangbinghui@hisilicon.com>
12
13description: |
14 Kirin PCIe host controller is based on the Synopsys DesignWare PCI core.
15 It shares common functions with the PCIe DesignWare core driver and
16 inherits common properties defined in
17 Documentation/devicetree/bindings/pci/snps,dw-pcie.yaml.
18
19allOf:
20 - $ref: /schemas/pci/snps,dw-pcie.yaml#
21
22properties:
23 compatible:
24 contains:
25 enum:
26 - hisilicon,kirin960-pcie
27 - hisilicon,kirin970-pcie
28
29 reg:
30 description: |
31 Should contain dbi, apb, config registers location and length.
32 For hisilicon,kirin960-pcie, it should also contain phy.
33 minItems: 3
34 maxItems: 4
35
36 reg-names:
37 minItems: 3
38 maxItems: 4
39
40 clocks: true
41
42 clock-names:
43 items:
44 - const: pcie_phy_ref
45 - const: pcie_aux
46 - const: pcie_apb_phy
47 - const: pcie_apb_sys
48 - const: pcie_aclk
49
50 phys:
51 maxItems: 1
52
53 hisilicon,clken-gpios:
54 description: |
55 Clock input enablement GPIOs from PCI devices like Ethernet, M.2 and
56 mini-PCIe slots.
57
58required:
59 - compatible
60 - reg
61 - reg-names
62
63unevaluatedProperties: false
64
65examples:
66 - |
67 #include <dt-bindings/interrupt-controller/arm-gic.h>
68 #include <dt-bindings/clock/hi3660-clock.h>
69 #include <dt-bindings/clock/hi3670-clock.h>
70
71 soc {
72 #address-cells = <2>;
73 #size-cells = <2>;
74
75 pcie@f4000000 {
76 compatible = "hisilicon,kirin960-pcie";
77 reg = <0x0 0xf4000000 0x0 0x1000>,
78 <0x0 0xff3fe000 0x0 0x1000>,
79 <0x0 0xf3f20000 0x0 0x40000>,
80 <0x0 0xf5000000 0x0 0x2000>;
81 reg-names = "dbi", "apb", "phy", "config";
82 bus-range = <0x0 0xff>;
83 #address-cells = <3>;
84 #size-cells = <2>;
85 device_type = "pci";
86 ranges = <0x02000000 0x0 0x00000000
87 0x0 0xf6000000
88 0x0 0x02000000>;
89 num-lanes = <1>;
90 #interrupt-cells = <1>;
91 interrupts = <0 283 4>;
92 interrupt-names = "msi";
93 interrupt-map-mask = <0xf800 0 0 7>;
94 interrupt-map = <0x0 0 0 1 &gic GIC_SPI 282 IRQ_TYPE_LEVEL_HIGH>,
95 <0x0 0 0 2 &gic GIC_SPI 283 IRQ_TYPE_LEVEL_HIGH>,
96 <0x0 0 0 3 &gic GIC_SPI 284 IRQ_TYPE_LEVEL_HIGH>,
97 <0x0 0 0 4 &gic GIC_SPI 285 IRQ_TYPE_LEVEL_HIGH>;
98 clocks = <&crg_ctrl HI3660_PCIEPHY_REF>,
99 <&crg_ctrl HI3660_CLK_GATE_PCIEAUX>,
100 <&crg_ctrl HI3660_PCLK_GATE_PCIE_PHY>,
101 <&crg_ctrl HI3660_PCLK_GATE_PCIE_SYS>,
102 <&crg_ctrl HI3660_ACLK_GATE_PCIE>;
103 clock-names = "pcie_phy_ref", "pcie_aux", "pcie_apb_phy",
104 "pcie_apb_sys", "pcie_aclk";
105 };
106
107 pcie@f5000000 {
108 compatible = "hisilicon,kirin970-pcie";
109 reg = <0x0 0xf4000000 0x0 0x1000000>,
110 <0x0 0xfc180000 0x0 0x1000>,
111 <0x0 0xf5000000 0x0 0x2000>;
112 reg-names = "dbi", "apb", "config";
113 bus-range = <0x0 0xff>;
114 #address-cells = <3>;
115 #size-cells = <2>;
116 device_type = "pci";
117 phys = <&pcie_phy>;
118 ranges = <0x02000000 0x0 0x00000000
119 0x0 0xf6000000
120 0x0 0x02000000>;
121 num-lanes = <1>;
122 #interrupt-cells = <1>;
123 interrupts = <GIC_SPI 283 IRQ_TYPE_LEVEL_HIGH>;
124 interrupt-names = "msi";
125 interrupt-map-mask = <0 0 0 7>;
126 interrupt-map = <0x0 0 0 1 &gic GIC_SPI 282 IRQ_TYPE_LEVEL_HIGH>,
127 <0x0 0 0 2 &gic GIC_SPI 283 IRQ_TYPE_LEVEL_HIGH>,
128 <0x0 0 0 3 &gic GIC_SPI 284 IRQ_TYPE_LEVEL_HIGH>,
129 <0x0 0 0 4 &gic GIC_SPI 285 IRQ_TYPE_LEVEL_HIGH>;
130 reset-gpios = <&gpio7 0 0>;
131 hisilicon,clken-gpios = <&gpio27 3 0>, <&gpio17 0 0>, <&gpio20 6 0>;
132 pcie@0,0 { // Lane 0: PCIe switch: Bus 1, Device 0
133 reg = <0 0 0 0 0>;
134 compatible = "pciclass,0604";
135 device_type = "pci";
136 #address-cells = <3>;
137 #size-cells = <2>;
138 ranges;
139
140 pcie@0,0 { // Lane 0: upstream
141 reg = <0 0 0 0 0>;
142 compatible = "pciclass,0604";
143 device_type = "pci";
144 #address-cells = <3>;
145 #size-cells = <2>;
146 ranges;
147
148 pcie@1,0 { // Lane 4: M.2
149 reg = <0x0800 0 0 0 0>;
150 compatible = "pciclass,0604";
151 device_type = "pci";
152 reset-gpios = <&gpio3 1 0>;
153 #address-cells = <3>;
154 #size-cells = <2>;
155 ranges;
156 };
157
158 pcie@5,0 { // Lane 5: Mini PCIe
159 reg = <0x2800 0 0 0 0>;
160 compatible = "pciclass,0604";
161 device_type = "pci";
162 reset-gpios = <&gpio27 4 0 >;
163 #address-cells = <3>;
164 #size-cells = <2>;
165 ranges;
166 };
167
168 pcie@7,0 { // Lane 6: Ethernet
169 reg = <0x03800 0 0 0 0>;
170 compatible = "pciclass,0604";
171 device_type = "pci";
172 reset-gpios = <&gpio25 2 0 >;
173 #address-cells = <3>;
174 #size-cells = <2>;
175 ranges;
176 };
177 };
178 };
179 };
180 };