# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause) %YAML 1.2 --- $id: http://devicetree.org/schemas/pci/mediatek-pcie.yaml# $schema: http://devicetree.org/meta-schemas/core.yaml# title: PCIe controller on MediaTek SoCs maintainers: - Christian Marangi properties: compatible: oneOf: - enum: - airoha,an7583-pcie - mediatek,mt2712-pcie - mediatek,mt7622-pcie - mediatek,mt7629-pcie - items: - const: airoha,en7523-pcie - const: mediatek,mt7622-pcie reg: maxItems: 1 reg-names: enum: [ port0, port1 ] clocks: minItems: 1 maxItems: 6 clock-names: minItems: 1 items: - enum: [ sys_ck0, sys_ck1 ] - enum: [ ahb_ck0, ahb_ck1 ] - enum: [ aux_ck0, aux_ck1 ] - enum: [ axi_ck0, axi_ck1 ] - enum: [ obff_ck0, obff_ck1 ] - enum: [ pipe_ck0, pipe_ck1 ] resets: maxItems: 1 reset-names: const: pcie-rst1 interrupts: maxItems: 1 interrupt-names: const: pcie_irq phys: maxItems: 1 phy-names: enum: [ pcie-phy0, pcie-phy1 ] power-domains: maxItems: 1 mediatek,pbus-csr: $ref: /schemas/types.yaml#/definitions/phandle-array items: - items: - description: phandle to pbus-csr syscon - description: offset of pbus-csr base address register - description: offset of pbus-csr base address mask register description: Phandle with two arguments to the syscon node used to detect if a given address is accessible on PCIe controller. '#interrupt-cells': const: 1 interrupt-controller: description: Interrupt controller node for handling legacy PCI interrupts. type: object properties: '#address-cells': const: 0 '#interrupt-cells': const: 1 interrupt-controller: true required: - '#address-cells' - '#interrupt-cells' - interrupt-controller additionalProperties: false required: - compatible - reg - reg-names - ranges - clocks - clock-names - '#interrupt-cells' - interrupts - interrupt-names - interrupt-controller allOf: - $ref: /schemas/pci/pci-host-bridge.yaml# - if: properties: compatible: const: airoha,an7583-pcie then: properties: reg-names: const: port1 clocks: maxItems: 1 clock-names: const: sys_ck1 phy-names: const: pcie-phy1 power-domain: false required: - resets - reset-names - phys - phy-names - mediatek,pbus-csr - if: properties: compatible: const: mediatek,mt2712-pcie then: properties: clocks: minItems: 2 maxItems: 2 clock-names: minItems: 2 maxItems: 2 reset: false reset-names: false power-domains: false mediatek,pbus-csr: false required: - phys - phy-names - if: properties: compatible: const: mediatek,mt7622-pcie then: properties: clocks: minItems: 6 reset: false reset-names: false phys: false phy-names: false mediatek,pbus-csr: false required: - power-domains - if: properties: compatible: const: mediatek,mt7629-pcie then: properties: clocks: minItems: 6 reset: false reset-names: false mediatek,pbus-csr: false required: - power-domains - if: properties: compatible: contains: const: airoha,en7523-pcie then: properties: clocks: maxItems: 1 clock-names: maxItems: 1 reset: false reset-names: false phys: false phy-names: false power-domain: false mediatek,pbus-csr: false unevaluatedProperties: false examples: # MT2712 - | #include #include #include soc_1 { #address-cells = <2>; #size-cells = <2>; pcie@112ff000 { compatible = "mediatek,mt2712-pcie"; device_type = "pci"; reg = <0 0x112ff000 0 0x1000>; reg-names = "port1"; linux,pci-domain = <1>; #address-cells = <3>; #size-cells = <2>; interrupts = ; interrupt-names = "pcie_irq"; clocks = <&topckgen>, /* CLK_TOP_PE2_MAC_P1_SEL */ <&pericfg>; /* CLK_PERI_PCIE1 */ clock-names = "sys_ck1", "ahb_ck1"; phys = <&u3port1 PHY_TYPE_PCIE>; phy-names = "pcie-phy1"; bus-range = <0x00 0xff>; ranges = <0x82000000 0 0x11400000 0x0 0x11400000 0 0x300000>; #interrupt-cells = <1>; interrupt-map-mask = <0 0 0 7>; interrupt-map = <0 0 0 1 &pcie_intc1 0>, <0 0 0 2 &pcie_intc1 1>, <0 0 0 3 &pcie_intc1 2>, <0 0 0 4 &pcie_intc1 3>; pcie_intc1: interrupt-controller { interrupt-controller; #address-cells = <0>; #interrupt-cells = <1>; }; }; pcie@11700000 { compatible = "mediatek,mt2712-pcie"; device_type = "pci"; reg = <0 0x11700000 0 0x1000>; reg-names = "port0"; linux,pci-domain = <0>; #address-cells = <3>; #size-cells = <2>; interrupts = ; interrupt-names = "pcie_irq"; clocks = <&topckgen>, /* CLK_TOP_PE2_MAC_P0_SEL */ <&pericfg>; /* CLK_PERI_PCIE0 */ clock-names = "sys_ck0", "ahb_ck0"; phys = <&u3port0 PHY_TYPE_PCIE>; phy-names = "pcie-phy0"; bus-range = <0x00 0xff>; ranges = <0x82000000 0 0x20000000 0x0 0x20000000 0 0x10000000>; #interrupt-cells = <1>; interrupt-map-mask = <0 0 0 7>; interrupt-map = <0 0 0 1 &pcie_intc0 0>, <0 0 0 2 &pcie_intc0 1>, <0 0 0 3 &pcie_intc0 2>, <0 0 0 4 &pcie_intc0 3>; pcie_intc0: interrupt-controller { interrupt-controller; #address-cells = <0>; #interrupt-cells = <1>; }; }; }; # MT7622 - | #include #include #include soc_2 { #address-cells = <2>; #size-cells = <2>; pcie@1a143000 { compatible = "mediatek,mt7622-pcie"; device_type = "pci"; reg = <0 0x1a143000 0 0x1000>; reg-names = "port0"; linux,pci-domain = <0>; #address-cells = <3>; #size-cells = <2>; interrupts = ; interrupt-names = "pcie_irq"; clocks = <&pciesys>, /* CLK_PCIE_P0_MAC_EN */ <&pciesys>, /* CLK_PCIE_P0_AHB_EN */ <&pciesys>, /* CLK_PCIE_P0_AUX_EN */ <&pciesys>, /* CLK_PCIE_P0_AXI_EN */ <&pciesys>, /* CLK_PCIE_P0_OBFF_EN */ <&pciesys>; /* CLK_PCIE_P0_PIPE_EN */ clock-names = "sys_ck0", "ahb_ck0", "aux_ck0", "axi_ck0", "obff_ck0", "pipe_ck0"; power-domains = <&scpsys MT7622_POWER_DOMAIN_HIF0>; bus-range = <0x00 0xff>; ranges = <0x82000000 0 0x20000000 0x0 0x20000000 0 0x8000000>; #interrupt-cells = <1>; interrupt-map-mask = <0 0 0 7>; interrupt-map = <0 0 0 1 &pcie_intc0_1 0>, <0 0 0 2 &pcie_intc0_1 1>, <0 0 0 3 &pcie_intc0_1 2>, <0 0 0 4 &pcie_intc0_1 3>; pcie_intc0_1: interrupt-controller { interrupt-controller; #address-cells = <0>; #interrupt-cells = <1>; }; }; pcie@1a145000 { compatible = "mediatek,mt7622-pcie"; device_type = "pci"; reg = <0 0x1a145000 0 0x1000>; reg-names = "port1"; linux,pci-domain = <1>; #address-cells = <3>; #size-cells = <2>; interrupts = ; interrupt-names = "pcie_irq"; clocks = <&pciesys>, /* CLK_PCIE_P1_MAC_EN */ /* designer has connect RC1 with p0_ahb clock */ <&pciesys>, /* CLK_PCIE_P0_AHB_EN */ <&pciesys>, /* CLK_PCIE_P1_AUX_EN */ <&pciesys>, /* CLK_PCIE_P1_AXI_EN */ <&pciesys>, /* CLK_PCIE_P1_OBFF_EN */ <&pciesys>; /* CLK_PCIE_P1_PIPE_EN */ clock-names = "sys_ck1", "ahb_ck1", "aux_ck1", "axi_ck1", "obff_ck1", "pipe_ck1"; power-domains = <&scpsys MT7622_POWER_DOMAIN_HIF0>; bus-range = <0x00 0xff>; ranges = <0x82000000 0 0x28000000 0x0 0x28000000 0 0x8000000>; #interrupt-cells = <1>; interrupt-map-mask = <0 0 0 7>; interrupt-map = <0 0 0 1 &pcie_intc1_1 0>, <0 0 0 2 &pcie_intc1_1 1>, <0 0 0 3 &pcie_intc1_1 2>, <0 0 0 4 &pcie_intc1_1 3>; pcie_intc1_1: interrupt-controller { interrupt-controller; #address-cells = <0>; #interrupt-cells = <1>; }; }; }; # AN7583 - | #include #include #include soc_3 { #address-cells = <2>; #size-cells = <2>; pcie@1fa92000 { compatible = "airoha,an7583-pcie"; device_type = "pci"; linux,pci-domain = <1>; #address-cells = <3>; #size-cells = <2>; reg = <0x0 0x1fa92000 0x0 0x1670>; reg-names = "port1"; clocks = <&scuclk EN7523_CLK_PCIE>; clock-names = "sys_ck1"; phys = <&pciephy>; phy-names = "pcie-phy1"; ranges = <0x02000000 0 0x24000000 0x0 0x24000000 0 0x4000000>; resets = <&scuclk>; /* AN7583_PCIE1_RST */ reset-names = "pcie-rst1"; mediatek,pbus-csr = <&pbus_csr 0x8 0xc>; interrupts = ; interrupt-names = "pcie_irq"; bus-range = <0x00 0xff>; #interrupt-cells = <1>; interrupt-map-mask = <0 0 0 7>; interrupt-map = <0 0 0 1 &pcie_intc1 0>, <0 0 0 2 &pcie_intc1 1>, <0 0 0 3 &pcie_intc1 2>, <0 0 0 4 &pcie_intc1 3>; pcie_intc1_4: interrupt-controller { interrupt-controller; #address-cells = <0>; #interrupt-cells = <1>; }; }; };