xref: /linux/Documentation/devicetree/bindings/pci/amd,versal2-mdb-host.yaml (revision e49a3eac9207e9575337f70feeb29430f6f16bb7)
1# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/pci/amd,versal2-mdb-host.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: AMD Versal2 MDB(Multimedia DMA Bridge) Host Controller
8
9maintainers:
10  - Thippeswamy Havalige <thippeswamy.havalige@amd.com>
11
12allOf:
13  - $ref: /schemas/pci/pci-host-bridge.yaml#
14  - $ref: /schemas/pci/snps,dw-pcie.yaml#
15
16properties:
17  compatible:
18    const: amd,versal2-mdb-host
19
20  reg:
21    items:
22      - description: MDB System Level Control and Status Register (SLCR) Base
23      - description: configuration region
24      - description: data bus interface
25      - description: address translation unit register
26
27  reg-names:
28    items:
29      - const: slcr
30      - const: config
31      - const: dbi
32      - const: atu
33
34  ranges:
35    maxItems: 2
36
37  msi-map:
38    maxItems: 1
39
40  interrupts:
41    maxItems: 1
42
43  interrupt-map-mask:
44    items:
45      - const: 0
46      - const: 0
47      - const: 0
48      - const: 7
49
50  interrupt-map:
51    maxItems: 4
52
53  "#interrupt-cells":
54    const: 1
55
56  interrupt-controller:
57    description: identifies the node as an interrupt controller
58    type: object
59    additionalProperties: false
60    properties:
61      interrupt-controller: true
62
63      "#address-cells":
64        const: 0
65
66      "#interrupt-cells":
67        const: 1
68
69    required:
70      - interrupt-controller
71      - "#address-cells"
72      - "#interrupt-cells"
73
74required:
75  - reg
76  - reg-names
77  - interrupts
78  - interrupt-map
79  - interrupt-map-mask
80  - msi-map
81  - "#interrupt-cells"
82  - interrupt-controller
83
84unevaluatedProperties: false
85
86examples:
87  - |
88    #include <dt-bindings/interrupt-controller/arm-gic.h>
89    #include <dt-bindings/interrupt-controller/irq.h>
90
91    soc {
92        #address-cells = <2>;
93        #size-cells = <2>;
94        pcie@ed931000 {
95            compatible = "amd,versal2-mdb-host";
96            reg = <0x0 0xed931000 0x0 0x2000>,
97                  <0x1000 0x100000 0x0 0xff00000>,
98                  <0x1000 0x0 0x0 0x1000>,
99                  <0x0 0xed860000 0x0 0x2000>;
100            reg-names = "slcr", "config", "dbi", "atu";
101            ranges = <0x2000000 0x00 0xa0000000 0x00 0xa0000000 0x00 0x10000000>,
102                     <0x43000000 0x1100 0x00 0x1100 0x00 0x00 0x1000000>;
103            interrupts = <GIC_SPI 165 IRQ_TYPE_LEVEL_HIGH>;
104            interrupt-parent = <&gic>;
105            interrupt-map-mask = <0 0 0 7>;
106            interrupt-map = <0 0 0 1 &pcie_intc_0 0>,
107                            <0 0 0 2 &pcie_intc_0 1>,
108                            <0 0 0 3 &pcie_intc_0 2>,
109                            <0 0 0 4 &pcie_intc_0 3>;
110            msi-map = <0x0 &gic_its 0x00 0x10000>;
111            #address-cells = <3>;
112            #size-cells = <2>;
113            #interrupt-cells = <1>;
114            device_type = "pci";
115            pcie_intc_0: interrupt-controller {
116                #address-cells = <0>;
117                #interrupt-cells = <1>;
118                interrupt-controller;
119           };
120        };
121    };
122