blob: 388307bddaeadd8bc14bfec51d077d0c38d21ea7 [file] [log] [blame]
Michael Bohan0425f6f2012-01-17 14:36:39 -08001/* Copyright (c) 2011-2012, Code Aurora Forum. All rights reserved.
Sathish Ambleyc58afc22011-10-09 21:55:39 -07002 *
3 * This program is free software; you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License version 2 and
5 * only version 2 as published by the Free Software Foundation.
6 *
7 * This program is distributed in the hope that it will be useful,
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10 * GNU General Public License for more details.
11 */
12
13#include <linux/kernel.h>
14#include <linux/platform_device.h>
15#include <linux/io.h>
Steve Mucklef132c6c2012-06-06 18:30:57 -070016#include <linux/gpio.h>
Sathish Ambleyc58afc22011-10-09 21:55:39 -070017#include <linux/irq.h>
18#include <linux/irqdomain.h>
19#include <linux/of.h>
20#include <linux/of_address.h>
21#include <linux/of_platform.h>
Michael Bohanc7224532012-01-06 16:02:52 -080022#include <linux/of_irq.h>
Olav Hauganb800c8c2012-01-30 08:50:45 -080023#include <linux/memory.h>
24#ifdef CONFIG_ANDROID_PMEM
25#include <linux/android_pmem.h>
26#endif
Matt Wagantallecaa1172012-05-08 21:38:45 -070027#include <linux/regulator/machine.h>
Michael Bohan2a468322012-08-14 17:06:34 -070028#include <linux/regulator/krait-regulator.h>
Eugene Seahce52ef22012-07-12 12:40:38 -060029#include <linux/msm_thermal.h>
Sathish Ambleyc58afc22011-10-09 21:55:39 -070030#include <asm/mach/map.h>
31#include <asm/hardware/gic.h>
32#include <mach/board.h>
Sathish Ambleyc58afc22011-10-09 21:55:39 -070033#include <mach/gpiomux.h>
34#include <mach/msm_iomap.h>
Olav Hauganb800c8c2012-01-30 08:50:45 -080035#ifdef CONFIG_ION_MSM
36#include <mach/ion.h>
37#endif
38#include <mach/msm_memtypes.h>
Jeff Hugo70946092012-02-10 11:30:43 -070039#include <mach/msm_smd.h>
Mahesh Sivasubramaniana8ff9922012-03-27 17:50:42 -060040#include <mach/rpm-smd.h>
David Collins8f4cebc2012-05-08 16:54:50 -070041#include <mach/rpm-regulator-smd.h>
Michael Bohan115cf652012-01-05 14:32:59 -080042#include <mach/qpnp-int.h>
Vikram Mulukutlaaeadb5f2012-05-04 14:03:07 -070043#include <mach/socinfo.h>
Gagan Macdd9bb792012-04-25 16:56:48 -060044#include <mach/msm_bus_board.h>
Mahesh Sivasubramanian1a995322012-07-12 15:26:46 -060045#include <mach/mpm.h>
Sathish Ambleyc58afc22011-10-09 21:55:39 -070046#include "clock.h"
Michael Bohan037a0f52012-02-29 19:13:09 -080047#include "devices.h"
Praveen Chidambaramda9501d2012-04-26 19:48:29 -060048#include "spm.h"
Jeff Hugoa643ca12012-06-11 16:00:23 -060049#include "modem_notifier.h"
Girish Mahadevan40abbe12012-04-25 14:58:13 -060050#include "lpm_resources.h"
Sathish Ambleyc58afc22011-10-09 21:55:39 -070051
Olav Hauganb800c8c2012-01-30 08:50:45 -080052#define MSM_KERNEL_EBI1_MEM_SIZE 0x280000
Olav Hauganb800c8c2012-01-30 08:50:45 -080053
54#ifdef CONFIG_KERNEL_PMEM_EBI_REGION
55static unsigned kernel_ebi1_mem_size = MSM_KERNEL_EBI1_MEM_SIZE;
56static int __init kernel_ebi1_mem_size_setup(char *p)
57{
58 kernel_ebi1_mem_size = memparse(p, NULL);
59 return 0;
60}
61early_param("kernel_ebi1_mem_size", kernel_ebi1_mem_size_setup);
62#endif
63
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -070064static struct memtype_reserve msm_8974_reserve_table[] __initdata = {
Olav Hauganb800c8c2012-01-30 08:50:45 -080065 [MEMTYPE_SMI] = {
66 },
67 [MEMTYPE_EBI0] = {
68 .flags = MEMTYPE_FLAGS_1M_ALIGN,
69 },
70 [MEMTYPE_EBI1] = {
71 .flags = MEMTYPE_FLAGS_1M_ALIGN,
72 },
73};
74
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -070075static int msm_8974_paddr_to_memtype(unsigned int paddr)
Olav Hauganb800c8c2012-01-30 08:50:45 -080076{
77 return MEMTYPE_EBI1;
78}
79
Olav Haugan49173442012-08-01 13:23:18 -070080static void __init reserve_ebi_memory(void)
Olav Hauganb800c8c2012-01-30 08:50:45 -080081{
Olav Hauganb800c8c2012-01-30 08:50:45 -080082#ifdef CONFIG_KERNEL_PMEM_EBI_REGION
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -070083 msm_8974_reserve_table[MEMTYPE_EBI1].size += kernel_ebi1_mem_size;
Olav Hauganb800c8c2012-01-30 08:50:45 -080084#endif
85}
Olav Hauganb800c8c2012-01-30 08:50:45 -080086
Jeff Hugo70946092012-02-10 11:30:43 -070087static struct resource smd_resource[] = {
88 {
89 .name = "modem_smd_in",
Jeff Hugo3417d072012-07-06 15:45:59 -060090 .start = 32 + 25, /* mss_sw_to_kpss_ipc_irq0 */
Jeff Hugo70946092012-02-10 11:30:43 -070091 .flags = IORESOURCE_IRQ,
92 },
93 {
94 .name = "modem_smsm_in",
Jeff Hugo3417d072012-07-06 15:45:59 -060095 .start = 32 + 26, /* mss_sw_to_kpss_ipc_irq1 */
Jeff Hugo70946092012-02-10 11:30:43 -070096 .flags = IORESOURCE_IRQ,
97 },
98 {
99 .name = "adsp_smd_in",
100 .start = 32 + 156, /* lpass_to_kpss_ipc_irq0 */
101 .flags = IORESOURCE_IRQ,
102 },
103 {
104 .name = "adsp_smsm_in",
105 .start = 32 + 157, /* lpass_to_kpss_ipc_irq1 */
106 .flags = IORESOURCE_IRQ,
107 },
108 {
109 .name = "wcnss_smd_in",
110 .start = 32 + 142, /* WcnssAppsSmdMedIrq */
111 .flags = IORESOURCE_IRQ,
112 },
113 {
114 .name = "wcnss_smsm_in",
Jeff Hugo89046272012-03-29 14:45:37 -0600115 .start = 32 + 144, /* RivaAppsWlanSmsmIrq */
Jeff Hugo70946092012-02-10 11:30:43 -0700116 .flags = IORESOURCE_IRQ,
117 },
Jeff Hugo9a5dc6e2012-03-29 14:39:42 -0600118 {
119 .name = "rpm_smd_in",
120 .start = 32 + 168, /* rpm_to_kpss_ipc_irq4 */
121 .flags = IORESOURCE_IRQ,
122 },
Jeff Hugo70946092012-02-10 11:30:43 -0700123};
124
125static struct smd_subsystem_config smd_config_list[] = {
126 {
127 .irq_config_id = SMD_MODEM,
128 .subsys_name = "modem",
129 .edge = SMD_APPS_MODEM,
130
131 .smd_int.irq_name = "modem_smd_in",
132 .smd_int.flags = IRQF_TRIGGER_RISING,
133 .smd_int.irq_id = -1,
134 .smd_int.device_name = "smd_dev",
135 .smd_int.dev_id = 0,
136 .smd_int.out_bit_pos = 1 << 12,
137 .smd_int.out_base = (void __iomem *)MSM_APCS_GCC_BASE,
138 .smd_int.out_offset = 0x8,
139
140 .smsm_int.irq_name = "modem_smsm_in",
141 .smsm_int.flags = IRQF_TRIGGER_RISING,
142 .smsm_int.irq_id = -1,
143 .smsm_int.device_name = "smsm_dev",
144 .smsm_int.dev_id = 0,
145 .smsm_int.out_bit_pos = 1 << 13,
146 .smsm_int.out_base = (void __iomem *)MSM_APCS_GCC_BASE,
147 .smsm_int.out_offset = 0x8,
148 },
149 {
150 .irq_config_id = SMD_Q6,
Jeff Hugoa1e3b8c2012-05-29 14:01:41 -0600151 .subsys_name = "adsp",
Jeff Hugo70946092012-02-10 11:30:43 -0700152 .edge = SMD_APPS_QDSP,
153
154 .smd_int.irq_name = "adsp_smd_in",
155 .smd_int.flags = IRQF_TRIGGER_RISING,
156 .smd_int.irq_id = -1,
157 .smd_int.device_name = "smd_dev",
158 .smd_int.dev_id = 0,
159 .smd_int.out_bit_pos = 1 << 8,
160 .smd_int.out_base = (void __iomem *)MSM_APCS_GCC_BASE,
161 .smd_int.out_offset = 0x8,
162
163 .smsm_int.irq_name = "adsp_smsm_in",
164 .smsm_int.flags = IRQF_TRIGGER_RISING,
165 .smsm_int.irq_id = -1,
166 .smsm_int.device_name = "smsm_dev",
167 .smsm_int.dev_id = 0,
168 .smsm_int.out_bit_pos = 1 << 9,
169 .smsm_int.out_base = (void __iomem *)MSM_APCS_GCC_BASE,
170 .smsm_int.out_offset = 0x8,
171 },
172 {
173 .irq_config_id = SMD_WCNSS,
174 .subsys_name = "wcnss",
175 .edge = SMD_APPS_WCNSS,
176
177 .smd_int.irq_name = "wcnss_smd_in",
178 .smd_int.flags = IRQF_TRIGGER_RISING,
179 .smd_int.irq_id = -1,
180 .smd_int.device_name = "smd_dev",
181 .smd_int.dev_id = 0,
182 .smd_int.out_bit_pos = 1 << 17,
183 .smd_int.out_base = (void __iomem *)MSM_APCS_GCC_BASE,
184 .smd_int.out_offset = 0x8,
185
186 .smsm_int.irq_name = "wcnss_smsm_in",
187 .smsm_int.flags = IRQF_TRIGGER_RISING,
188 .smsm_int.irq_id = -1,
189 .smsm_int.device_name = "smsm_dev",
190 .smsm_int.dev_id = 0,
191 .smsm_int.out_bit_pos = 1 << 19,
192 .smsm_int.out_base = (void __iomem *)MSM_APCS_GCC_BASE,
193 .smsm_int.out_offset = 0x8,
194 },
Jeff Hugo9a5dc6e2012-03-29 14:39:42 -0600195 {
196 .irq_config_id = SMD_RPM,
197 .subsys_name = NULL, /* do not use PIL to load RPM */
198 .edge = SMD_APPS_RPM,
199
200 .smd_int.irq_name = "rpm_smd_in",
201 .smd_int.flags = IRQF_TRIGGER_RISING,
202 .smd_int.irq_id = -1,
203 .smd_int.device_name = "smd_dev",
204 .smd_int.dev_id = 0,
205 .smd_int.out_bit_pos = 1 << 0,
206 .smd_int.out_base = (void __iomem *)MSM_APCS_GCC_BASE,
207 .smd_int.out_offset = 0x8,
208
209 .smsm_int.irq_name = NULL, /* RPM does not support SMSM */
210 .smsm_int.flags = 0,
211 .smsm_int.irq_id = 0,
212 .smsm_int.device_name = NULL,
213 .smsm_int.dev_id = 0,
214 .smsm_int.out_bit_pos = 0,
215 .smsm_int.out_base = NULL,
216 .smsm_int.out_offset = 0,
217 },
218};
219
220static struct smd_smem_regions aux_smem_areas[] = {
221 {
222 .phys_addr = (void *)(0xfc428000),
223 .size = 0x4000,
224 },
Jeff Hugo70946092012-02-10 11:30:43 -0700225};
226
Jeff Hugo3e366292012-03-29 15:19:14 -0600227static struct smd_subsystem_restart_config smd_ssr_cfg = {
228 .disable_smsm_reset_handshake = 1,
229};
230
Jeff Hugo70946092012-02-10 11:30:43 -0700231static struct smd_platform smd_platform_data = {
232 .num_ss_configs = ARRAY_SIZE(smd_config_list),
233 .smd_ss_configs = smd_config_list,
Jeff Hugo3e366292012-03-29 15:19:14 -0600234 .smd_ssr_config = &smd_ssr_cfg,
Jeff Hugo9a5dc6e2012-03-29 14:39:42 -0600235 .num_smem_areas = ARRAY_SIZE(aux_smem_areas),
236 .smd_smem_areas = aux_smem_areas,
Jeff Hugo70946092012-02-10 11:30:43 -0700237};
238
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700239struct platform_device msm_device_smd_8974 = {
Jeff Hugo70946092012-02-10 11:30:43 -0700240 .name = "msm_smd",
241 .id = -1,
242 .resource = smd_resource,
243 .num_resources = ARRAY_SIZE(smd_resource),
244 .dev = {
245 .platform_data = &smd_platform_data,
246 }
247};
248
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700249static void __init msm_8974_calculate_reserve_sizes(void)
Olav Hauganb800c8c2012-01-30 08:50:45 -0800250{
Olav Haugan49173442012-08-01 13:23:18 -0700251 reserve_ebi_memory();
Olav Hauganb800c8c2012-01-30 08:50:45 -0800252}
253
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700254static struct reserve_info msm_8974_reserve_info __initdata = {
255 .memtype_reserve_table = msm_8974_reserve_table,
256 .calculate_reserve_sizes = msm_8974_calculate_reserve_sizes,
257 .paddr_to_memtype = msm_8974_paddr_to_memtype,
Olav Hauganb800c8c2012-01-30 08:50:45 -0800258};
259
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700260static void __init msm_8974_early_memory(void)
Olav Hauganb800c8c2012-01-30 08:50:45 -0800261{
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700262 reserve_info = &msm_8974_reserve_info;
Laura Abbottd8d0f772012-07-10 10:27:06 -0700263 of_scan_flat_dt(dt_scan_for_memory_reserve, msm_8974_reserve_table);
Olav Hauganb800c8c2012-01-30 08:50:45 -0800264}
265
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700266void __init msm_8974_reserve(void)
Olav Hauganb800c8c2012-01-30 08:50:45 -0800267{
268 msm_reserve();
269}
270
Pavankumar Kondeti8c447382012-03-29 09:02:09 +0530271static struct platform_device android_usb_device = {
272 .name = "android_usb",
273 .id = -1,
274};
275
Gagan Macdd9bb792012-04-25 16:56:48 -0600276#define BIMC_BASE 0xfc380000
277#define BIMC_SIZE 0x0006A000
278#define SYS_NOC_BASE 0xfc460000
279#define PERIPH_NOC_BASE 0xFC468000
280#define OCMEM_NOC_BASE 0xfc470000
281#define MMSS_NOC_BASE 0xfc478000
282#define CONFIG_NOC_BASE 0xfc480000
283#define NOC_SIZE 0x00004000
284
285static struct resource bimc_res[] = {
286 {
287 .start = BIMC_BASE,
288 .end = BIMC_BASE + BIMC_SIZE,
289 .flags = IORESOURCE_MEM,
290 .name = "bimc_mem",
291 },
292};
293
294static struct resource ocmem_noc_res[] = {
295 {
296 .start = OCMEM_NOC_BASE,
297 .end = OCMEM_NOC_BASE + NOC_SIZE,
298 .flags = IORESOURCE_MEM,
299 .name = "ocmem_noc_mem",
300 },
301};
302
303static struct resource mmss_noc_res[] = {
304 {
305 .start = MMSS_NOC_BASE,
306 .end = MMSS_NOC_BASE + NOC_SIZE,
307 .flags = IORESOURCE_MEM,
308 .name = "mmss_noc_mem",
309 },
310};
311
312static struct resource sys_noc_res[] = {
313 {
314 .start = SYS_NOC_BASE,
315 .end = SYS_NOC_BASE + NOC_SIZE,
316 .flags = IORESOURCE_MEM,
317 .name = "sys_noc_mem",
318 },
319};
320
321static struct resource config_noc_res[] = {
322 {
323 .start = CONFIG_NOC_BASE,
324 .end = CONFIG_NOC_BASE + NOC_SIZE,
325 .flags = IORESOURCE_MEM,
326 .name = "config_noc_mem",
327 },
328};
329
330static struct resource periph_noc_res[] = {
331 {
332 .start = PERIPH_NOC_BASE,
333 .end = PERIPH_NOC_BASE + NOC_SIZE,
334 .flags = IORESOURCE_MEM,
335 .name = "periph_noc_mem",
336 },
337};
338
339static struct platform_device msm_bus_sys_noc = {
340 .name = "msm_bus_fabric",
341 .id = MSM_BUS_FAB_SYS_NOC,
342 .num_resources = ARRAY_SIZE(sys_noc_res),
343 .resource = sys_noc_res,
344};
345
346static struct platform_device msm_bus_bimc = {
347 .name = "msm_bus_fabric",
348 .id = MSM_BUS_FAB_BIMC,
349 .num_resources = ARRAY_SIZE(bimc_res),
350 .resource = bimc_res,
351};
352
353static struct platform_device msm_bus_mmss_noc = {
354 .name = "msm_bus_fabric",
355 .id = MSM_BUS_FAB_MMSS_NOC,
356 .num_resources = ARRAY_SIZE(mmss_noc_res),
357 .resource = mmss_noc_res,
358};
359
360static struct platform_device msm_bus_ocmem_noc = {
361 .name = "msm_bus_fabric",
362 .id = MSM_BUS_FAB_OCMEM_NOC,
363 .num_resources = ARRAY_SIZE(ocmem_noc_res),
364 .resource = ocmem_noc_res,
365};
366
367static struct platform_device msm_bus_periph_noc = {
368 .name = "msm_bus_fabric",
369 .id = MSM_BUS_FAB_PERIPH_NOC,
370 .num_resources = ARRAY_SIZE(periph_noc_res),
371 .resource = periph_noc_res,
372};
373
374static struct platform_device msm_bus_config_noc = {
375 .name = "msm_bus_fabric",
376 .id = MSM_BUS_FAB_CONFIG_NOC,
377 .num_resources = ARRAY_SIZE(config_noc_res),
378 .resource = config_noc_res,
379};
380
381static struct platform_device msm_bus_ocmem_vnoc = {
382 .name = "msm_bus_fabric",
383 .id = MSM_BUS_FAB_OCMEM_VNOC,
384};
385
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700386static struct platform_device *msm_bus_8974_devices[] = {
Gagan Macdd9bb792012-04-25 16:56:48 -0600387 &msm_bus_sys_noc,
388 &msm_bus_bimc,
389 &msm_bus_mmss_noc,
390 &msm_bus_ocmem_noc,
391 &msm_bus_periph_noc,
392 &msm_bus_config_noc,
393 &msm_bus_ocmem_vnoc,
394};
395
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700396static void __init msm8974_init_buses(void)
Gagan Macdd9bb792012-04-25 16:56:48 -0600397{
398#ifdef CONFIG_MSM_BUS_SCALING
399 msm_bus_sys_noc.dev.platform_data =
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700400 &msm_bus_8974_sys_noc_pdata;
401 msm_bus_bimc.dev.platform_data = &msm_bus_8974_bimc_pdata;
402 msm_bus_mmss_noc.dev.platform_data = &msm_bus_8974_mmss_noc_pdata;
403 msm_bus_ocmem_noc.dev.platform_data = &msm_bus_8974_ocmem_noc_pdata;
404 msm_bus_periph_noc.dev.platform_data = &msm_bus_8974_periph_noc_pdata;
405 msm_bus_config_noc.dev.platform_data = &msm_bus_8974_config_noc_pdata;
406 msm_bus_ocmem_vnoc.dev.platform_data = &msm_bus_8974_ocmem_vnoc_pdata;
Gagan Macdd9bb792012-04-25 16:56:48 -0600407#endif
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700408 platform_add_devices(msm_bus_8974_devices,
409 ARRAY_SIZE(msm_bus_8974_devices));
Gagan Macdd9bb792012-04-25 16:56:48 -0600410};
Hariprasad Dhalinarasimhaf42732a2012-05-21 18:00:49 -0700411
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700412void __init msm_8974_add_devices(void)
Sathish Ambleyc58afc22011-10-09 21:55:39 -0700413{
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700414 platform_device_register(&msm_device_smd_8974);
Pavankumar Kondeti8c447382012-03-29 09:02:09 +0530415 platform_device_register(&android_usb_device);
Sathish Ambleyc58afc22011-10-09 21:55:39 -0700416}
417
Vikram Mulukutlaaa6f36c2012-06-12 18:16:29 -0700418/*
419 * Used to satisfy dependencies for devices that need to be
420 * run early or in a particular order. Most likely your device doesn't fall
421 * into this category, and thus the driver should not be added here. The
422 * EPROBE_DEFER can satisfy most dependency problems.
423 */
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700424void __init msm_8974_add_drivers(void)
Vikram Mulukutlaaa6f36c2012-06-12 18:16:29 -0700425{
Jeff Hugoa643ca12012-06-11 16:00:23 -0600426 msm_init_modem_notifier_list();
Vikram Mulukutlaaa6f36c2012-06-12 18:16:29 -0700427 msm_smd_init();
428 msm_rpm_driver_init();
Girish Mahadevan40abbe12012-04-25 14:58:13 -0600429 msm_lpmrs_module_init();
Vikram Mulukutlaaa6f36c2012-06-12 18:16:29 -0700430 rpm_regulator_smd_driver_init();
431 msm_spm_device_init();
Michael Bohan2a468322012-08-14 17:06:34 -0700432 krait_power_init();
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700433 if (machine_is_msm8974_rumi())
Vikram Mulukutla19245e02012-07-23 15:58:04 -0700434 msm_clock_init(&msm8974_rumi_clock_init_data);
Vikram Mulukutlaaa6f36c2012-06-12 18:16:29 -0700435 else
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700436 msm_clock_init(&msm8974_clock_init_data);
437 msm8974_init_buses();
Eugene Seahce52ef22012-07-12 12:40:38 -0600438 msm_thermal_device_init();
Vikram Mulukutlaaa6f36c2012-06-12 18:16:29 -0700439}
440
441static struct of_device_id irq_match[] __initdata = {
442 { .compatible = "qcom,msm-qgic2", .data = gic_of_init, },
443 { .compatible = "qcom,msm-gpio", .data = msm_gpio_of_init, },
444 { .compatible = "qcom,spmi-pmic-arb", .data = qpnpint_of_init, },
445 {}
446};
Mahesh Sivasubramanian1a995322012-07-12 15:26:46 -0600447static struct of_device_id mpm_match[] __initdata = {
448 {.compatible = "qcom,mpm-v2", },
449 {},
450};
Vikram Mulukutlaaa6f36c2012-06-12 18:16:29 -0700451
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700452void __init msm_8974_init_irq(void)
Vikram Mulukutlaaa6f36c2012-06-12 18:16:29 -0700453{
Mahesh Sivasubramanian1a995322012-07-12 15:26:46 -0600454 struct device_node *node;
455
Vikram Mulukutlaaa6f36c2012-06-12 18:16:29 -0700456 of_irq_init(irq_match);
Mahesh Sivasubramanian1a995322012-07-12 15:26:46 -0600457 node = of_find_matching_node(NULL, mpm_match);
458
459 WARN_ON(!node);
460
461 if (node)
462 of_mpm_init(node);
Vikram Mulukutlaaa6f36c2012-06-12 18:16:29 -0700463}
464
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700465static struct of_dev_auxdata msm_8974_auxdata_lookup[] __initdata = {
Pavankumar Kondeti0063b842012-01-16 12:19:58 +0530466 OF_DEV_AUXDATA("qcom,hsusb-otg", 0xF9A55000, \
467 "msm_otg", NULL),
Manu Gautam51be9712012-06-06 14:54:52 +0530468 OF_DEV_AUXDATA("qcom,dwc-usb3-msm", 0xF9200000, \
469 "msm_dwc3", NULL),
Shimrit Malichi57ae1492012-08-06 14:03:45 +0300470 OF_DEV_AUXDATA("qcom,usb-bam-msm", 0xF9304000, \
471 "usb_bam", NULL),
Harini Jayaraman5f98dbb2011-12-20 13:38:19 -0700472 OF_DEV_AUXDATA("qcom,spi-qup-v2", 0xF9924000, \
473 "spi_qsd.1", NULL),
Kenneth Heitkef3c829c2012-01-13 17:02:43 -0700474 OF_DEV_AUXDATA("qcom,spmi-pmic-arb", 0xFC4C0000, \
475 "spmi-pmic-arb.0", NULL),
Sujit Reddy Thumma85fc52c2012-05-02 12:53:45 +0530476 OF_DEV_AUXDATA("qcom,msm-sdcc", 0xF9824000, \
David Ng665140f2012-04-12 16:03:45 -0700477 "msm_sdcc.1", NULL),
Sujit Reddy Thumma85fc52c2012-05-02 12:53:45 +0530478 OF_DEV_AUXDATA("qcom,msm-sdcc", 0xF98A4000, \
479 "msm_sdcc.2", NULL),
480 OF_DEV_AUXDATA("qcom,msm-sdcc", 0xF9864000, \
David Ng665140f2012-04-12 16:03:45 -0700481 "msm_sdcc.3", NULL),
Sujit Reddy Thumma85fc52c2012-05-02 12:53:45 +0530482 OF_DEV_AUXDATA("qcom,msm-sdcc", 0xF98E4000, \
483 "msm_sdcc.4", NULL),
Matt Wagantallc2bbdc32012-03-21 19:44:50 -0700484 OF_DEV_AUXDATA("qcom,pil-q6v5-lpass", 0xFE200000, \
485 "pil-q6v5-lpass", NULL),
Matt Wagantall4e2599e2012-03-21 22:31:35 -0700486 OF_DEV_AUXDATA("qcom,pil-q6v5-mss", 0xFC880000, "pil-q6v5-mss", NULL),
Matt Wagantalle6e00d52012-03-08 17:39:07 -0800487 OF_DEV_AUXDATA("qcom,pil-mba", 0xFC820000, "pil-mba", NULL),
Tianyi Gouc1e049f82011-11-23 14:20:16 -0800488 OF_DEV_AUXDATA("qcom,pil-pronto", 0xFB21B000, \
489 "pil_pronto", NULL),
Pratik Patel80515b52012-06-17 17:57:24 -0700490 OF_DEV_AUXDATA("arm,coresight-tmc", 0xFC322000, \
491 "coresight-tmc-etr", NULL),
492 OF_DEV_AUXDATA("arm,coresight-tpiu", 0xFC318000, \
493 "coresight-tpiu", NULL),
494 OF_DEV_AUXDATA("qcom,coresight-replicator", 0xFC31C000, \
495 "coresight-replicator", NULL),
496 OF_DEV_AUXDATA("arm,coresight-tmc", 0xFC307000, \
497 "coresight-tmc-etf", NULL),
498 OF_DEV_AUXDATA("arm,coresight-funnel", 0xFC31B000, \
499 "coresight-funnel-merg", NULL),
500 OF_DEV_AUXDATA("arm,coresight-funnel", 0xFC319000, \
501 "coresight-funnel-in0", NULL),
502 OF_DEV_AUXDATA("arm,coresight-funnel", 0xFC31A000, \
503 "coresight-funnel-in1", NULL),
504 OF_DEV_AUXDATA("arm,coresight-funnel", 0xFC345000, \
505 "coresight-funnel-kpss", NULL),
506 OF_DEV_AUXDATA("arm,coresight-funnel", 0xFC364000, \
507 "coresight-funnel-mmss", NULL),
508 OF_DEV_AUXDATA("arm,coresight-stm", 0xFC321000, \
509 "coresight-stm", NULL),
510 OF_DEV_AUXDATA("arm,coresight-etm", 0xFC33C000, \
511 "coresight-etm0", NULL),
512 OF_DEV_AUXDATA("arm,coresight-etm", 0xFC33D000, \
513 "coresight-etm1", NULL),
514 OF_DEV_AUXDATA("arm,coresight-etm", 0xFC33E000, \
515 "coresight-etm2", NULL),
516 OF_DEV_AUXDATA("arm,coresight-etm", 0xFC33F000, \
517 "coresight-etm3", NULL),
Hariprasad Dhalinarasimhade991f02012-05-31 13:15:51 -0700518 OF_DEV_AUXDATA("qcom,msm-rng", 0xF9BFF000, \
519 "msm_rng", NULL),
Ramesh Masavarapufb1f01e2012-06-14 09:40:40 -0700520 OF_DEV_AUXDATA("qcom,qseecom", 0xFE806000, \
521 "qseecom", NULL),
Adrian Salido-Moreno5ef3ac02012-05-14 18:40:47 -0700522 OF_DEV_AUXDATA("qcom,mdss_mdp", 0xFD900000, "mdp.0", NULL),
Siddartha Mohanadoss0a188882012-07-06 15:51:00 -0700523 OF_DEV_AUXDATA("qcom,msm-tsens", 0xFC4A8000, \
524 "msm-tsens", NULL),
Mona Hossainb43e94b2012-05-07 08:52:06 -0700525 OF_DEV_AUXDATA("qcom,qcedev", 0xFD440000, \
526 "qcedev.0", NULL),
527 OF_DEV_AUXDATA("qcom,qcrypto", 0xFD440000, \
528 "qcrypto.0", NULL),
Sathish Ambleyc58afc22011-10-09 21:55:39 -0700529 {}
530};
531
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700532void __init msm_8974_init(struct of_dev_auxdata **adata)
Sathish Ambleyc58afc22011-10-09 21:55:39 -0700533{
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700534 msm_8974_init_gpiomux();
Vikram Mulukutlaaeadb5f2012-05-04 14:03:07 -0700535
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700536 *adata = msm_8974_auxdata_lookup;
Matt Wagantallecaa1172012-05-08 21:38:45 -0700537
538 regulator_has_full_constraints();
Sathish Ambleyc58afc22011-10-09 21:55:39 -0700539}
Olav Hauganb800c8c2012-01-30 08:50:45 -0800540
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700541void __init msm_8974_very_early(void)
Olav Hauganb800c8c2012-01-30 08:50:45 -0800542{
Abhimanyu Kapur90ced6e2012-06-26 17:41:25 -0700543 msm_8974_early_memory();
Olav Hauganb800c8c2012-01-30 08:50:45 -0800544}