xref: /freebsd/sys/contrib/device-tree/Bindings/pci/rcar-pci.txt (revision 6be3386466ab79a84b48429ae66244f21526d3df)
1c66ec88fSEmmanuel Vadot* Renesas R-Car PCIe interface
2c66ec88fSEmmanuel Vadot
3c66ec88fSEmmanuel VadotRequired properties:
4*6be33864SEmmanuel Vadotcompatible: "renesas,pcie-r8a7742" for the R8A7742 SoC;
5*6be33864SEmmanuel Vadot	    "renesas,pcie-r8a7743" for the R8A7743 SoC;
6c66ec88fSEmmanuel Vadot	    "renesas,pcie-r8a7744" for the R8A7744 SoC;
7c66ec88fSEmmanuel Vadot	    "renesas,pcie-r8a774a1" for the R8A774A1 SoC;
8c66ec88fSEmmanuel Vadot	    "renesas,pcie-r8a774b1" for the R8A774B1 SoC;
9c66ec88fSEmmanuel Vadot	    "renesas,pcie-r8a774c0" for the R8A774C0 SoC;
10c66ec88fSEmmanuel Vadot	    "renesas,pcie-r8a7779" for the R8A7779 SoC;
11c66ec88fSEmmanuel Vadot	    "renesas,pcie-r8a7790" for the R8A7790 SoC;
12c66ec88fSEmmanuel Vadot	    "renesas,pcie-r8a7791" for the R8A7791 SoC;
13c66ec88fSEmmanuel Vadot	    "renesas,pcie-r8a7793" for the R8A7793 SoC;
14c66ec88fSEmmanuel Vadot	    "renesas,pcie-r8a7795" for the R8A7795 SoC;
15c66ec88fSEmmanuel Vadot	    "renesas,pcie-r8a7796" for the R8A77960 SoC;
16c66ec88fSEmmanuel Vadot	    "renesas,pcie-r8a77961" for the R8A77961 SoC;
17c66ec88fSEmmanuel Vadot	    "renesas,pcie-r8a77980" for the R8A77980 SoC;
18c66ec88fSEmmanuel Vadot	    "renesas,pcie-r8a77990" for the R8A77990 SoC;
19c66ec88fSEmmanuel Vadot	    "renesas,pcie-rcar-gen2" for a generic R-Car Gen2 or
20c66ec88fSEmmanuel Vadot				     RZ/G1 compatible device.
21c66ec88fSEmmanuel Vadot	    "renesas,pcie-rcar-gen3" for a generic R-Car Gen3 or
22c66ec88fSEmmanuel Vadot				     RZ/G2 compatible device.
23c66ec88fSEmmanuel Vadot
24c66ec88fSEmmanuel Vadot	    When compatible with the generic version, nodes must list the
25c66ec88fSEmmanuel Vadot	    SoC-specific version corresponding to the platform first
26c66ec88fSEmmanuel Vadot	    followed by the generic version.
27c66ec88fSEmmanuel Vadot
28c66ec88fSEmmanuel Vadot- reg: base address and length of the PCIe controller registers.
29c66ec88fSEmmanuel Vadot- #address-cells: set to <3>
30c66ec88fSEmmanuel Vadot- #size-cells: set to <2>
31c66ec88fSEmmanuel Vadot- bus-range: PCI bus numbers covered
32c66ec88fSEmmanuel Vadot- device_type: set to "pci"
33c66ec88fSEmmanuel Vadot- ranges: ranges for the PCI memory and I/O regions.
34c66ec88fSEmmanuel Vadot- dma-ranges: ranges for the inbound memory regions.
35c66ec88fSEmmanuel Vadot- interrupts: two interrupt sources for MSI interrupts, followed by interrupt
36c66ec88fSEmmanuel Vadot	source for hardware related interrupts (e.g. link speed change).
37c66ec88fSEmmanuel Vadot- #interrupt-cells: set to <1>
38c66ec88fSEmmanuel Vadot- interrupt-map-mask and interrupt-map: standard PCI properties
39c66ec88fSEmmanuel Vadot	to define the mapping of the PCIe interface to interrupt numbers.
40c66ec88fSEmmanuel Vadot- clocks: from common clock binding: clock specifiers for the PCIe controller
41c66ec88fSEmmanuel Vadot	and PCIe bus clocks.
42c66ec88fSEmmanuel Vadot- clock-names: from common clock binding: should be "pcie" and "pcie_bus".
43c66ec88fSEmmanuel Vadot
44c66ec88fSEmmanuel VadotOptional properties:
45c66ec88fSEmmanuel Vadot- phys: from common PHY binding: PHY phandle and specifier (only make sense
46c66ec88fSEmmanuel Vadot	for R-Car gen3 SoCs where the PCIe PHYs have their own register blocks).
47c66ec88fSEmmanuel Vadot- phy-names: from common PHY binding: should be "pcie".
48c66ec88fSEmmanuel Vadot
49c66ec88fSEmmanuel VadotExample:
50c66ec88fSEmmanuel Vadot
51c66ec88fSEmmanuel VadotSoC-specific DT Entry:
52c66ec88fSEmmanuel Vadot
53c66ec88fSEmmanuel Vadot	pcie: pcie@fe000000 {
54c66ec88fSEmmanuel Vadot		compatible = "renesas,pcie-r8a7791", "renesas,pcie-rcar-gen2";
55c66ec88fSEmmanuel Vadot		reg = <0 0xfe000000 0 0x80000>;
56c66ec88fSEmmanuel Vadot		#address-cells = <3>;
57c66ec88fSEmmanuel Vadot		#size-cells = <2>;
58c66ec88fSEmmanuel Vadot		bus-range = <0x00 0xff>;
59c66ec88fSEmmanuel Vadot		device_type = "pci";
60c66ec88fSEmmanuel Vadot		ranges = <0x01000000 0 0x00000000 0 0xfe100000 0 0x00100000
61c66ec88fSEmmanuel Vadot			  0x02000000 0 0xfe200000 0 0xfe200000 0 0x00200000
62c66ec88fSEmmanuel Vadot			  0x02000000 0 0x30000000 0 0x30000000 0 0x08000000
63c66ec88fSEmmanuel Vadot			  0x42000000 0 0x38000000 0 0x38000000 0 0x08000000>;
64c66ec88fSEmmanuel Vadot		dma-ranges = <0x42000000 0 0x40000000 0 0x40000000 0 0x40000000
65c66ec88fSEmmanuel Vadot			      0x42000000 2 0x00000000 2 0x00000000 0 0x40000000>;
66c66ec88fSEmmanuel Vadot		interrupts = <0 116 4>, <0 117 4>, <0 118 4>;
67c66ec88fSEmmanuel Vadot		#interrupt-cells = <1>;
68c66ec88fSEmmanuel Vadot		interrupt-map-mask = <0 0 0 0>;
69c66ec88fSEmmanuel Vadot		interrupt-map = <0 0 0 0 &gic 0 116 4>;
70c66ec88fSEmmanuel Vadot		clocks = <&mstp3_clks R8A7791_CLK_PCIE>, <&pcie_bus_clk>;
71c66ec88fSEmmanuel Vadot		clock-names = "pcie", "pcie_bus";
72c66ec88fSEmmanuel Vadot	};
73