blob: 0277a1ca99c606f9f16fa68ab777fda3fc6ccdac [file] [log] [blame]
/* Copyright (c) 2012-2013, The Linux Foundation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 and
* only version 2 as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
/include/ "skeleton.dtsi"
/include/ "msm8226-ion.dtsi"
/include/ "msm-gdsc.dtsi"
/include/ "msm8226-iommu.dtsi"
/include/ "msm8226-pm.dtsi"
/ {
model = "Qualcomm MSM 8226";
compatible = "qcom,msm8226";
interrupt-parent = <&intc>;
intc: interrupt-controller@f9000000 {
compatible = "qcom,msm-qgic2";
interrupt-controller;
#interrupt-cells = <3>;
reg = <0xF9000000 0x1000>,
<0xF9002000 0x1000>;
};
msmgpio: gpio@fd510000 {
compatible = "qcom,msm-gpio";
interrupt-controller;
#interrupt-cells = <2>;
reg = <0xfd510000 0x4000>;
gpio-controller;
#gpio-cells = <2>;
ngpio = <117>;
interrupts = <0 208 0>;
qcom,direct-connect-irqs = <8>;
};
timer {
compatible = "arm,armv7-timer";
interrupts = <1 2 0 1 3 0>;
clock-frequency = <19200000>;
};
serial@f991f000 {
compatible = "qcom,msm-lsuart-v14";
reg = <0xf991f000 0x1000>;
interrupts = <0 109 0>;
status = "disabled";
};
serial@f995e000 {
compatible = "qcom,msm-lsuart-v14";
reg = <0xf995e000 0x1000>;
interrupts = <0 114 0>;
status = "disabled";
};
qcom,sps@f9984000 {
compatible = "qcom,msm_sps";
reg = <0xf9984000 0x15000>,
<0xf9999000 0xb000>;
interrupts = <0 94 0>;
};
usb@f9a55000 {
compatible = "qcom,hsusb-otg";
reg = <0xf9a55000 0x400>;
interrupts = <0 134 0>, <0 140 0>;
interrupt-names = "core_irq", "async_irq";
HSUSB_VDDCX-supply = <&pm8026_s1>;
HSUSB_1p8-supply = <&pm8026_l10>;
HSUSB_3p3-supply = <&pm8026_l20>;
qcom,hsusb-otg-phy-type = <2>;
qcom,hsusb-otg-mode = <1>;
qcom,hsusb-otg-otg-control = <1>;
qcom,hsusb-otg-disable-reset;
};
android_usb {
compatible = "qcom,android-usb";
};
wcd9xxx_intc: wcd9xxx-irq {
compatible = "qcom,wcd9xxx-irq";
interrupt-controller;
#interrupt-cells = <1>;
interrupt-parent = <&msmgpio>;
interrupts = <68 0>;
interrupt-names = "cdc-int";
};
slim@fe12f000 {
cell-index = <1>;
compatible = "qcom,slim-ngd";
reg = <0xfe12f000 0x35000>,
<0xfe104000 0x20000>;
reg-names = "slimbus_physical", "slimbus_bam_physical";
interrupts = <0 163 0>, <0 164 0>;
interrupt-names = "slimbus_irq", "slimbus_bam_irq";
tapan_codec {
compatible = "qcom,tapan-slim-pgd";
elemental-addr = [00 01 E0 00 17 02];
interrupt-parent = <&wcd9xxx_intc>;
interrupts = <0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
17 18 19 20 21 22 23 24 25 26 27 28>;
qcom,cdc-reset-gpio = <&msmgpio 72 0>;
cdc-vdd-buck-supply = <&pm8026_s4>;
qcom,cdc-vdd-buck-voltage = <2100000 2100000>;
qcom,cdc-vdd-buck-current = <650000>;
cdc-vdd-h-supply = <&pm8026_l6>;
qcom,cdc-vdd-h-voltage = <1800000 1800000>;
qcom,cdc-vdd-h-current = <25000>;
cdc-vdd-px-supply = <&pm8026_l6>;
qcom,cdc-vdd-px-voltage = <1800000 1800000>;
qcom,cdc-vdd-px-current = <25000>;
cdc-vdd-a-1p2v-supply = <&pm8026_l4>;
qcom,cdc-vdd-a-1p2v-voltage = <1200000 1200000>;
qcom,cdc-vdd-a-1p2v-current = <10000>;
cdc-vdd-cx-supply = <&pm8026_l4>;
qcom,cdc-vdd-cx-voltage = <1200000 1200000>;
qcom,cdc-vdd-cx-current = <10000>;
qcom,cdc-micbias-ldoh-v = <0x3>;
qcom,cdc-micbias-cfilt1-mv = <1800>;
qcom,cdc-micbias-cfilt2-mv = <1800>;
qcom,cdc-micbias-cfilt3-mv = <1800>;
qcom,cdc-micbias1-cfilt-sel = <0x0>;
qcom,cdc-micbias2-cfilt-sel = <0x1>;
qcom,cdc-micbias3-cfilt-sel = <0x2>;
qcom,cdc-mclk-clk-rate = <9600000>;
qcom,cdc-slim-ifd = "tapan-slim-ifd";
qcom,cdc-slim-ifd-elemental-addr = [00 00 E0 00 17 02];
};
};
qcom,msm-adsp-loader {
compatible = "qcom,adsp-loader";
qcom,adsp-state = <0>;
};
sound {
compatible = "qcom,msm8226-audio-tapan";
qcom,model = "msm8226-tapan-snd-card";
qcom,audio-routing =
"RX_BIAS", "MCLK",
"LDO_H", "MCLK",
"AMIC1", "MIC BIAS1 Internal1",
"MIC BIAS1 Internal1", "Handset Mic",
"AMIC2", "MIC BIAS2 External",
"MIC BIAS2 External", "Headset Mic",
"AMIC3", "MIC BIAS2 External",
"MIC BIAS2 External", "ANCRight Headset Mic",
"AMIC4", "MIC BIAS2 External",
"MIC BIAS2 External", "ANCLeft Headset Mic",
"DMIC1", "MIC BIAS1 External",
"MIC BIAS1 External", "Digital Mic1",
"DMIC2", "MIC BIAS1 External",
"MIC BIAS1 External", "Digital Mic2",
"DMIC3", "MIC BIAS3 External",
"MIC BIAS3 External", "Digital Mic3",
"DMIC4", "MIC BIAS3 External",
"MIC BIAS3 External", "Digital Mic4",
"DMIC5", "MIC BIAS4 External",
"MIC BIAS4 External", "Digital Mic5",
"DMIC6", "MIC BIAS4 External",
"MIC BIAS4 External", "Digital Mic6";
qcom,tapan-mclk-clk-freq = <9600000>;
};
qcom,msm-pcm {
compatible = "qcom,msm-pcm-dsp";
};
qcom,msm-pcm-routing {
compatible = "qcom,msm-pcm-routing";
};
qcom,msm-pcm-lpa {
compatible = "qcom,msm-pcm-lpa";
};
qcom,msm-compr-dsp {
compatible = "qcom,msm-compr-dsp";
};
qcom,msm-voip-dsp {
compatible = "qcom,msm-voip-dsp";
};
qcom,msm-pcm-voice {
compatible = "qcom,msm-pcm-voice";
};
qcom,msm-stub-codec {
compatible = "qcom,msm-stub-codec";
};
qcom,msm-dai-fe {
compatible = "qcom,msm-dai-fe";
};
qcom,msm-pcm-afe {
compatible = "qcom,msm-pcm-afe";
};
qcom,msm-dai-q6-hdmi {
compatible = "qcom,msm-dai-q6-hdmi";
qcom,msm-dai-q6-dev-id = <8>;
};
qcom,msm-dai-q6 {
compatible = "qcom,msm-dai-q6";
qcom,msm-dai-q6-sb-0-rx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <16384>;
};
qcom,msm-dai-q6-sb-0-tx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <16385>;
};
qcom,msm-dai-q6-sb-1-rx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <16386>;
};
qcom,msm-dai-q6-sb-1-tx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <16387>;
};
qcom,msm-dai-q6-sb-3-rx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <16390>;
};
qcom,msm-dai-q6-sb-3-tx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <16391>;
};
qcom,msm-dai-q6-sb-4-rx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <16392>;
};
qcom,msm-dai-q6-sb-4-tx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <16393>;
};
qcom,msm-dai-q6-bt-sco-rx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <12288>;
};
qcom,msm-dai-q6-bt-sco-tx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <12289>;
};
qcom,msm-dai-q6-int-fm-rx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <12292>;
};
qcom,msm-dai-q6-int-fm-tx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <12293>;
};
qcom,msm-dai-q6-be-afe-pcm-rx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <224>;
};
qcom,msm-dai-q6-be-afe-pcm-tx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <225>;
};
qcom,msm-dai-q6-afe-proxy-rx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <241>;
};
qcom,msm-dai-q6-afe-proxy-tx {
compatible = "qcom,msm-dai-q6-dev";
qcom,msm-dai-q6-dev-id = <240>;
};
};
qcom,msm-pcm-hostless {
compatible = "qcom,msm-pcm-hostless";
};
qcom,wdt@f9017000 {
compatible = "qcom,msm-watchdog";
reg = <0xf9017000 0x1000>;
interrupts = <0 3 0>, <0 4 0>;
qcom,bark-time = <11000>;
qcom,pet-time = <10000>;
qcom,ipi-ping;
};
qcom,smem@fa00000 {
compatible = "qcom,smem";
reg = <0xfa00000 0x200000>,
<0xfa006000 0x1000>,
<0xfc428000 0x4000>;
reg-names = "smem", "irq-reg-base", "aux-mem1";
qcom,smd-modem {
compatible = "qcom,smd";
qcom,smd-edge = <0>;
qcom,smd-irq-offset = <0x8>;
qcom,smd-irq-bitmask = <0x1000>;
qcom,pil-string = "modem";
interrupts = <0 25 1>;
};
qcom,smsm-modem {
compatible = "qcom,smsm";
qcom,smsm-edge = <0>;
qcom,smsm-irq-offset = <0x8>;
qcom,smsm-irq-bitmask = <0x2000>;
interrupts = <0 26 1>;
};
qcom,smd-adsp {
compatible = "qcom,smd";
qcom,smd-edge = <1>;
qcom,smd-irq-offset = <0x8>;
qcom,smd-irq-bitmask = <0x100>;
qcom,pil-string = "adsp";
interrupts = <0 156 1>;
};
qcom,smsm-adsp {
compatible = "qcom,smsm";
qcom,smsm-edge = <1>;
qcom,smsm-irq-offset = <0x8>;
qcom,smsm-irq-bitmask = <0x200>;
interrupts = <0 157 1>;
};
qcom,smd-wcnss {
compatible = "qcom,smd";
qcom,smd-edge = <6>;
qcom,smd-irq-offset = <0x8>;
qcom,smd-irq-bitmask = <0x20000>;
qcom,pil-string = "wcnss";
interrupts = <0 142 1>;
};
qcom,smsm-wcnss {
compatible = "qcom,smsm";
qcom,smsm-edge = <6>;
qcom,smsm-irq-offset = <0x8>;
qcom,smsm-irq-bitmask = <0x80000>;
interrupts = <0 144 1>;
};
qcom,smd-rpm {
compatible = "qcom,smd";
qcom,smd-edge = <15>;
qcom,smd-irq-offset = <0x8>;
qcom,smd-irq-bitmask = <0x1>;
interrupts = <0 168 1>;
qcom,irq-no-suspend;
};
};
rpm_bus: qcom,rpm-smd {
compatible = "qcom,rpm-smd";
rpm-channel-name = "rpm_requests";
rpm-channel-type = <15>; /* SMD_APPS_RPM */
rpm-standalone;
};
sdcc1: qcom,sdcc@f9824000 {
cell-index = <1>; /* SDC1 eMMC slot */
compatible = "qcom,msm-sdcc";
reg = <0xf9824000 0x800>,
<0xf9824800 0x100>,
<0xf9804000 0x7000>;
reg-names = "core_mem", "dml_mem", "bam_mem";
interrupts = <0 123 0>, <0 137 0>;
interrupt-names = "core_irq", "bam_irq";
qcom,bus-width = <8>;
status = "disabled";
};
sdcc2: qcom,sdcc@f98a4000 {
cell-index = <2>; /* SDC2 SD card slot */
compatible = "qcom,msm-sdcc";
reg = <0xf98a4000 0x800>,
<0xf98a4800 0x100>,
<0xf9884000 0x7000>;
reg-names = "core_mem", "dml_mem", "bam_mem";
interrupts = <0 125 0>, <0 220 0>;
interrupt-names = "core_irq", "bam_irq";
qcom,bus-width = <4>;
status = "disabled";
};
spmi_bus: qcom,spmi@fc4c0000 {
cell-index = <0>;
compatible = "qcom,spmi-pmic-arb";
reg = <0xfc4cf000 0x1000>,
<0Xfc4cb000 0x1000>;
/* 190,ee0_krait_hlos_spmi_periph_irq */
/* 187,channel_0_krait_hlos_trans_done_irq */
interrupts = <0 190 0>, <0 187 0>;
qcom,not-wakeup;
qcom,pmic-arb-ee = <0>;
qcom,pmic-arb-channel = <0>;
qcom,pmic-arb-ppid-map = <0x001000a0>, /* PM8026_0 */
<0x005000a2>, /* INTERRUPT */
<0x006000a3>, /* SPMI_0 */
<0x00800000>, /* PON0 */
<0x00a000a5>, /* VREF_LPDDR3 */
<0x01000001>, /* SMBB_CHG */
<0x01100002>, /* SMBB_BUCK */
<0x01200003>, /* SMBB_BIF */
<0x01300004>, /* SMBB_USB */
<0x01500005>, /* SMBB_BOOST */
<0x01600006>, /* SMBB_MISC */
<0x02800009>, /* COINCELL */
<0x02c000a6>, /* MBG */
<0x0310000a>, /* VADC1_USR */
<0x03200041>, /* VADC1_MDM */
<0x0330000b>, /* VADC1_BMS */
<0x0340000c>, /* VADC2_BTM */
<0x0360000d>, /* IADC1_USR */
<0x03700042>, /* IADC1_MDM */
<0x0380000e>, /* IADC1_BMS */
<0x0400000f>, /* BMS_1 */
<0x050000a7>, /* SHARED_XO */
<0x051000a8>, /* BB_CLK1 */
<0x05200010>, /* BB_CLK2 */
<0x05a000ac>, /* SLEEP_CLK */
<0x06000045>, /* RTC_RW */
<0x06100012>, /* RTC_ALARM */
<0x070000ae>, /* PBS_CORE */
<0x071000af>, /* PBS_CLIENT_1 */
<0x072000b0>, /* PBS_CLIENT_2 */
<0x073000b1>, /* PBS_CLIENT_3 */
<0x074000b2>, /* PBS_CLIENT_4 */
<0x075000b3>, /* PBS_CLIENT_5 */
<0x076000b4>, /* PBS_CLIENT_6 */
<0x07700046>, /* PBS_CLIENT_7 */
<0x07800047>, /* PBS_CLIENT_8 */
<0x079000b5>, /* PBS_CLIENT_9 */
<0x07a000b6>, /* PBS_CLIENT_10 */
<0x07b000b7>, /* PBS_CLIENT_11 */
<0x07c000b8>, /* PBS_CLIENT_12 */
<0x07d000b9>, /* PBS_CLIENT_13 */
<0x07e000ba>, /* PBS_CLIENT_14 */
<0x07f000bb>, /* PBS_CLIENT_15 */
<0x0a0000bd>, /* MPP_1 */
<0x0a100014>, /* MPP_2 */
<0x0a200015>, /* MPP_3 */
<0x0a300016>, /* MPP_4 */
<0x0a400048>, /* MPP_5 */
<0x0a500017>, /* MPP_6 */
<0x0a600018>, /* MPP_7 */
<0x0a700049>, /* MPP_8 */
<0x0c000019>, /* GPIO_1 */
<0x0c10001a>, /* GPIO_2 */
<0x0c20004a>, /* GPIO_3 */
<0x0c30004b>, /* GPIO_4 */
<0x0c40001b>, /* GPIO_5 */
<0x0c50001c>, /* GPIO_6 */
<0x0c60001d>, /* GPIO_7 */
<0x0c70004c>, /* GPIO_8 */
<0x0fe000be>, /* TRIM_0 */
<0x110000bf>, /* BUCK_CMN_1 */
<0x114000c0>, /* SMPS1 */
<0x115000c1>, /* FTPS1_1 */
<0x116000c2>, /* BUCK_FREQ_1 */
<0x1170001e>, /* SMPS2 */
<0x1180001f>, /* FTPS1_2 */
<0x11900020>, /* BUCK_FREQ_2 */
<0x11a000c3>, /* SMPS3 */
<0x11b000c4>, /* SMPS_3_PS1 */
<0x11c000c5>, /* BUCK_FREQ_3 */
<0x11d000c6>, /* SMPS4 */
<0x11e000c7>, /* SMPS_4_PS1 */
<0x11f000c8>, /* BUCK_FREQ_4 */
<0x120000c9>, /* SMPS5 */
<0x121000ca>, /* SMPS_5_PS1 */
<0x122000cb>, /* BUCK_FREQ_5 */
<0x140000cc>, /* LDO_1 */
<0x141000cd>, /* LDO_2 */
<0x142000ce>, /* LDO_3 */
<0x143000cf>, /* LDO_4 */
<0x144000d0>, /* LDO_5 */
<0x145000d1>, /* LDO_6 */
<0x146000d2>, /* LDO_7 */
<0x147000d3>, /* LDO_8 */
<0x148000d4>, /* LDO_9 */
<0x149000d5>, /* LDO_10 */
<0x14a000d6>, /* LDO_11 */
<0x14b000d7>, /* LDO_12 */
<0x14c000d8>, /* LDO_13 */
<0x14d000d9>, /* LDO_14 */
<0x14e000da>, /* LDO_15 */
<0x14f000db>, /* LDO_16 */
<0x150000dc>, /* LDO_17 */
<0x151000dd>, /* LDO_18 */
<0x152000de>, /* LDO_19 */
<0x153000df>, /* LDO_20 */
<0x154000e0>, /* LDO_21 */
<0x155000e1>, /* LDO_22 */
<0x156000e2>, /* LDO_23 */
<0x157000e3>, /* LDO_24 */
<0x158000e4>, /* LDO_25 */
<0x159000e5>, /* LDO_26 */
<0x15a000e6>, /* LDO_27 */
<0x15b000e7>, /* LDO_28 */
<0x180000e8>, /* LVS_1 */
<0x1b0000e9>, /* LPG_LUT */
<0x1b1000ea>, /* LPG_CHAN_1 */
<0x1b200023>, /* LPG_CHAN_2 */
<0x1b300024>, /* LPG_CHAN_3 */
<0x1b400025>, /* LPG_CHAN_4 */
<0x1b500026>, /* LPG_CHAN_5 */
<0x1b600027>, /* LPG_CHAN_6 */
<0x1bc00028>, /* PWM_3D */
<0x1c000029>, /* VIB1 */
<0x1d30002a>, /* FLASH_DRV */
<0x1d80002b>; /* WLED */
};
i2c@f9926000 { /* BLSP-1 QUP-4 */
cell-index = <0>;
compatible = "qcom,i2c-qup";
reg = <0xf9926000 0x1000>;
#address-cells = <1>;
#size-cells = <0>;
reg-names = "qup_phys_addr";
interrupts = <0 98 0>;
interrupt-names = "qup_err_intr";
qcom,i2c-bus-freq = <100000>;
};
};
&gdsc_venus {
status = "ok";
};
&gdsc_mdss {
status = "ok";
};
&gdsc_jpeg {
status = "ok";
};
&gdsc_vfe {
status = "ok";
};
&gdsc_oxili_cx {
status = "ok";
};
&gdsc_usb_hsic {
status = "ok";
};
/include/ "msm8226-regulator.dtsi"
/include/ "msm-pm8026.dtsi"