mirror of
https://github.com/torvalds/linux.git
synced 2026-04-18 06:44:00 -04:00
Introduce Airoha AN7583 SoC compatible in mediatek PCIe controller binding. Similar to GEN3, the Airoha AN7583 GEN2 PCIe controller require the PBUS csr property to permit the correct functionality of the PCIe controller. Signed-off-by: Christian Marangi <ansuelsmth@gmail.com> Signed-off-by: Manivannan Sadhasivam <mani@kernel.org> Reviewed-by: Rob Herring (Arm) <robh@kernel.org> Link: https://patch.msgid.link/20251020111121.31779-3-ansuelsmth@gmail.com
439 lines
11 KiB
YAML
439 lines
11 KiB
YAML
# 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 <ansuelsmth@gmail.com>
|
|
|
|
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 <dt-bindings/interrupt-controller/arm-gic.h>
|
|
#include <dt-bindings/interrupt-controller/irq.h>
|
|
#include <dt-bindings/phy/phy.h>
|
|
|
|
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 = <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>;
|
|
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 = <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>;
|
|
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 <dt-bindings/interrupt-controller/arm-gic.h>
|
|
#include <dt-bindings/interrupt-controller/irq.h>
|
|
#include <dt-bindings/power/mt7622-power.h>
|
|
|
|
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 = <GIC_SPI 228 IRQ_TYPE_LEVEL_LOW>;
|
|
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 = <GIC_SPI 229 IRQ_TYPE_LEVEL_LOW>;
|
|
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 <dt-bindings/interrupt-controller/irq.h>
|
|
#include <dt-bindings/interrupt-controller/arm-gic.h>
|
|
#include <dt-bindings/clock/en7523-clk.h>
|
|
|
|
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 = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>;
|
|
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>;
|
|
};
|
|
};
|
|
};
|