| // SPDX-License-Identifier: GPL-2.0 |
| /dts-v1/; |
| |
| #include <dt-bindings/clock/qcom,gcc-msm8960.h> |
| #include <dt-bindings/reset/qcom,gcc-msm8960.h> |
| #include <dt-bindings/clock/qcom,mmcc-msm8960.h> |
| #include <dt-bindings/clock/qcom,rpmcc.h> |
| #include <dt-bindings/soc/qcom,gsbi.h> |
| #include <dt-bindings/interrupt-controller/irq.h> |
| #include <dt-bindings/interrupt-controller/arm-gic.h> |
| / { |
| #address-cells = <1>; |
| #size-cells = <1>; |
| model = "Qualcomm APQ8064"; |
| compatible = "qcom,apq8064"; |
| interrupt-parent = <&intc>; |
| |
| reserved-memory { |
| #address-cells = <1>; |
| #size-cells = <1>; |
| ranges; |
| |
| smem_region: smem@80000000 { |
| reg = <0x80000000 0x200000>; |
| no-map; |
| }; |
| |
| wcnss_mem: wcnss@8f000000 { |
| reg = <0x8f000000 0x700000>; |
| no-map; |
| }; |
| }; |
| |
| cpus { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| CPU0: cpu@0 { |
| compatible = "qcom,krait"; |
| enable-method = "qcom,kpss-acc-v1"; |
| device_type = "cpu"; |
| reg = <0>; |
| next-level-cache = <&L2>; |
| qcom,acc = <&acc0>; |
| qcom,saw = <&saw0>; |
| cpu-idle-states = <&CPU_SPC>; |
| }; |
| |
| CPU1: cpu@1 { |
| compatible = "qcom,krait"; |
| enable-method = "qcom,kpss-acc-v1"; |
| device_type = "cpu"; |
| reg = <1>; |
| next-level-cache = <&L2>; |
| qcom,acc = <&acc1>; |
| qcom,saw = <&saw1>; |
| cpu-idle-states = <&CPU_SPC>; |
| }; |
| |
| CPU2: cpu@2 { |
| compatible = "qcom,krait"; |
| enable-method = "qcom,kpss-acc-v1"; |
| device_type = "cpu"; |
| reg = <2>; |
| next-level-cache = <&L2>; |
| qcom,acc = <&acc2>; |
| qcom,saw = <&saw2>; |
| cpu-idle-states = <&CPU_SPC>; |
| }; |
| |
| CPU3: cpu@3 { |
| compatible = "qcom,krait"; |
| enable-method = "qcom,kpss-acc-v1"; |
| device_type = "cpu"; |
| reg = <3>; |
| next-level-cache = <&L2>; |
| qcom,acc = <&acc3>; |
| qcom,saw = <&saw3>; |
| cpu-idle-states = <&CPU_SPC>; |
| }; |
| |
| L2: l2-cache { |
| compatible = "cache"; |
| cache-level = <2>; |
| }; |
| |
| idle-states { |
| CPU_SPC: spc { |
| compatible = "qcom,idle-state-spc", |
| "arm,idle-state"; |
| entry-latency-us = <400>; |
| exit-latency-us = <900>; |
| min-residency-us = <3000>; |
| }; |
| }; |
| }; |
| |
| memory { |
| device_type = "memory"; |
| reg = <0x0 0x0>; |
| }; |
| |
| thermal-zones { |
| cpu-thermal0 { |
| polling-delay-passive = <250>; |
| polling-delay = <1000>; |
| |
| thermal-sensors = <&gcc 7>; |
| coefficients = <1199 0>; |
| |
| trips { |
| cpu_alert0: trip0 { |
| temperature = <75000>; |
| hysteresis = <2000>; |
| type = "passive"; |
| }; |
| cpu_crit0: trip1 { |
| temperature = <110000>; |
| hysteresis = <2000>; |
| type = "critical"; |
| }; |
| }; |
| }; |
| |
| cpu-thermal1 { |
| polling-delay-passive = <250>; |
| polling-delay = <1000>; |
| |
| thermal-sensors = <&gcc 8>; |
| coefficients = <1132 0>; |
| |
| trips { |
| cpu_alert1: trip0 { |
| temperature = <75000>; |
| hysteresis = <2000>; |
| type = "passive"; |
| }; |
| cpu_crit1: trip1 { |
| temperature = <110000>; |
| hysteresis = <2000>; |
| type = "critical"; |
| }; |
| }; |
| }; |
| |
| cpu-thermal2 { |
| polling-delay-passive = <250>; |
| polling-delay = <1000>; |
| |
| thermal-sensors = <&gcc 9>; |
| coefficients = <1199 0>; |
| |
| trips { |
| cpu_alert2: trip0 { |
| temperature = <75000>; |
| hysteresis = <2000>; |
| type = "passive"; |
| }; |
| cpu_crit2: trip1 { |
| temperature = <110000>; |
| hysteresis = <2000>; |
| type = "critical"; |
| }; |
| }; |
| }; |
| |
| cpu-thermal3 { |
| polling-delay-passive = <250>; |
| polling-delay = <1000>; |
| |
| thermal-sensors = <&gcc 10>; |
| coefficients = <1132 0>; |
| |
| trips { |
| cpu_alert3: trip0 { |
| temperature = <75000>; |
| hysteresis = <2000>; |
| type = "passive"; |
| }; |
| cpu_crit3: trip1 { |
| temperature = <110000>; |
| hysteresis = <2000>; |
| type = "critical"; |
| }; |
| }; |
| }; |
| }; |
| |
| cpu-pmu { |
| compatible = "qcom,krait-pmu"; |
| interrupts = <1 10 0x304>; |
| }; |
| |
| clocks { |
| cxo_board: cxo_board { |
| compatible = "fixed-clock"; |
| #clock-cells = <0>; |
| clock-frequency = <19200000>; |
| }; |
| |
| pxo_board { |
| compatible = "fixed-clock"; |
| #clock-cells = <0>; |
| clock-frequency = <27000000>; |
| }; |
| |
| sleep_clk: sleep_clk { |
| compatible = "fixed-clock"; |
| #clock-cells = <0>; |
| clock-frequency = <32768>; |
| }; |
| }; |
| |
| sfpb_mutex: hwmutex { |
| compatible = "qcom,sfpb-mutex"; |
| syscon = <&sfpb_wrapper_mutex 0x604 0x4>; |
| #hwlock-cells = <1>; |
| }; |
| |
| smem { |
| compatible = "qcom,smem"; |
| memory-region = <&smem_region>; |
| |
| hwlocks = <&sfpb_mutex 3>; |
| }; |
| |
| smd { |
| compatible = "qcom,smd"; |
| |
| modem@0 { |
| interrupts = <0 37 IRQ_TYPE_EDGE_RISING>; |
| |
| qcom,ipc = <&l2cc 8 3>; |
| qcom,smd-edge = <0>; |
| |
| status = "disabled"; |
| }; |
| |
| q6@1 { |
| interrupts = <0 90 IRQ_TYPE_EDGE_RISING>; |
| |
| qcom,ipc = <&l2cc 8 15>; |
| qcom,smd-edge = <1>; |
| |
| status = "disabled"; |
| }; |
| |
| dsps@3 { |
| interrupts = <0 138 IRQ_TYPE_EDGE_RISING>; |
| |
| qcom,ipc = <&sps_sic_non_secure 0x4080 0>; |
| qcom,smd-edge = <3>; |
| |
| status = "disabled"; |
| }; |
| |
| riva@6 { |
| interrupts = <0 198 IRQ_TYPE_EDGE_RISING>; |
| |
| qcom,ipc = <&l2cc 8 25>; |
| qcom,smd-edge = <6>; |
| |
| status = "disabled"; |
| }; |
| }; |
| |
| smsm { |
| compatible = "qcom,smsm"; |
| |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| qcom,ipc-1 = <&l2cc 8 4>; |
| qcom,ipc-2 = <&l2cc 8 14>; |
| qcom,ipc-3 = <&l2cc 8 23>; |
| qcom,ipc-4 = <&sps_sic_non_secure 0x4094 0>; |
| |
| apps_smsm: apps@0 { |
| reg = <0>; |
| #qcom,smem-state-cells = <1>; |
| }; |
| |
| modem_smsm: modem@1 { |
| reg = <1>; |
| interrupts = <0 38 IRQ_TYPE_EDGE_RISING>; |
| |
| interrupt-controller; |
| #interrupt-cells = <2>; |
| }; |
| |
| q6_smsm: q6@2 { |
| reg = <2>; |
| interrupts = <0 89 IRQ_TYPE_EDGE_RISING>; |
| |
| interrupt-controller; |
| #interrupt-cells = <2>; |
| }; |
| |
| wcnss_smsm: wcnss@3 { |
| reg = <3>; |
| interrupts = <0 204 IRQ_TYPE_EDGE_RISING>; |
| |
| interrupt-controller; |
| #interrupt-cells = <2>; |
| }; |
| |
| dsps_smsm: dsps@4 { |
| reg = <4>; |
| interrupts = <0 137 IRQ_TYPE_EDGE_RISING>; |
| |
| interrupt-controller; |
| #interrupt-cells = <2>; |
| }; |
| }; |
| |
| firmware { |
| scm { |
| compatible = "qcom,scm-apq8064"; |
| |
| clocks = <&rpmcc RPM_DAYTONA_FABRIC_CLK>; |
| clock-names = "core"; |
| }; |
| }; |
| |
| |
| /* |
| * These channels from the ADC are simply hardware monitors. |
| * That is why the ADC is referred to as "HKADC" - HouseKeeping |
| * ADC. |
| */ |
| iio-hwmon { |
| compatible = "iio-hwmon"; |
| io-channels = <&xoadc 0x00 0x01>, /* Battery */ |
| <&xoadc 0x00 0x02>, /* DC in (charger) */ |
| <&xoadc 0x00 0x04>, /* VPH the main system voltage */ |
| <&xoadc 0x00 0x0b>, /* Die temperature */ |
| <&xoadc 0x00 0x0c>, /* Reference voltage 1.25V */ |
| <&xoadc 0x00 0x0d>, /* Reference voltage 0.625V */ |
| <&xoadc 0x00 0x0e>; /* Charger temperature */ |
| }; |
| |
| soc: soc { |
| #address-cells = <1>; |
| #size-cells = <1>; |
| ranges; |
| compatible = "simple-bus"; |
| |
| tlmm_pinmux: pinctrl@800000 { |
| compatible = "qcom,apq8064-pinctrl"; |
| reg = <0x800000 0x4000>; |
| |
| gpio-controller; |
| #gpio-cells = <2>; |
| interrupt-controller; |
| #interrupt-cells = <2>; |
| interrupts = <0 16 IRQ_TYPE_LEVEL_HIGH>; |
| |
| pinctrl-names = "default"; |
| pinctrl-0 = <&ps_hold>; |
| }; |
| |
| sfpb_wrapper_mutex: syscon@1200000 { |
| compatible = "syscon"; |
| reg = <0x01200000 0x8000>; |
| }; |
| |
| intc: interrupt-controller@2000000 { |
| compatible = "qcom,msm-qgic2"; |
| interrupt-controller; |
| #interrupt-cells = <3>; |
| reg = <0x02000000 0x1000>, |
| <0x02002000 0x1000>; |
| }; |
| |
| timer@200a000 { |
| compatible = "qcom,kpss-timer", |
| "qcom,kpss-wdt-apq8064", "qcom,msm-timer"; |
| interrupts = <1 1 0x301>, |
| <1 2 0x301>, |
| <1 3 0x301>; |
| reg = <0x0200a000 0x100>; |
| clock-frequency = <27000000>, |
| <32768>; |
| cpu-offset = <0x80000>; |
| }; |
| |
| acc0: clock-controller@2088000 { |
| compatible = "qcom,kpss-acc-v1"; |
| reg = <0x02088000 0x1000>, <0x02008000 0x1000>; |
| }; |
| |
| acc1: clock-controller@2098000 { |
| compatible = "qcom,kpss-acc-v1"; |
| reg = <0x02098000 0x1000>, <0x02008000 0x1000>; |
| }; |
| |
| acc2: clock-controller@20a8000 { |
| compatible = "qcom,kpss-acc-v1"; |
| reg = <0x020a8000 0x1000>, <0x02008000 0x1000>; |
| }; |
| |
| acc3: clock-controller@20b8000 { |
| compatible = "qcom,kpss-acc-v1"; |
| reg = <0x020b8000 0x1000>, <0x02008000 0x1000>; |
| }; |
| |
| saw0: power-controller@2089000 { |
| compatible = "qcom,apq8064-saw2-v1.1-cpu", "qcom,saw2"; |
| reg = <0x02089000 0x1000>, <0x02009000 0x1000>; |
| regulator; |
| }; |
| |
| saw1: power-controller@2099000 { |
| compatible = "qcom,apq8064-saw2-v1.1-cpu", "qcom,saw2"; |
| reg = <0x02099000 0x1000>, <0x02009000 0x1000>; |
| regulator; |
| }; |
| |
| saw2: power-controller@20a9000 { |
| compatible = "qcom,apq8064-saw2-v1.1-cpu", "qcom,saw2"; |
| reg = <0x020a9000 0x1000>, <0x02009000 0x1000>; |
| regulator; |
| }; |
| |
| saw3: power-controller@20b9000 { |
| compatible = "qcom,apq8064-saw2-v1.1-cpu", "qcom,saw2"; |
| reg = <0x020b9000 0x1000>, <0x02009000 0x1000>; |
| regulator; |
| }; |
| |
| sps_sic_non_secure: sps-sic-non-secure@12100000 { |
| compatible = "syscon"; |
| reg = <0x12100000 0x10000>; |
| }; |
| |
| gsbi1: gsbi@12440000 { |
| status = "disabled"; |
| compatible = "qcom,gsbi-v1.0.0"; |
| cell-index = <1>; |
| reg = <0x12440000 0x100>; |
| clocks = <&gcc GSBI1_H_CLK>; |
| clock-names = "iface"; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| ranges; |
| |
| syscon-tcsr = <&tcsr>; |
| |
| gsbi1_serial: serial@12450000 { |
| compatible = "qcom,msm-uartdm-v1.3", "qcom,msm-uartdm"; |
| reg = <0x12450000 0x100>, |
| <0x12400000 0x03>; |
| interrupts = <0 193 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc GSBI1_UART_CLK>, <&gcc GSBI1_H_CLK>; |
| clock-names = "core", "iface"; |
| status = "disabled"; |
| }; |
| |
| gsbi1_i2c: i2c@12460000 { |
| compatible = "qcom,i2c-qup-v1.1.1"; |
| pinctrl-0 = <&i2c1_pins>; |
| pinctrl-1 = <&i2c1_pins_sleep>; |
| pinctrl-names = "default", "sleep"; |
| reg = <0x12460000 0x1000>; |
| interrupts = <0 194 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc GSBI1_QUP_CLK>, <&gcc GSBI1_H_CLK>; |
| clock-names = "core", "iface"; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| status = "disabled"; |
| }; |
| |
| }; |
| |
| gsbi2: gsbi@12480000 { |
| status = "disabled"; |
| compatible = "qcom,gsbi-v1.0.0"; |
| cell-index = <2>; |
| reg = <0x12480000 0x100>; |
| clocks = <&gcc GSBI2_H_CLK>; |
| clock-names = "iface"; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| ranges; |
| |
| syscon-tcsr = <&tcsr>; |
| |
| gsbi2_i2c: i2c@124a0000 { |
| compatible = "qcom,i2c-qup-v1.1.1"; |
| reg = <0x124a0000 0x1000>; |
| pinctrl-0 = <&i2c2_pins>; |
| pinctrl-1 = <&i2c2_pins_sleep>; |
| pinctrl-names = "default", "sleep"; |
| interrupts = <0 196 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc GSBI2_QUP_CLK>, <&gcc GSBI2_H_CLK>; |
| clock-names = "core", "iface"; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| status = "disabled"; |
| }; |
| }; |
| |
| gsbi3: gsbi@16200000 { |
| status = "disabled"; |
| compatible = "qcom,gsbi-v1.0.0"; |
| cell-index = <3>; |
| reg = <0x16200000 0x100>; |
| clocks = <&gcc GSBI3_H_CLK>; |
| clock-names = "iface"; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| ranges; |
| gsbi3_i2c: i2c@16280000 { |
| compatible = "qcom,i2c-qup-v1.1.1"; |
| pinctrl-0 = <&i2c3_pins>; |
| pinctrl-1 = <&i2c3_pins_sleep>; |
| pinctrl-names = "default", "sleep"; |
| reg = <0x16280000 0x1000>; |
| interrupts = <GIC_SPI 151 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc GSBI3_QUP_CLK>, |
| <&gcc GSBI3_H_CLK>; |
| clock-names = "core", "iface"; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| status = "disabled"; |
| }; |
| }; |
| |
| gsbi4: gsbi@16300000 { |
| status = "disabled"; |
| compatible = "qcom,gsbi-v1.0.0"; |
| cell-index = <4>; |
| reg = <0x16300000 0x03>; |
| clocks = <&gcc GSBI4_H_CLK>; |
| clock-names = "iface"; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| ranges; |
| |
| gsbi4_i2c: i2c@16380000 { |
| compatible = "qcom,i2c-qup-v1.1.1"; |
| pinctrl-0 = <&i2c4_pins>; |
| pinctrl-1 = <&i2c4_pins_sleep>; |
| pinctrl-names = "default", "sleep"; |
| reg = <0x16380000 0x1000>; |
| interrupts = <GIC_SPI 153 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc GSBI4_QUP_CLK>, |
| <&gcc GSBI4_H_CLK>; |
| clock-names = "core", "iface"; |
| status = "disabled"; |
| }; |
| }; |
| |
| gsbi5: gsbi@1a200000 { |
| status = "disabled"; |
| compatible = "qcom,gsbi-v1.0.0"; |
| cell-index = <5>; |
| reg = <0x1a200000 0x03>; |
| clocks = <&gcc GSBI5_H_CLK>; |
| clock-names = "iface"; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| ranges; |
| |
| gsbi5_serial: serial@1a240000 { |
| compatible = "qcom,msm-uartdm-v1.3", "qcom,msm-uartdm"; |
| reg = <0x1a240000 0x100>, |
| <0x1a200000 0x03>; |
| interrupts = <0 154 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc GSBI5_UART_CLK>, <&gcc GSBI5_H_CLK>; |
| clock-names = "core", "iface"; |
| status = "disabled"; |
| }; |
| |
| gsbi5_spi: spi@1a280000 { |
| compatible = "qcom,spi-qup-v1.1.1"; |
| reg = <0x1a280000 0x1000>; |
| interrupts = <0 155 IRQ_TYPE_LEVEL_HIGH>; |
| pinctrl-0 = <&spi5_default>; |
| pinctrl-1 = <&spi5_sleep>; |
| pinctrl-names = "default", "sleep"; |
| clocks = <&gcc GSBI5_QUP_CLK>, <&gcc GSBI5_H_CLK>; |
| clock-names = "core", "iface"; |
| status = "disabled"; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| }; |
| }; |
| |
| gsbi6: gsbi@16500000 { |
| status = "disabled"; |
| compatible = "qcom,gsbi-v1.0.0"; |
| cell-index = <6>; |
| reg = <0x16500000 0x03>; |
| clocks = <&gcc GSBI6_H_CLK>; |
| clock-names = "iface"; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| ranges; |
| |
| gsbi6_serial: serial@16540000 { |
| compatible = "qcom,msm-uartdm-v1.3", "qcom,msm-uartdm"; |
| reg = <0x16540000 0x100>, |
| <0x16500000 0x03>; |
| interrupts = <0 156 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc GSBI6_UART_CLK>, <&gcc GSBI6_H_CLK>; |
| clock-names = "core", "iface"; |
| status = "disabled"; |
| }; |
| |
| gsbi6_i2c: i2c@16580000 { |
| compatible = "qcom,i2c-qup-v1.1.1"; |
| pinctrl-0 = <&i2c6_pins>; |
| pinctrl-1 = <&i2c6_pins_sleep>; |
| pinctrl-names = "default", "sleep"; |
| reg = <0x16580000 0x1000>; |
| interrupts = <GIC_SPI 157 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc GSBI6_QUP_CLK>, |
| <&gcc GSBI6_H_CLK>; |
| clock-names = "core", "iface"; |
| status = "disabled"; |
| }; |
| }; |
| |
| gsbi7: gsbi@16600000 { |
| status = "disabled"; |
| compatible = "qcom,gsbi-v1.0.0"; |
| cell-index = <7>; |
| reg = <0x16600000 0x100>; |
| clocks = <&gcc GSBI7_H_CLK>; |
| clock-names = "iface"; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| ranges; |
| syscon-tcsr = <&tcsr>; |
| |
| gsbi7_serial: serial@16640000 { |
| compatible = "qcom,msm-uartdm-v1.3", "qcom,msm-uartdm"; |
| reg = <0x16640000 0x1000>, |
| <0x16600000 0x1000>; |
| interrupts = <0 158 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc GSBI7_UART_CLK>, <&gcc GSBI7_H_CLK>; |
| clock-names = "core", "iface"; |
| status = "disabled"; |
| }; |
| |
| gsbi7_i2c: i2c@16680000 { |
| compatible = "qcom,i2c-qup-v1.1.1"; |
| pinctrl-0 = <&i2c7_pins>; |
| pinctrl-1 = <&i2c7_pins_sleep>; |
| pinctrl-names = "default", "sleep"; |
| reg = <0x16680000 0x1000>; |
| interrupts = <GIC_SPI 159 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc GSBI7_QUP_CLK>, |
| <&gcc GSBI7_H_CLK>; |
| clock-names = "core", "iface"; |
| status = "disabled"; |
| }; |
| }; |
| |
| rng@1a500000 { |
| compatible = "qcom,prng"; |
| reg = <0x1a500000 0x200>; |
| clocks = <&gcc PRNG_CLK>; |
| clock-names = "core"; |
| }; |
| |
| ssbi@c00000 { |
| compatible = "qcom,ssbi"; |
| reg = <0x00c00000 0x1000>; |
| qcom,controller-type = "pmic-arbiter"; |
| |
| pm8821: pmic@1 { |
| compatible = "qcom,pm8821"; |
| interrupt-parent = <&tlmm_pinmux>; |
| interrupts = <76 IRQ_TYPE_LEVEL_LOW>; |
| #interrupt-cells = <2>; |
| interrupt-controller; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| pm8821_mpps: mpps@50 { |
| compatible = "qcom,pm8821-mpp", "qcom,ssbi-mpp"; |
| reg = <0x50>; |
| interrupts = <24 IRQ_TYPE_NONE>, |
| <25 IRQ_TYPE_NONE>, |
| <26 IRQ_TYPE_NONE>, |
| <27 IRQ_TYPE_NONE>; |
| gpio-controller; |
| #gpio-cells = <2>; |
| }; |
| }; |
| }; |
| |
| qcom,ssbi@500000 { |
| compatible = "qcom,ssbi"; |
| reg = <0x00500000 0x1000>; |
| qcom,controller-type = "pmic-arbiter"; |
| |
| pmicintc: pmic@0 { |
| compatible = "qcom,pm8921"; |
| interrupt-parent = <&tlmm_pinmux>; |
| interrupts = <74 8>; |
| #interrupt-cells = <2>; |
| interrupt-controller; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| pm8921_gpio: gpio@150 { |
| |
| compatible = "qcom,pm8921-gpio", |
| "qcom,ssbi-gpio"; |
| reg = <0x150>; |
| interrupt-controller; |
| #interrupt-cells = <2>; |
| gpio-controller; |
| gpio-ranges = <&pm8921_gpio 0 0 44>; |
| #gpio-cells = <2>; |
| |
| }; |
| |
| pm8921_mpps: mpps@50 { |
| compatible = "qcom,pm8921-mpp", |
| "qcom,ssbi-mpp"; |
| reg = <0x50>; |
| gpio-controller; |
| #gpio-cells = <2>; |
| interrupts = |
| <128 IRQ_TYPE_NONE>, |
| <129 IRQ_TYPE_NONE>, |
| <130 IRQ_TYPE_NONE>, |
| <131 IRQ_TYPE_NONE>, |
| <132 IRQ_TYPE_NONE>, |
| <133 IRQ_TYPE_NONE>, |
| <134 IRQ_TYPE_NONE>, |
| <135 IRQ_TYPE_NONE>, |
| <136 IRQ_TYPE_NONE>, |
| <137 IRQ_TYPE_NONE>, |
| <138 IRQ_TYPE_NONE>, |
| <139 IRQ_TYPE_NONE>; |
| }; |
| |
| rtc@11d { |
| compatible = "qcom,pm8921-rtc"; |
| interrupt-parent = <&pmicintc>; |
| interrupts = <39 1>; |
| reg = <0x11d>; |
| allow-set-time; |
| }; |
| |
| pwrkey@1c { |
| compatible = "qcom,pm8921-pwrkey"; |
| reg = <0x1c>; |
| interrupt-parent = <&pmicintc>; |
| interrupts = <50 1>, <51 1>; |
| debounce = <15625>; |
| pull-up; |
| }; |
| |
| xoadc: xoadc@197 { |
| compatible = "qcom,pm8921-adc"; |
| reg = <197>; |
| interrupts-extended = <&pmicintc 78 IRQ_TYPE_EDGE_RISING>; |
| #address-cells = <2>; |
| #size-cells = <0>; |
| #io-channel-cells = <2>; |
| |
| vcoin: adc-channel@00 { |
| reg = <0x00 0x00>; |
| }; |
| vbat: adc-channel@01 { |
| reg = <0x00 0x01>; |
| }; |
| dcin: adc-channel@02 { |
| reg = <0x00 0x02>; |
| }; |
| vph_pwr: adc-channel@04 { |
| reg = <0x00 0x04>; |
| }; |
| batt_therm: adc-channel@08 { |
| reg = <0x00 0x08>; |
| }; |
| batt_id: adc-channel@09 { |
| reg = <0x00 0x09>; |
| }; |
| usb_vbus: adc-channel@0a { |
| reg = <0x00 0x0a>; |
| }; |
| die_temp: adc-channel@0b { |
| reg = <0x00 0x0b>; |
| }; |
| ref_625mv: adc-channel@0c { |
| reg = <0x00 0x0c>; |
| }; |
| ref_1250mv: adc-channel@0d { |
| reg = <0x00 0x0d>; |
| }; |
| chg_temp: adc-channel@0e { |
| reg = <0x00 0x0e>; |
| }; |
| ref_muxoff: adc-channel@0f { |
| reg = <0x00 0x0f>; |
| }; |
| }; |
| }; |
| }; |
| |
| qfprom: qfprom@700000 { |
| compatible = "qcom,qfprom"; |
| reg = <0x00700000 0x1000>; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| ranges; |
| tsens_calib: calib { |
| reg = <0x404 0x10>; |
| }; |
| tsens_backup: backup_calib { |
| reg = <0x414 0x10>; |
| }; |
| }; |
| |
| gcc: clock-controller@900000 { |
| compatible = "qcom,gcc-apq8064"; |
| reg = <0x00900000 0x4000>; |
| nvmem-cells = <&tsens_calib>, <&tsens_backup>; |
| nvmem-cell-names = "calib", "calib_backup"; |
| #clock-cells = <1>; |
| #reset-cells = <1>; |
| #thermal-sensor-cells = <1>; |
| }; |
| |
| lcc: clock-controller@28000000 { |
| compatible = "qcom,lcc-apq8064"; |
| reg = <0x28000000 0x1000>; |
| #clock-cells = <1>; |
| #reset-cells = <1>; |
| }; |
| |
| mmcc: clock-controller@4000000 { |
| compatible = "qcom,mmcc-apq8064"; |
| reg = <0x4000000 0x1000>; |
| #clock-cells = <1>; |
| #reset-cells = <1>; |
| }; |
| |
| l2cc: clock-controller@2011000 { |
| compatible = "syscon"; |
| reg = <0x2011000 0x1000>; |
| }; |
| |
| rpm@108000 { |
| compatible = "qcom,rpm-apq8064"; |
| reg = <0x108000 0x1000>; |
| qcom,ipc = <&l2cc 0x8 2>; |
| |
| interrupts = <GIC_SPI 19 IRQ_TYPE_EDGE_RISING>, |
| <GIC_SPI 21 IRQ_TYPE_EDGE_RISING>, |
| <GIC_SPI 22 IRQ_TYPE_EDGE_RISING>; |
| interrupt-names = "ack", "err", "wakeup"; |
| |
| rpmcc: clock-controller { |
| compatible = "qcom,rpmcc-apq8064", "qcom,rpmcc"; |
| #clock-cells = <1>; |
| }; |
| |
| regulators { |
| compatible = "qcom,rpm-pm8921-regulators"; |
| |
| pm8921_s1: s1 {}; |
| pm8921_s2: s2 {}; |
| pm8921_s3: s3 {}; |
| pm8921_s4: s4 {}; |
| pm8921_s7: s7 {}; |
| pm8921_s8: s8 {}; |
| |
| pm8921_l1: l1 {}; |
| pm8921_l2: l2 {}; |
| pm8921_l3: l3 {}; |
| pm8921_l4: l4 {}; |
| pm8921_l5: l5 {}; |
| pm8921_l6: l6 {}; |
| pm8921_l7: l7 {}; |
| pm8921_l8: l8 {}; |
| pm8921_l9: l9 {}; |
| pm8921_l10: l10 {}; |
| pm8921_l11: l11 {}; |
| pm8921_l12: l12 {}; |
| pm8921_l14: l14 {}; |
| pm8921_l15: l15 {}; |
| pm8921_l16: l16 {}; |
| pm8921_l17: l17 {}; |
| pm8921_l18: l18 {}; |
| pm8921_l21: l21 {}; |
| pm8921_l22: l22 {}; |
| pm8921_l23: l23 {}; |
| pm8921_l24: l24 {}; |
| pm8921_l25: l25 {}; |
| pm8921_l26: l26 {}; |
| pm8921_l27: l27 {}; |
| pm8921_l28: l28 {}; |
| pm8921_l29: l29 {}; |
| |
| pm8921_lvs1: lvs1 {}; |
| pm8921_lvs2: lvs2 {}; |
| pm8921_lvs3: lvs3 {}; |
| pm8921_lvs4: lvs4 {}; |
| pm8921_lvs5: lvs5 {}; |
| pm8921_lvs6: lvs6 {}; |
| pm8921_lvs7: lvs7 {}; |
| |
| pm8921_usb_switch: usb-switch {}; |
| |
| pm8921_hdmi_switch: hdmi-switch { |
| bias-pull-down; |
| }; |
| |
| pm8921_ncp: ncp {}; |
| }; |
| }; |
| |
| usb1: usb@12500000 { |
| compatible = "qcom,ci-hdrc"; |
| reg = <0x12500000 0x200>, |
| <0x12500200 0x200>; |
| interrupts = <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc USB_HS1_XCVR_CLK>, <&gcc USB_HS1_H_CLK>; |
| clock-names = "core", "iface"; |
| assigned-clocks = <&gcc USB_HS1_XCVR_CLK>; |
| assigned-clock-rates = <60000000>; |
| resets = <&gcc USB_HS1_RESET>; |
| reset-names = "core"; |
| phy_type = "ulpi"; |
| ahb-burst-config = <0>; |
| phys = <&usb_hs1_phy>; |
| phy-names = "usb-phy"; |
| status = "disabled"; |
| #reset-cells = <1>; |
| |
| ulpi { |
| usb_hs1_phy: phy { |
| compatible = "qcom,usb-hs-phy-apq8064", |
| "qcom,usb-hs-phy"; |
| clocks = <&sleep_clk>, <&cxo_board>; |
| clock-names = "sleep", "ref"; |
| resets = <&usb1 0>; |
| reset-names = "por"; |
| #phy-cells = <0>; |
| }; |
| }; |
| }; |
| |
| usb3: usb@12520000 { |
| compatible = "qcom,ci-hdrc"; |
| reg = <0x12520000 0x200>, |
| <0x12520200 0x200>; |
| interrupts = <GIC_SPI 188 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc USB_HS3_XCVR_CLK>, <&gcc USB_HS3_H_CLK>; |
| clock-names = "core", "iface"; |
| assigned-clocks = <&gcc USB_HS3_XCVR_CLK>; |
| assigned-clock-rates = <60000000>; |
| resets = <&gcc USB_HS3_RESET>; |
| reset-names = "core"; |
| phy_type = "ulpi"; |
| ahb-burst-config = <0>; |
| phys = <&usb_hs3_phy>; |
| phy-names = "usb-phy"; |
| status = "disabled"; |
| #reset-cells = <1>; |
| |
| ulpi { |
| usb_hs3_phy: phy { |
| compatible = "qcom,usb-hs-phy-apq8064", |
| "qcom,usb-hs-phy"; |
| #phy-cells = <0>; |
| clocks = <&sleep_clk>, <&cxo_board>; |
| clock-names = "sleep", "ref"; |
| resets = <&usb3 0>; |
| reset-names = "por"; |
| }; |
| }; |
| }; |
| |
| usb4: usb@12530000 { |
| compatible = "qcom,ci-hdrc"; |
| reg = <0x12530000 0x200>, |
| <0x12530200 0x200>; |
| interrupts = <GIC_SPI 215 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc USB_HS4_XCVR_CLK>, <&gcc USB_HS4_H_CLK>; |
| clock-names = "core", "iface"; |
| assigned-clocks = <&gcc USB_HS4_XCVR_CLK>; |
| assigned-clock-rates = <60000000>; |
| resets = <&gcc USB_HS4_RESET>; |
| reset-names = "core"; |
| phy_type = "ulpi"; |
| ahb-burst-config = <0>; |
| phys = <&usb_hs4_phy>; |
| phy-names = "usb-phy"; |
| status = "disabled"; |
| #reset-cells = <1>; |
| |
| ulpi { |
| usb_hs4_phy: phy { |
| compatible = "qcom,usb-hs-phy-apq8064", |
| "qcom,usb-hs-phy"; |
| #phy-cells = <0>; |
| clocks = <&sleep_clk>, <&cxo_board>; |
| clock-names = "sleep", "ref"; |
| resets = <&usb4 0>; |
| reset-names = "por"; |
| }; |
| }; |
| }; |
| |
| sata_phy0: phy@1b400000 { |
| compatible = "qcom,apq8064-sata-phy"; |
| status = "disabled"; |
| reg = <0x1b400000 0x200>; |
| reg-names = "phy_mem"; |
| clocks = <&gcc SATA_PHY_CFG_CLK>; |
| clock-names = "cfg"; |
| #phy-cells = <0>; |
| }; |
| |
| sata0: sata@29000000 { |
| compatible = "qcom,apq8064-ahci", "generic-ahci"; |
| status = "disabled"; |
| reg = <0x29000000 0x180>; |
| interrupts = <GIC_SPI 209 IRQ_TYPE_LEVEL_HIGH>; |
| |
| clocks = <&gcc SFAB_SATA_S_H_CLK>, |
| <&gcc SATA_H_CLK>, |
| <&gcc SATA_A_CLK>, |
| <&gcc SATA_RXOOB_CLK>, |
| <&gcc SATA_PMALIVE_CLK>; |
| clock-names = "slave_iface", |
| "iface", |
| "bus", |
| "rxoob", |
| "core_pmalive"; |
| |
| assigned-clocks = <&gcc SATA_RXOOB_CLK>, |
| <&gcc SATA_PMALIVE_CLK>; |
| assigned-clock-rates = <100000000>, <100000000>; |
| |
| phys = <&sata_phy0>; |
| phy-names = "sata-phy"; |
| ports-implemented = <0x1>; |
| }; |
| |
| /* Temporary fixed regulator */ |
| sdcc1bam:dma@12402000{ |
| compatible = "qcom,bam-v1.3.0"; |
| reg = <0x12402000 0x8000>; |
| interrupts = <0 98 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc SDC1_H_CLK>; |
| clock-names = "bam_clk"; |
| #dma-cells = <1>; |
| qcom,ee = <0>; |
| }; |
| |
| sdcc3bam:dma@12182000{ |
| compatible = "qcom,bam-v1.3.0"; |
| reg = <0x12182000 0x8000>; |
| interrupts = <0 96 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc SDC3_H_CLK>; |
| clock-names = "bam_clk"; |
| #dma-cells = <1>; |
| qcom,ee = <0>; |
| }; |
| |
| sdcc4bam:dma@121c2000{ |
| compatible = "qcom,bam-v1.3.0"; |
| reg = <0x121c2000 0x8000>; |
| interrupts = <0 95 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&gcc SDC4_H_CLK>; |
| clock-names = "bam_clk"; |
| #dma-cells = <1>; |
| qcom,ee = <0>; |
| }; |
| |
| amba { |
| compatible = "simple-bus"; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| ranges; |
| sdcc1: sdcc@12400000 { |
| status = "disabled"; |
| compatible = "arm,pl18x", "arm,primecell"; |
| pinctrl-names = "default"; |
| pinctrl-0 = <&sdcc1_pins>; |
| arm,primecell-periphid = <0x00051180>; |
| reg = <0x12400000 0x2000>; |
| interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>; |
| interrupt-names = "cmd_irq"; |
| clocks = <&gcc SDC1_CLK>, <&gcc SDC1_H_CLK>; |
| clock-names = "mclk", "apb_pclk"; |
| bus-width = <8>; |
| max-frequency = <96000000>; |
| non-removable; |
| cap-sd-highspeed; |
| cap-mmc-highspeed; |
| dmas = <&sdcc1bam 2>, <&sdcc1bam 1>; |
| dma-names = "tx", "rx"; |
| }; |
| |
| sdcc3: sdcc@12180000 { |
| compatible = "arm,pl18x", "arm,primecell"; |
| arm,primecell-periphid = <0x00051180>; |
| status = "disabled"; |
| reg = <0x12180000 0x2000>; |
| interrupts = <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>; |
| interrupt-names = "cmd_irq"; |
| clocks = <&gcc SDC3_CLK>, <&gcc SDC3_H_CLK>; |
| clock-names = "mclk", "apb_pclk"; |
| bus-width = <4>; |
| cap-sd-highspeed; |
| cap-mmc-highspeed; |
| max-frequency = <192000000>; |
| no-1-8-v; |
| dmas = <&sdcc3bam 2>, <&sdcc3bam 1>; |
| dma-names = "tx", "rx"; |
| }; |
| |
| sdcc4: sdcc@121c0000 { |
| compatible = "arm,pl18x", "arm,primecell"; |
| arm,primecell-periphid = <0x00051180>; |
| status = "disabled"; |
| reg = <0x121c0000 0x2000>; |
| interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>; |
| interrupt-names = "cmd_irq"; |
| clocks = <&gcc SDC4_CLK>, <&gcc SDC4_H_CLK>; |
| clock-names = "mclk", "apb_pclk"; |
| bus-width = <4>; |
| cap-sd-highspeed; |
| cap-mmc-highspeed; |
| max-frequency = <48000000>; |
| dmas = <&sdcc4bam 2>, <&sdcc4bam 1>; |
| dma-names = "tx", "rx"; |
| pinctrl-names = "default"; |
| pinctrl-0 = <&sdc4_gpios>; |
| }; |
| }; |
| |
| tcsr: syscon@1a400000 { |
| compatible = "qcom,tcsr-apq8064", "syscon"; |
| reg = <0x1a400000 0x100>; |
| }; |
| |
| gpu: adreno-3xx@4300000 { |
| compatible = "qcom,adreno-3xx"; |
| reg = <0x04300000 0x20000>; |
| reg-names = "kgsl_3d0_reg_memory"; |
| interrupts = <GIC_SPI 80 IRQ_TYPE_LEVEL_HIGH>; |
| interrupt-names = "kgsl_3d0_irq"; |
| clock-names = |
| "core_clk", |
| "iface_clk", |
| "mem_clk", |
| "mem_iface_clk"; |
| clocks = |
| <&mmcc GFX3D_CLK>, |
| <&mmcc GFX3D_AHB_CLK>, |
| <&mmcc GFX3D_AXI_CLK>, |
| <&mmcc MMSS_IMEM_AHB_CLK>; |
| qcom,chipid = <0x03020002>; |
| |
| iommus = <&gfx3d 0 |
| &gfx3d 1 |
| &gfx3d 2 |
| &gfx3d 3 |
| &gfx3d 4 |
| &gfx3d 5 |
| &gfx3d 6 |
| &gfx3d 7 |
| &gfx3d 8 |
| &gfx3d 9 |
| &gfx3d 10 |
| &gfx3d 11 |
| &gfx3d 12 |
| &gfx3d 13 |
| &gfx3d 14 |
| &gfx3d 15 |
| &gfx3d 16 |
| &gfx3d 17 |
| &gfx3d 18 |
| &gfx3d 19 |
| &gfx3d 20 |
| &gfx3d 21 |
| &gfx3d 22 |
| &gfx3d 23 |
| &gfx3d 24 |
| &gfx3d 25 |
| &gfx3d 26 |
| &gfx3d 27 |
| &gfx3d 28 |
| &gfx3d 29 |
| &gfx3d 30 |
| &gfx3d 31 |
| &gfx3d1 0 |
| &gfx3d1 1 |
| &gfx3d1 2 |
| &gfx3d1 3 |
| &gfx3d1 4 |
| &gfx3d1 5 |
| &gfx3d1 6 |
| &gfx3d1 7 |
| &gfx3d1 8 |
| &gfx3d1 9 |
| &gfx3d1 10 |
| &gfx3d1 11 |
| &gfx3d1 12 |
| &gfx3d1 13 |
| &gfx3d1 14 |
| &gfx3d1 15 |
| &gfx3d1 16 |
| &gfx3d1 17 |
| &gfx3d1 18 |
| &gfx3d1 19 |
| &gfx3d1 20 |
| &gfx3d1 21 |
| &gfx3d1 22 |
| &gfx3d1 23 |
| &gfx3d1 24 |
| &gfx3d1 25 |
| &gfx3d1 26 |
| &gfx3d1 27 |
| &gfx3d1 28 |
| &gfx3d1 29 |
| &gfx3d1 30 |
| &gfx3d1 31>; |
| |
| qcom,gpu-pwrlevels { |
| compatible = "qcom,gpu-pwrlevels"; |
| qcom,gpu-pwrlevel@0 { |
| qcom,gpu-freq = <450000000>; |
| }; |
| qcom,gpu-pwrlevel@1 { |
| qcom,gpu-freq = <27000000>; |
| }; |
| }; |
| }; |
| |
| mmss_sfpb: syscon@5700000 { |
| compatible = "syscon"; |
| reg = <0x5700000 0x70>; |
| }; |
| |
| dsi0: mdss_dsi@4700000 { |
| compatible = "qcom,mdss-dsi-ctrl"; |
| label = "MDSS DSI CTRL->0"; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>; |
| reg = <0x04700000 0x200>; |
| reg-names = "dsi_ctrl"; |
| |
| clocks = <&mmcc DSI_M_AHB_CLK>, |
| <&mmcc DSI_S_AHB_CLK>, |
| <&mmcc AMP_AHB_CLK>, |
| <&mmcc DSI_CLK>, |
| <&mmcc DSI1_BYTE_CLK>, |
| <&mmcc DSI_PIXEL_CLK>, |
| <&mmcc DSI1_ESC_CLK>; |
| clock-names = "iface_clk", "bus_clk", "core_mmss_clk", |
| "src_clk", "byte_clk", "pixel_clk", |
| "core_clk"; |
| |
| assigned-clocks = <&mmcc DSI1_BYTE_SRC>, |
| <&mmcc DSI1_ESC_SRC>, |
| <&mmcc DSI_SRC>, |
| <&mmcc DSI_PIXEL_SRC>; |
| assigned-clock-parents = <&dsi0_phy 0>, |
| <&dsi0_phy 0>, |
| <&dsi0_phy 1>, |
| <&dsi0_phy 1>; |
| syscon-sfpb = <&mmss_sfpb>; |
| phys = <&dsi0_phy>; |
| ports { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| port@0 { |
| reg = <0>; |
| dsi0_in: endpoint { |
| }; |
| }; |
| |
| port@1 { |
| reg = <1>; |
| dsi0_out: endpoint { |
| }; |
| }; |
| }; |
| }; |
| |
| |
| dsi0_phy: dsi-phy@4700200 { |
| compatible = "qcom,dsi-phy-28nm-8960"; |
| #clock-cells = <1>; |
| #phy-cells = <0>; |
| |
| reg = <0x04700200 0x100>, |
| <0x04700300 0x200>, |
| <0x04700500 0x5c>; |
| reg-names = "dsi_pll", "dsi_phy", "dsi_phy_regulator"; |
| clock-names = "iface_clk", "ref"; |
| clocks = <&mmcc DSI_M_AHB_CLK>, |
| <&cxo_board>; |
| }; |
| |
| |
| mdp_port0: iommu@7500000 { |
| compatible = "qcom,apq8064-iommu"; |
| #iommu-cells = <1>; |
| clock-names = |
| "smmu_pclk", |
| "iommu_clk"; |
| clocks = |
| <&mmcc SMMU_AHB_CLK>, |
| <&mmcc MDP_AXI_CLK>; |
| reg = <0x07500000 0x100000>; |
| interrupts = |
| <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>, |
| <GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>; |
| qcom,ncb = <2>; |
| }; |
| |
| mdp_port1: iommu@7600000 { |
| compatible = "qcom,apq8064-iommu"; |
| #iommu-cells = <1>; |
| clock-names = |
| "smmu_pclk", |
| "iommu_clk"; |
| clocks = |
| <&mmcc SMMU_AHB_CLK>, |
| <&mmcc MDP_AXI_CLK>; |
| reg = <0x07600000 0x100000>; |
| interrupts = |
| <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>, |
| <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>; |
| qcom,ncb = <2>; |
| }; |
| |
| gfx3d: iommu@7c00000 { |
| compatible = "qcom,apq8064-iommu"; |
| #iommu-cells = <1>; |
| clock-names = |
| "smmu_pclk", |
| "iommu_clk"; |
| clocks = |
| <&mmcc SMMU_AHB_CLK>, |
| <&mmcc GFX3D_AXI_CLK>; |
| reg = <0x07c00000 0x100000>; |
| interrupts = |
| <GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>, |
| <GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>; |
| qcom,ncb = <3>; |
| }; |
| |
| gfx3d1: iommu@7d00000 { |
| compatible = "qcom,apq8064-iommu"; |
| #iommu-cells = <1>; |
| clock-names = |
| "smmu_pclk", |
| "iommu_clk"; |
| clocks = |
| <&mmcc SMMU_AHB_CLK>, |
| <&mmcc GFX3D_AXI_CLK>; |
| reg = <0x07d00000 0x100000>; |
| interrupts = |
| <GIC_SPI 210 IRQ_TYPE_LEVEL_HIGH>, |
| <GIC_SPI 211 IRQ_TYPE_LEVEL_HIGH>; |
| qcom,ncb = <3>; |
| }; |
| |
| pcie: pci@1b500000 { |
| compatible = "qcom,pcie-apq8064", "snps,dw-pcie"; |
| reg = <0x1b500000 0x1000 |
| 0x1b502000 0x80 |
| 0x1b600000 0x100 |
| 0x0ff00000 0x100000>; |
| reg-names = "dbi", "elbi", "parf", "config"; |
| device_type = "pci"; |
| linux,pci-domain = <0>; |
| bus-range = <0x00 0xff>; |
| num-lanes = <1>; |
| #address-cells = <3>; |
| #size-cells = <2>; |
| ranges = <0x81000000 0 0 0x0fe00000 0 0x00100000 /* I/O */ |
| 0x82000000 0 0x08000000 0x08000000 0 0x07e00000>; /* memory */ |
| interrupts = <GIC_SPI 238 IRQ_TYPE_LEVEL_HIGH>; |
| interrupt-names = "msi"; |
| #interrupt-cells = <1>; |
| interrupt-map-mask = <0 0 0 0x7>; |
| interrupt-map = <0 0 0 1 &intc 0 36 IRQ_TYPE_LEVEL_HIGH>, /* int_a */ |
| <0 0 0 2 &intc 0 37 IRQ_TYPE_LEVEL_HIGH>, /* int_b */ |
| <0 0 0 3 &intc 0 38 IRQ_TYPE_LEVEL_HIGH>, /* int_c */ |
| <0 0 0 4 &intc 0 39 IRQ_TYPE_LEVEL_HIGH>; /* int_d */ |
| clocks = <&gcc PCIE_A_CLK>, |
| <&gcc PCIE_H_CLK>, |
| <&gcc PCIE_PHY_REF_CLK>; |
| clock-names = "core", "iface", "phy"; |
| resets = <&gcc PCIE_ACLK_RESET>, |
| <&gcc PCIE_HCLK_RESET>, |
| <&gcc PCIE_POR_RESET>, |
| <&gcc PCIE_PCI_RESET>, |
| <&gcc PCIE_PHY_RESET>; |
| reset-names = "axi", "ahb", "por", "pci", "phy"; |
| status = "disabled"; |
| }; |
| |
| hdmi: hdmi-tx@4a00000 { |
| compatible = "qcom,hdmi-tx-8960"; |
| pinctrl-names = "default"; |
| pinctrl-0 = <&hdmi_pinctrl>; |
| reg = <0x04a00000 0x2f0>; |
| reg-names = "core_physical"; |
| interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&mmcc HDMI_APP_CLK>, |
| <&mmcc HDMI_M_AHB_CLK>, |
| <&mmcc HDMI_S_AHB_CLK>; |
| clock-names = "core_clk", |
| "master_iface_clk", |
| "slave_iface_clk"; |
| |
| phys = <&hdmi_phy>; |
| phy-names = "hdmi-phy"; |
| |
| ports { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| port@0 { |
| reg = <0>; |
| hdmi_in: endpoint { |
| }; |
| }; |
| |
| port@1 { |
| reg = <1>; |
| hdmi_out: endpoint { |
| }; |
| }; |
| }; |
| }; |
| |
| hdmi_phy: hdmi-phy@4a00400 { |
| compatible = "qcom,hdmi-phy-8960"; |
| reg = <0x4a00400 0x60>, |
| <0x4a00500 0x100>; |
| reg-names = "hdmi_phy", |
| "hdmi_pll"; |
| |
| clocks = <&mmcc HDMI_S_AHB_CLK>; |
| clock-names = "slave_iface_clk"; |
| #phy-cells = <0>; |
| }; |
| |
| mdp: mdp@5100000 { |
| compatible = "qcom,mdp4"; |
| reg = <0x05100000 0xf0000>; |
| interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>; |
| clocks = <&mmcc MDP_CLK>, |
| <&mmcc MDP_AHB_CLK>, |
| <&mmcc MDP_AXI_CLK>, |
| <&mmcc MDP_LUT_CLK>, |
| <&mmcc HDMI_TV_CLK>, |
| <&mmcc MDP_TV_CLK>; |
| clock-names = "core_clk", |
| "iface_clk", |
| "bus_clk", |
| "lut_clk", |
| "hdmi_clk", |
| "tv_clk"; |
| |
| iommus = <&mdp_port0 0 |
| &mdp_port0 2 |
| &mdp_port1 0 |
| &mdp_port1 2>; |
| |
| ports { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| port@0 { |
| reg = <0>; |
| mdp_lvds_out: endpoint { |
| }; |
| }; |
| |
| port@1 { |
| reg = <1>; |
| mdp_dsi1_out: endpoint { |
| }; |
| }; |
| |
| port@2 { |
| reg = <2>; |
| mdp_dsi2_out: endpoint { |
| }; |
| }; |
| |
| port@3 { |
| reg = <3>; |
| mdp_dtv_out: endpoint { |
| }; |
| }; |
| }; |
| }; |
| |
| riva: riva-pil@3204000 { |
| compatible = "qcom,riva-pil"; |
| |
| reg = <0x03200800 0x1000>, <0x03202000 0x2000>, <0x03204000 0x100>; |
| reg-names = "ccu", "dxe", "pmu"; |
| |
| interrupts-extended = <&intc GIC_SPI 199 IRQ_TYPE_EDGE_RISING>, |
| <&wcnss_smsm 6 IRQ_TYPE_EDGE_RISING>; |
| interrupt-names = "wdog", "fatal"; |
| |
| memory-region = <&wcnss_mem>; |
| |
| vddcx-supply = <&pm8921_s3>; |
| vddmx-supply = <&pm8921_l24>; |
| vddpx-supply = <&pm8921_s4>; |
| |
| status = "disabled"; |
| |
| iris { |
| compatible = "qcom,wcn3660"; |
| |
| clocks = <&cxo_board>; |
| clock-names = "xo"; |
| |
| vddxo-supply = <&pm8921_l4>; |
| vddrfa-supply = <&pm8921_s2>; |
| vddpa-supply = <&pm8921_l10>; |
| vdddig-supply = <&pm8921_lvs2>; |
| }; |
| |
| smd-edge { |
| interrupts = <GIC_SPI 198 IRQ_TYPE_EDGE_RISING>; |
| |
| qcom,ipc = <&l2cc 8 25>; |
| qcom,smd-edge = <6>; |
| |
| label = "riva"; |
| |
| wcnss { |
| compatible = "qcom,wcnss"; |
| qcom,smd-channels = "WCNSS_CTRL"; |
| |
| qcom,mmio = <&riva>; |
| |
| bt { |
| compatible = "qcom,wcnss-bt"; |
| }; |
| |
| wifi { |
| compatible = "qcom,wcnss-wlan"; |
| |
| interrupts = <GIC_SPI 203 IRQ_TYPE_LEVEL_HIGH>, |
| <GIC_SPI 202 IRQ_TYPE_LEVEL_HIGH>; |
| interrupt-names = "tx", "rx"; |
| |
| qcom,smem-states = <&apps_smsm 10>, <&apps_smsm 9>; |
| qcom,smem-state-names = "tx-enable", "tx-rings-empty"; |
| }; |
| }; |
| }; |
| }; |
| |
| etb@1a01000 { |
| compatible = "coresight-etb10", "arm,primecell"; |
| reg = <0x1a01000 0x1000>; |
| |
| clocks = <&rpmcc RPM_QDSS_CLK>; |
| clock-names = "apb_pclk"; |
| |
| in-ports { |
| port { |
| etb_in: endpoint { |
| remote-endpoint = <&replicator_out0>; |
| }; |
| }; |
| }; |
| }; |
| |
| tpiu@1a03000 { |
| compatible = "arm,coresight-tpiu", "arm,primecell"; |
| reg = <0x1a03000 0x1000>; |
| |
| clocks = <&rpmcc RPM_QDSS_CLK>; |
| clock-names = "apb_pclk"; |
| |
| in-ports { |
| port { |
| tpiu_in: endpoint { |
| remote-endpoint = <&replicator_out1>; |
| }; |
| }; |
| }; |
| }; |
| |
| replicator { |
| compatible = "arm,coresight-replicator"; |
| |
| clocks = <&rpmcc RPM_QDSS_CLK>; |
| clock-names = "apb_pclk"; |
| |
| out-ports { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| port@0 { |
| reg = <0>; |
| replicator_out0: endpoint { |
| remote-endpoint = <&etb_in>; |
| }; |
| }; |
| port@1 { |
| reg = <1>; |
| replicator_out1: endpoint { |
| remote-endpoint = <&tpiu_in>; |
| }; |
| }; |
| }; |
| |
| in-ports { |
| port { |
| replicator_in: endpoint { |
| remote-endpoint = <&funnel_out>; |
| }; |
| }; |
| }; |
| }; |
| |
| funnel@1a04000 { |
| compatible = "arm,coresight-funnel", "arm,primecell"; |
| reg = <0x1a04000 0x1000>; |
| |
| clocks = <&rpmcc RPM_QDSS_CLK>; |
| clock-names = "apb_pclk"; |
| |
| in-ports { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| /* |
| * Not described input ports: |
| * 2 - connected to STM component |
| * 3 - not-connected |
| * 6 - not-connected |
| * 7 - not-connected |
| */ |
| port@0 { |
| reg = <0>; |
| funnel_in0: endpoint { |
| remote-endpoint = <&etm0_out>; |
| }; |
| }; |
| port@1 { |
| reg = <1>; |
| funnel_in1: endpoint { |
| remote-endpoint = <&etm1_out>; |
| }; |
| }; |
| port@4 { |
| reg = <4>; |
| funnel_in4: endpoint { |
| remote-endpoint = <&etm2_out>; |
| }; |
| }; |
| port@5 { |
| reg = <5>; |
| funnel_in5: endpoint { |
| remote-endpoint = <&etm3_out>; |
| }; |
| }; |
| }; |
| |
| out-ports { |
| port { |
| funnel_out: endpoint { |
| remote-endpoint = <&replicator_in>; |
| }; |
| }; |
| }; |
| }; |
| |
| etm@1a1c000 { |
| compatible = "arm,coresight-etm3x", "arm,primecell"; |
| reg = <0x1a1c000 0x1000>; |
| |
| clocks = <&rpmcc RPM_QDSS_CLK>; |
| clock-names = "apb_pclk"; |
| |
| cpu = <&CPU0>; |
| |
| out-ports { |
| port { |
| etm0_out: endpoint { |
| remote-endpoint = <&funnel_in0>; |
| }; |
| }; |
| }; |
| }; |
| |
| etm@1a1d000 { |
| compatible = "arm,coresight-etm3x", "arm,primecell"; |
| reg = <0x1a1d000 0x1000>; |
| |
| clocks = <&rpmcc RPM_QDSS_CLK>; |
| clock-names = "apb_pclk"; |
| |
| cpu = <&CPU1>; |
| |
| out-ports { |
| port { |
| etm1_out: endpoint { |
| remote-endpoint = <&funnel_in1>; |
| }; |
| }; |
| }; |
| }; |
| |
| etm@1a1e000 { |
| compatible = "arm,coresight-etm3x", "arm,primecell"; |
| reg = <0x1a1e000 0x1000>; |
| |
| clocks = <&rpmcc RPM_QDSS_CLK>; |
| clock-names = "apb_pclk"; |
| |
| cpu = <&CPU2>; |
| |
| out-ports { |
| port { |
| etm2_out: endpoint { |
| remote-endpoint = <&funnel_in4>; |
| }; |
| }; |
| }; |
| }; |
| |
| etm@1a1f000 { |
| compatible = "arm,coresight-etm3x", "arm,primecell"; |
| reg = <0x1a1f000 0x1000>; |
| |
| clocks = <&rpmcc RPM_QDSS_CLK>; |
| clock-names = "apb_pclk"; |
| |
| cpu = <&CPU3>; |
| |
| out-ports { |
| port { |
| etm3_out: endpoint { |
| remote-endpoint = <&funnel_in5>; |
| }; |
| }; |
| }; |
| }; |
| }; |
| }; |
| #include "qcom-apq8064-pins.dtsi" |