1*0eaa8d1cSKrzysztof Kozlowski# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) 2*0eaa8d1cSKrzysztof Kozlowski%YAML 1.2 3*0eaa8d1cSKrzysztof Kozlowski--- 4*0eaa8d1cSKrzysztof Kozlowski$id: http://devicetree.org/schemas/pci/qcom,pcie-msm8996.yaml# 5*0eaa8d1cSKrzysztof Kozlowski$schema: http://devicetree.org/meta-schemas/core.yaml# 6*0eaa8d1cSKrzysztof Kozlowski 7*0eaa8d1cSKrzysztof Kozlowskititle: Qualcomm MSM8996 PCI Express Root Complex 8*0eaa8d1cSKrzysztof Kozlowski 9*0eaa8d1cSKrzysztof Kozlowskimaintainers: 10*0eaa8d1cSKrzysztof Kozlowski - Bjorn Andersson <andersson@kernel.org> 11*0eaa8d1cSKrzysztof Kozlowski - Manivannan Sadhasivam <mani@kernel.org> 12*0eaa8d1cSKrzysztof Kozlowski 13*0eaa8d1cSKrzysztof Kozlowskiproperties: 14*0eaa8d1cSKrzysztof Kozlowski compatible: 15*0eaa8d1cSKrzysztof Kozlowski oneOf: 16*0eaa8d1cSKrzysztof Kozlowski - enum: 17*0eaa8d1cSKrzysztof Kozlowski - qcom,pcie-msm8996 18*0eaa8d1cSKrzysztof Kozlowski - items: 19*0eaa8d1cSKrzysztof Kozlowski - const: qcom,pcie-msm8998 20*0eaa8d1cSKrzysztof Kozlowski - const: qcom,pcie-msm8996 21*0eaa8d1cSKrzysztof Kozlowski 22*0eaa8d1cSKrzysztof Kozlowski reg: 23*0eaa8d1cSKrzysztof Kozlowski minItems: 4 24*0eaa8d1cSKrzysztof Kozlowski maxItems: 5 25*0eaa8d1cSKrzysztof Kozlowski 26*0eaa8d1cSKrzysztof Kozlowski reg-names: 27*0eaa8d1cSKrzysztof Kozlowski minItems: 4 28*0eaa8d1cSKrzysztof Kozlowski items: 29*0eaa8d1cSKrzysztof Kozlowski - const: parf 30*0eaa8d1cSKrzysztof Kozlowski - const: dbi 31*0eaa8d1cSKrzysztof Kozlowski - const: elbi 32*0eaa8d1cSKrzysztof Kozlowski - const: config 33*0eaa8d1cSKrzysztof Kozlowski - const: mhi 34*0eaa8d1cSKrzysztof Kozlowski 35*0eaa8d1cSKrzysztof Kozlowski clocks: 36*0eaa8d1cSKrzysztof Kozlowski maxItems: 5 37*0eaa8d1cSKrzysztof Kozlowski 38*0eaa8d1cSKrzysztof Kozlowski clock-names: 39*0eaa8d1cSKrzysztof Kozlowski items: 40*0eaa8d1cSKrzysztof Kozlowski - const: pipe # Pipe Clock driving internal logic 41*0eaa8d1cSKrzysztof Kozlowski - const: aux 42*0eaa8d1cSKrzysztof Kozlowski - const: cfg 43*0eaa8d1cSKrzysztof Kozlowski - const: bus_master # Master AXI clock 44*0eaa8d1cSKrzysztof Kozlowski - const: bus_slave # Slave AXI clock 45*0eaa8d1cSKrzysztof Kozlowski 46*0eaa8d1cSKrzysztof Kozlowski interrupts: 47*0eaa8d1cSKrzysztof Kozlowski minItems: 8 48*0eaa8d1cSKrzysztof Kozlowski maxItems: 9 49*0eaa8d1cSKrzysztof Kozlowski 50*0eaa8d1cSKrzysztof Kozlowski interrupt-names: 51*0eaa8d1cSKrzysztof Kozlowski minItems: 8 52*0eaa8d1cSKrzysztof Kozlowski items: 53*0eaa8d1cSKrzysztof Kozlowski - const: msi0 54*0eaa8d1cSKrzysztof Kozlowski - const: msi1 55*0eaa8d1cSKrzysztof Kozlowski - const: msi2 56*0eaa8d1cSKrzysztof Kozlowski - const: msi3 57*0eaa8d1cSKrzysztof Kozlowski - const: msi4 58*0eaa8d1cSKrzysztof Kozlowski - const: msi5 59*0eaa8d1cSKrzysztof Kozlowski - const: msi6 60*0eaa8d1cSKrzysztof Kozlowski - const: msi7 61*0eaa8d1cSKrzysztof Kozlowski - const: global 62*0eaa8d1cSKrzysztof Kozlowski 63*0eaa8d1cSKrzysztof Kozlowski vdda-supply: 64*0eaa8d1cSKrzysztof Kozlowski description: A phandle to the core analog power supply 65*0eaa8d1cSKrzysztof Kozlowski 66*0eaa8d1cSKrzysztof Kozlowski vddpe-3v3-supply: 67*0eaa8d1cSKrzysztof Kozlowski description: A phandle to the PCIe endpoint power supply 68*0eaa8d1cSKrzysztof Kozlowski 69*0eaa8d1cSKrzysztof Kozlowskirequired: 70*0eaa8d1cSKrzysztof Kozlowski - power-domains 71*0eaa8d1cSKrzysztof Kozlowski 72*0eaa8d1cSKrzysztof KozlowskiallOf: 73*0eaa8d1cSKrzysztof Kozlowski - $ref: qcom,pcie-common.yaml# 74*0eaa8d1cSKrzysztof Kozlowski 75*0eaa8d1cSKrzysztof KozlowskiunevaluatedProperties: false 76*0eaa8d1cSKrzysztof Kozlowski 77*0eaa8d1cSKrzysztof Kozlowskiexamples: 78*0eaa8d1cSKrzysztof Kozlowski - | 79*0eaa8d1cSKrzysztof Kozlowski #include <dt-bindings/clock/qcom,gcc-msm8996.h> 80*0eaa8d1cSKrzysztof Kozlowski #include <dt-bindings/gpio/gpio.h> 81*0eaa8d1cSKrzysztof Kozlowski #include <dt-bindings/interrupt-controller/arm-gic.h> 82*0eaa8d1cSKrzysztof Kozlowski 83*0eaa8d1cSKrzysztof Kozlowski pcie@600000 { 84*0eaa8d1cSKrzysztof Kozlowski compatible = "qcom,pcie-msm8996"; 85*0eaa8d1cSKrzysztof Kozlowski reg = <0x00600000 0x2000>, 86*0eaa8d1cSKrzysztof Kozlowski <0x0c000000 0xf1d>, 87*0eaa8d1cSKrzysztof Kozlowski <0x0c000f20 0xa8>, 88*0eaa8d1cSKrzysztof Kozlowski <0x0c100000 0x100000>; 89*0eaa8d1cSKrzysztof Kozlowski reg-names = "parf", "dbi", "elbi", "config"; 90*0eaa8d1cSKrzysztof Kozlowski ranges = <0x01000000 0x0 0x00000000 0x0c200000 0x0 0x100000>, 91*0eaa8d1cSKrzysztof Kozlowski <0x02000000 0x0 0x0c300000 0x0c300000 0x0 0xd00000>; 92*0eaa8d1cSKrzysztof Kozlowski 93*0eaa8d1cSKrzysztof Kozlowski device_type = "pci"; 94*0eaa8d1cSKrzysztof Kozlowski bus-range = <0x00 0xff>; 95*0eaa8d1cSKrzysztof Kozlowski num-lanes = <1>; 96*0eaa8d1cSKrzysztof Kozlowski #address-cells = <3>; 97*0eaa8d1cSKrzysztof Kozlowski #size-cells = <2>; 98*0eaa8d1cSKrzysztof Kozlowski linux,pci-domain = <0>; 99*0eaa8d1cSKrzysztof Kozlowski 100*0eaa8d1cSKrzysztof Kozlowski clocks = <&gcc GCC_PCIE_0_PIPE_CLK>, 101*0eaa8d1cSKrzysztof Kozlowski <&gcc GCC_PCIE_0_AUX_CLK>, 102*0eaa8d1cSKrzysztof Kozlowski <&gcc GCC_PCIE_0_CFG_AHB_CLK>, 103*0eaa8d1cSKrzysztof Kozlowski <&gcc GCC_PCIE_0_MSTR_AXI_CLK>, 104*0eaa8d1cSKrzysztof Kozlowski <&gcc GCC_PCIE_0_SLV_AXI_CLK>; 105*0eaa8d1cSKrzysztof Kozlowski clock-names = "pipe", 106*0eaa8d1cSKrzysztof Kozlowski "aux", 107*0eaa8d1cSKrzysztof Kozlowski "cfg", 108*0eaa8d1cSKrzysztof Kozlowski "bus_master", 109*0eaa8d1cSKrzysztof Kozlowski "bus_slave"; 110*0eaa8d1cSKrzysztof Kozlowski 111*0eaa8d1cSKrzysztof Kozlowski interrupts = <GIC_SPI 405 IRQ_TYPE_LEVEL_HIGH>, 112*0eaa8d1cSKrzysztof Kozlowski <GIC_SPI 406 IRQ_TYPE_LEVEL_HIGH>, 113*0eaa8d1cSKrzysztof Kozlowski <GIC_SPI 407 IRQ_TYPE_LEVEL_HIGH>, 114*0eaa8d1cSKrzysztof Kozlowski <GIC_SPI 408 IRQ_TYPE_LEVEL_HIGH>, 115*0eaa8d1cSKrzysztof Kozlowski <GIC_SPI 409 IRQ_TYPE_LEVEL_HIGH>, 116*0eaa8d1cSKrzysztof Kozlowski <GIC_SPI 410 IRQ_TYPE_LEVEL_HIGH>, 117*0eaa8d1cSKrzysztof Kozlowski <GIC_SPI 411 IRQ_TYPE_LEVEL_HIGH>, 118*0eaa8d1cSKrzysztof Kozlowski <GIC_SPI 412 IRQ_TYPE_LEVEL_HIGH>; 119*0eaa8d1cSKrzysztof Kozlowski interrupt-names = "msi0", 120*0eaa8d1cSKrzysztof Kozlowski "msi1", 121*0eaa8d1cSKrzysztof Kozlowski "msi2", 122*0eaa8d1cSKrzysztof Kozlowski "msi3", 123*0eaa8d1cSKrzysztof Kozlowski "msi4", 124*0eaa8d1cSKrzysztof Kozlowski "msi5", 125*0eaa8d1cSKrzysztof Kozlowski "msi6", 126*0eaa8d1cSKrzysztof Kozlowski "msi7"; 127*0eaa8d1cSKrzysztof Kozlowski #interrupt-cells = <1>; 128*0eaa8d1cSKrzysztof Kozlowski interrupt-map-mask = <0 0 0 0x7>; 129*0eaa8d1cSKrzysztof Kozlowski interrupt-map = <0 0 0 1 &intc GIC_SPI 244 IRQ_TYPE_LEVEL_HIGH>, /* int_a */ 130*0eaa8d1cSKrzysztof Kozlowski <0 0 0 2 &intc GIC_SPI 245 IRQ_TYPE_LEVEL_HIGH>, /* int_b */ 131*0eaa8d1cSKrzysztof Kozlowski <0 0 0 3 &intc GIC_SPI 247 IRQ_TYPE_LEVEL_HIGH>, /* int_c */ 132*0eaa8d1cSKrzysztof Kozlowski <0 0 0 4 &intc GIC_SPI 248 IRQ_TYPE_LEVEL_HIGH>; /* int_d */ 133*0eaa8d1cSKrzysztof Kozlowski 134*0eaa8d1cSKrzysztof Kozlowski pinctrl-names = "default", "sleep"; 135*0eaa8d1cSKrzysztof Kozlowski pinctrl-0 = <&pcie0_state_on>; 136*0eaa8d1cSKrzysztof Kozlowski pinctrl-1 = <&pcie0_state_off>; 137*0eaa8d1cSKrzysztof Kozlowski 138*0eaa8d1cSKrzysztof Kozlowski phys = <&pciephy_0>; 139*0eaa8d1cSKrzysztof Kozlowski phy-names = "pciephy"; 140*0eaa8d1cSKrzysztof Kozlowski 141*0eaa8d1cSKrzysztof Kozlowski power-domains = <&gcc PCIE0_GDSC>; 142*0eaa8d1cSKrzysztof Kozlowski 143*0eaa8d1cSKrzysztof Kozlowski perst-gpios = <&tlmm 35 GPIO_ACTIVE_LOW>; 144*0eaa8d1cSKrzysztof Kozlowski vddpe-3v3-supply = <&wlan_en>; 145*0eaa8d1cSKrzysztof Kozlowski vdda-supply = <&vreg_l28a_0p925>; 146*0eaa8d1cSKrzysztof Kozlowski 147*0eaa8d1cSKrzysztof Kozlowski pcie@0 { 148*0eaa8d1cSKrzysztof Kozlowski device_type = "pci"; 149*0eaa8d1cSKrzysztof Kozlowski reg = <0x0 0x0 0x0 0x0 0x0>; 150*0eaa8d1cSKrzysztof Kozlowski bus-range = <0x01 0xff>; 151*0eaa8d1cSKrzysztof Kozlowski 152*0eaa8d1cSKrzysztof Kozlowski #address-cells = <3>; 153*0eaa8d1cSKrzysztof Kozlowski #size-cells = <2>; 154*0eaa8d1cSKrzysztof Kozlowski ranges; 155*0eaa8d1cSKrzysztof Kozlowski }; 156*0eaa8d1cSKrzysztof Kozlowski }; 157