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