blob: 3606c41854f7a875caba3d4c66e009b44aff2019 [file] [log] [blame]
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07001/* Copyright (c) 2011, Code Aurora Forum. All rights reserved.
2 *
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
14#include <linux/kernel.h>
15#include <linux/list.h>
16#include <linux/platform_device.h>
17#include <linux/msm_rotator.h>
18#include <linux/clkdev.h>
19#include <mach/irqs-8064.h>
20#include <mach/board.h>
21#include <mach/msm_iomap.h>
Yan He06913ce2011-08-26 16:33:46 -070022#include <mach/usbdiag.h>
23#include <mach/msm_sps.h>
Jeff Ohlstein905f1ce2011-09-07 18:50:18 -070024#include <mach/dma.h>
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070025#include "clock.h"
26#include "devices.h"
27
28/* Address of GSBI blocks */
Stepan Moskovchenko2701a442011-08-19 13:47:22 -070029#define MSM_GSBI1_PHYS 0x12440000
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070030#define MSM_GSBI3_PHYS 0x16200000
Harini Jayaramanc4c58692011-07-19 14:50:10 -060031#define MSM_GSBI4_PHYS 0x16300000
32#define MSM_GSBI5_PHYS 0x1A200000
33#define MSM_GSBI6_PHYS 0x16500000
34#define MSM_GSBI7_PHYS 0x16600000
35
Kenneth Heitke748593a2011-07-15 15:45:11 -060036/* GSBI UART devices */
Stepan Moskovchenko2701a442011-08-19 13:47:22 -070037#define MSM_UART1DM_PHYS (MSM_GSBI1_PHYS + 0x10000)
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070038#define MSM_UART3DM_PHYS (MSM_GSBI3_PHYS + 0x40000)
39
Harini Jayaramanc4c58692011-07-19 14:50:10 -060040/* GSBI QUP devices */
41#define MSM_GSBI3_QUP_PHYS (MSM_GSBI3_PHYS + 0x80000)
42#define MSM_GSBI4_QUP_PHYS (MSM_GSBI4_PHYS + 0x80000)
43#define MSM_GSBI5_QUP_PHYS (MSM_GSBI5_PHYS + 0x80000)
44#define MSM_GSBI6_QUP_PHYS (MSM_GSBI6_PHYS + 0x80000)
45#define MSM_GSBI7_QUP_PHYS (MSM_GSBI7_PHYS + 0x80000)
46#define MSM_QUP_SIZE SZ_4K
47
Kenneth Heitke36920d32011-07-20 16:44:30 -060048/* Address of SSBI CMD */
49#define MSM_PMIC1_SSBI_CMD_PHYS 0x00500000
50#define MSM_PMIC2_SSBI_CMD_PHYS 0x00C00000
51#define MSM_PMIC_SSBI_SIZE SZ_4K
Harini Jayaramanc4c58692011-07-19 14:50:10 -060052
Hemant Kumarcaa09092011-07-30 00:26:33 -070053/* Address of HS USBOTG1 */
54#define MSM_HSUSB_PHYS 0x12500000
55#define MSM_HSUSB_SIZE SZ_4K
56
Joel King0581896d2011-07-19 16:43:28 -070057static struct resource msm_dmov_resource[] = {
58 {
59 .start = ADM_0_SCSS_0_IRQ,
Joel King0581896d2011-07-19 16:43:28 -070060 .flags = IORESOURCE_IRQ,
61 },
Jeff Ohlstein905f1ce2011-09-07 18:50:18 -070062 {
63 .start = 0x18300000,
64 .end = 0x18300000 + SZ_1M - 1,
65 .flags = IORESOURCE_MEM,
66 },
67};
68
69static struct msm_dmov_pdata msm_dmov_pdata = {
70 .sd = 0,
71 .sd_size = 0x800,
Joel King0581896d2011-07-19 16:43:28 -070072};
73
Stepan Moskovchenkodf13d342011-08-03 19:01:25 -070074struct platform_device apq8064_device_dmov = {
Joel King0581896d2011-07-19 16:43:28 -070075 .name = "msm_dmov",
76 .id = -1,
77 .resource = msm_dmov_resource,
78 .num_resources = ARRAY_SIZE(msm_dmov_resource),
Jeff Ohlstein905f1ce2011-09-07 18:50:18 -070079 .dev = {
80 .platform_data = &msm_dmov_pdata,
81 },
Joel King0581896d2011-07-19 16:43:28 -070082};
83
Stepan Moskovchenko2701a442011-08-19 13:47:22 -070084static struct resource resources_uart_gsbi1[] = {
85 {
86 .start = APQ8064_GSBI1_UARTDM_IRQ,
87 .end = APQ8064_GSBI1_UARTDM_IRQ,
88 .flags = IORESOURCE_IRQ,
89 },
90 {
91 .start = MSM_UART1DM_PHYS,
92 .end = MSM_UART1DM_PHYS + PAGE_SIZE - 1,
93 .name = "uartdm_resource",
94 .flags = IORESOURCE_MEM,
95 },
96 {
97 .start = MSM_GSBI1_PHYS,
98 .end = MSM_GSBI1_PHYS + PAGE_SIZE - 1,
99 .name = "gsbi_resource",
100 .flags = IORESOURCE_MEM,
101 },
102};
103
104struct platform_device apq8064_device_uart_gsbi1 = {
105 .name = "msm_serial_hsl",
106 .id = 0,
107 .num_resources = ARRAY_SIZE(resources_uart_gsbi1),
108 .resource = resources_uart_gsbi1,
109};
110
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700111static struct resource resources_uart_gsbi3[] = {
112 {
113 .start = GSBI3_UARTDM_IRQ,
114 .end = GSBI3_UARTDM_IRQ,
115 .flags = IORESOURCE_IRQ,
116 },
117 {
118 .start = MSM_UART3DM_PHYS,
119 .end = MSM_UART3DM_PHYS + PAGE_SIZE - 1,
120 .name = "uartdm_resource",
121 .flags = IORESOURCE_MEM,
122 },
123 {
124 .start = MSM_GSBI3_PHYS,
125 .end = MSM_GSBI3_PHYS + PAGE_SIZE - 1,
126 .name = "gsbi_resource",
127 .flags = IORESOURCE_MEM,
128 },
129};
130
131struct platform_device apq8064_device_uart_gsbi3 = {
132 .name = "msm_serial_hsl",
133 .id = 0,
134 .num_resources = ARRAY_SIZE(resources_uart_gsbi3),
135 .resource = resources_uart_gsbi3,
136};
137
Kenneth Heitke748593a2011-07-15 15:45:11 -0600138static struct resource resources_qup_i2c_gsbi4[] = {
139 {
140 .name = "gsbi_qup_i2c_addr",
141 .start = MSM_GSBI4_PHYS,
Harini Jayaramane1554a92011-09-15 14:43:02 -0600142 .end = MSM_GSBI4_PHYS + 4 - 1,
Kenneth Heitke748593a2011-07-15 15:45:11 -0600143 .flags = IORESOURCE_MEM,
144 },
145 {
146 .name = "qup_phys_addr",
147 .start = MSM_GSBI4_QUP_PHYS,
Harini Jayaramane1554a92011-09-15 14:43:02 -0600148 .end = MSM_GSBI4_QUP_PHYS + MSM_QUP_SIZE - 1,
Kenneth Heitke748593a2011-07-15 15:45:11 -0600149 .flags = IORESOURCE_MEM,
150 },
151 {
152 .name = "qup_err_intr",
153 .start = GSBI4_QUP_IRQ,
154 .end = GSBI4_QUP_IRQ,
155 .flags = IORESOURCE_IRQ,
156 },
157};
158
159struct platform_device apq8064_device_qup_i2c_gsbi4 = {
160 .name = "qup_i2c",
161 .id = 4,
162 .num_resources = ARRAY_SIZE(resources_qup_i2c_gsbi4),
163 .resource = resources_qup_i2c_gsbi4,
164};
165
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700166static struct resource resources_qup_spi_gsbi5[] = {
167 {
168 .name = "spi_base",
169 .start = MSM_GSBI5_QUP_PHYS,
170 .end = MSM_GSBI5_QUP_PHYS + SZ_4K - 1,
171 .flags = IORESOURCE_MEM,
172 },
173 {
174 .name = "gsbi_base",
175 .start = MSM_GSBI5_PHYS,
176 .end = MSM_GSBI5_PHYS + 4 - 1,
177 .flags = IORESOURCE_MEM,
178 },
179 {
180 .name = "spi_irq_in",
181 .start = GSBI5_QUP_IRQ,
182 .end = GSBI5_QUP_IRQ,
183 .flags = IORESOURCE_IRQ,
184 },
185};
186
187struct platform_device apq8064_device_qup_spi_gsbi5 = {
188 .name = "spi_qsd",
189 .id = 0,
190 .num_resources = ARRAY_SIZE(resources_qup_spi_gsbi5),
191 .resource = resources_qup_spi_gsbi5,
192};
193
194static struct resource resources_ssbi_pmic1[] = {
195 {
196 .start = MSM_PMIC1_SSBI_CMD_PHYS,
197 .end = MSM_PMIC1_SSBI_CMD_PHYS + MSM_PMIC_SSBI_SIZE - 1,
198 .flags = IORESOURCE_MEM,
199 },
200};
201
Sagar Dharia8bdcdaf2011-09-16 16:01:15 -0600202#define LPASS_SLIMBUS_PHYS 0x28080000
203#define LPASS_SLIMBUS_BAM_PHYS 0x28084000
204/* Board info for the slimbus slave device */
205static struct resource slimbus_res[] = {
206 {
207 .start = LPASS_SLIMBUS_PHYS,
208 .end = LPASS_SLIMBUS_PHYS + 8191,
209 .flags = IORESOURCE_MEM,
210 .name = "slimbus_physical",
211 },
212 {
213 .start = LPASS_SLIMBUS_BAM_PHYS,
214 .end = LPASS_SLIMBUS_BAM_PHYS + 8191,
215 .flags = IORESOURCE_MEM,
216 .name = "slimbus_bam_physical",
217 },
218 {
219 .start = SLIMBUS0_CORE_EE1_IRQ,
220 .end = SLIMBUS0_CORE_EE1_IRQ,
221 .flags = IORESOURCE_IRQ,
222 .name = "slimbus_irq",
223 },
224 {
225 .start = SLIMBUS0_BAM_EE1_IRQ,
226 .end = SLIMBUS0_BAM_EE1_IRQ,
227 .flags = IORESOURCE_IRQ,
228 .name = "slimbus_bam_irq",
229 },
230};
231
232struct platform_device apq8064_slim_ctrl = {
233 .name = "msm_slim_ctrl",
234 .id = 1,
235 .num_resources = ARRAY_SIZE(slimbus_res),
236 .resource = slimbus_res,
237 .dev = {
238 .coherent_dma_mask = 0xffffffffULL,
239 },
240};
241
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700242struct platform_device apq8064_device_ssbi_pmic1 = {
243 .name = "msm_ssbi",
244 .id = 0,
245 .resource = resources_ssbi_pmic1,
246 .num_resources = ARRAY_SIZE(resources_ssbi_pmic1),
247};
248
249static struct resource resources_ssbi_pmic2[] = {
250 {
251 .start = MSM_PMIC2_SSBI_CMD_PHYS,
252 .end = MSM_PMIC2_SSBI_CMD_PHYS + MSM_PMIC_SSBI_SIZE - 1,
253 .flags = IORESOURCE_MEM,
254 },
255};
256
257struct platform_device apq8064_device_ssbi_pmic2 = {
258 .name = "msm_ssbi",
259 .id = 1,
260 .resource = resources_ssbi_pmic2,
261 .num_resources = ARRAY_SIZE(resources_ssbi_pmic2),
262};
263
264static struct resource resources_otg[] = {
265 {
266 .start = MSM_HSUSB_PHYS,
267 .end = MSM_HSUSB_PHYS + MSM_HSUSB_SIZE - 1,
268 .flags = IORESOURCE_MEM,
269 },
270 {
271 .start = USB1_HS_IRQ,
272 .end = USB1_HS_IRQ,
273 .flags = IORESOURCE_IRQ,
274 },
275};
276
Stepan Moskovchenko14aa6492011-08-08 15:15:01 -0700277struct platform_device apq8064_device_otg = {
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700278 .name = "msm_otg",
279 .id = -1,
280 .num_resources = ARRAY_SIZE(resources_otg),
281 .resource = resources_otg,
282 .dev = {
283 .coherent_dma_mask = 0xffffffff,
284 },
285};
286
287static struct resource resources_hsusb[] = {
288 {
289 .start = MSM_HSUSB_PHYS,
290 .end = MSM_HSUSB_PHYS + MSM_HSUSB_SIZE - 1,
291 .flags = IORESOURCE_MEM,
292 },
293 {
294 .start = USB1_HS_IRQ,
295 .end = USB1_HS_IRQ,
296 .flags = IORESOURCE_IRQ,
297 },
298};
299
Stepan Moskovchenko14aa6492011-08-08 15:15:01 -0700300struct platform_device apq8064_device_gadget_peripheral = {
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700301 .name = "msm_hsusb",
302 .id = -1,
303 .num_resources = ARRAY_SIZE(resources_hsusb),
304 .resource = resources_hsusb,
305 .dev = {
306 .coherent_dma_mask = 0xffffffff,
307 },
308};
309
310#define MSM_SDC1_BASE 0x12400000
311#define MSM_SDC1_DML_BASE (MSM_SDC1_BASE + 0x800)
312#define MSM_SDC1_BAM_BASE (MSM_SDC1_BASE + 0x2000)
313#define MSM_SDC2_BASE 0x12140000
314#define MSM_SDC2_DML_BASE (MSM_SDC2_BASE + 0x800)
315#define MSM_SDC2_BAM_BASE (MSM_SDC2_BASE + 0x2000)
316#define MSM_SDC3_BASE 0x12180000
317#define MSM_SDC3_DML_BASE (MSM_SDC3_BASE + 0x800)
318#define MSM_SDC3_BAM_BASE (MSM_SDC3_BASE + 0x2000)
319#define MSM_SDC4_BASE 0x121C0000
320#define MSM_SDC4_DML_BASE (MSM_SDC4_BASE + 0x800)
321#define MSM_SDC4_BAM_BASE (MSM_SDC4_BASE + 0x2000)
322
323static struct resource resources_sdc1[] = {
324 {
325 .name = "core_mem",
326 .flags = IORESOURCE_MEM,
327 .start = MSM_SDC1_BASE,
328 .end = MSM_SDC1_DML_BASE - 1,
329 },
330 {
331 .name = "core_irq",
332 .flags = IORESOURCE_IRQ,
333 .start = SDC1_IRQ_0,
334 .end = SDC1_IRQ_0
335 },
336#ifdef CONFIG_MMC_MSM_SPS_SUPPORT
337 {
338 .name = "sdcc_dml_addr",
339 .start = MSM_SDC1_DML_BASE,
340 .end = MSM_SDC1_BAM_BASE - 1,
341 .flags = IORESOURCE_MEM,
342 },
343 {
344 .name = "sdcc_bam_addr",
345 .start = MSM_SDC1_BAM_BASE,
346 .end = MSM_SDC1_BAM_BASE + (2 * SZ_4K) - 1,
347 .flags = IORESOURCE_MEM,
348 },
349 {
350 .name = "sdcc_bam_irq",
351 .start = SDC1_BAM_IRQ,
352 .end = SDC1_BAM_IRQ,
353 .flags = IORESOURCE_IRQ,
354 },
355#endif
356};
357
358static struct resource resources_sdc2[] = {
359 {
360 .name = "core_mem",
361 .flags = IORESOURCE_MEM,
362 .start = MSM_SDC2_BASE,
363 .end = MSM_SDC2_DML_BASE - 1,
364 },
365 {
366 .name = "core_irq",
367 .flags = IORESOURCE_IRQ,
368 .start = SDC2_IRQ_0,
369 .end = SDC2_IRQ_0
370 },
371#ifdef CONFIG_MMC_MSM_SPS_SUPPORT
372 {
373 .name = "sdcc_dml_addr",
374 .start = MSM_SDC2_DML_BASE,
375 .end = MSM_SDC2_BAM_BASE - 1,
376 .flags = IORESOURCE_MEM,
377 },
378 {
379 .name = "sdcc_bam_addr",
380 .start = MSM_SDC2_BAM_BASE,
381 .end = MSM_SDC2_BAM_BASE + (2 * SZ_4K) - 1,
382 .flags = IORESOURCE_MEM,
383 },
384 {
385 .name = "sdcc_bam_irq",
386 .start = SDC2_BAM_IRQ,
387 .end = SDC2_BAM_IRQ,
388 .flags = IORESOURCE_IRQ,
389 },
390#endif
391};
392
393static struct resource resources_sdc3[] = {
394 {
395 .name = "core_mem",
396 .flags = IORESOURCE_MEM,
397 .start = MSM_SDC3_BASE,
398 .end = MSM_SDC3_DML_BASE - 1,
399 },
400 {
401 .name = "core_irq",
402 .flags = IORESOURCE_IRQ,
403 .start = SDC3_IRQ_0,
404 .end = SDC3_IRQ_0
405 },
406#ifdef CONFIG_MMC_MSM_SPS_SUPPORT
407 {
408 .name = "sdcc_dml_addr",
409 .start = MSM_SDC3_DML_BASE,
410 .end = MSM_SDC3_BAM_BASE - 1,
411 .flags = IORESOURCE_MEM,
412 },
413 {
414 .name = "sdcc_bam_addr",
415 .start = MSM_SDC3_BAM_BASE,
416 .end = MSM_SDC3_BAM_BASE + (2 * SZ_4K) - 1,
417 .flags = IORESOURCE_MEM,
418 },
419 {
420 .name = "sdcc_bam_irq",
421 .start = SDC3_BAM_IRQ,
422 .end = SDC3_BAM_IRQ,
423 .flags = IORESOURCE_IRQ,
424 },
425#endif
426};
427
428static struct resource resources_sdc4[] = {
429 {
430 .name = "core_mem",
431 .flags = IORESOURCE_MEM,
432 .start = MSM_SDC4_BASE,
433 .end = MSM_SDC4_DML_BASE - 1,
434 },
435 {
436 .name = "core_irq",
437 .flags = IORESOURCE_IRQ,
438 .start = SDC4_IRQ_0,
439 .end = SDC4_IRQ_0
440 },
441#ifdef CONFIG_MMC_MSM_SPS_SUPPORT
442 {
443 .name = "sdcc_dml_addr",
444 .start = MSM_SDC4_DML_BASE,
445 .end = MSM_SDC4_BAM_BASE - 1,
446 .flags = IORESOURCE_MEM,
447 },
448 {
449 .name = "sdcc_bam_addr",
450 .start = MSM_SDC4_BAM_BASE,
451 .end = MSM_SDC4_BAM_BASE + (2 * SZ_4K) - 1,
452 .flags = IORESOURCE_MEM,
453 },
454 {
455 .name = "sdcc_bam_irq",
456 .start = SDC4_BAM_IRQ,
457 .end = SDC4_BAM_IRQ,
458 .flags = IORESOURCE_IRQ,
459 },
460#endif
461};
462
463struct platform_device apq8064_device_sdc1 = {
464 .name = "msm_sdcc",
465 .id = 1,
466 .num_resources = ARRAY_SIZE(resources_sdc1),
467 .resource = resources_sdc1,
468 .dev = {
469 .coherent_dma_mask = 0xffffffff,
470 },
471};
472
473struct platform_device apq8064_device_sdc2 = {
474 .name = "msm_sdcc",
475 .id = 2,
476 .num_resources = ARRAY_SIZE(resources_sdc2),
477 .resource = resources_sdc2,
478 .dev = {
479 .coherent_dma_mask = 0xffffffff,
480 },
481};
482
483struct platform_device apq8064_device_sdc3 = {
484 .name = "msm_sdcc",
485 .id = 3,
486 .num_resources = ARRAY_SIZE(resources_sdc3),
487 .resource = resources_sdc3,
488 .dev = {
489 .coherent_dma_mask = 0xffffffff,
490 },
491};
492
493struct platform_device apq8064_device_sdc4 = {
494 .name = "msm_sdcc",
495 .id = 4,
496 .num_resources = ARRAY_SIZE(resources_sdc4),
497 .resource = resources_sdc4,
498 .dev = {
499 .coherent_dma_mask = 0xffffffff,
500 },
501};
502
503static struct platform_device *apq8064_sdcc_devices[] __initdata = {
504 &apq8064_device_sdc1,
505 &apq8064_device_sdc2,
506 &apq8064_device_sdc3,
507 &apq8064_device_sdc4,
508};
509
510int __init apq8064_add_sdcc(unsigned int controller,
511 struct mmc_platform_data *plat)
512{
513 struct platform_device *pdev;
514
515 if (!plat)
516 return 0;
517 if (controller < 1 || controller > 4)
518 return -EINVAL;
519
520 pdev = apq8064_sdcc_devices[controller-1];
521 pdev->dev.platform_data = plat;
522 return platform_device_register(pdev);
523}
524
Yan He06913ce2011-08-26 16:33:46 -0700525static struct resource resources_sps[] = {
526 {
527 .name = "pipe_mem",
528 .start = 0x12800000,
529 .end = 0x12800000 + 0x4000 - 1,
530 .flags = IORESOURCE_MEM,
531 },
532 {
533 .name = "bamdma_dma",
534 .start = 0x12240000,
535 .end = 0x12240000 + 0x1000 - 1,
536 .flags = IORESOURCE_MEM,
537 },
538 {
539 .name = "bamdma_bam",
540 .start = 0x12244000,
541 .end = 0x12244000 + 0x4000 - 1,
542 .flags = IORESOURCE_MEM,
543 },
544 {
545 .name = "bamdma_irq",
546 .start = SPS_BAM_DMA_IRQ,
547 .end = SPS_BAM_DMA_IRQ,
548 .flags = IORESOURCE_IRQ,
549 },
550};
551
552static struct msm_sps_platform_data msm_sps_pdata = {
553 .bamdma_restricted_pipes = 0x06,
554};
555
556struct platform_device msm_device_sps_apq8064 = {
557 .name = "msm_sps",
558 .id = -1,
559 .num_resources = ARRAY_SIZE(resources_sps),
560 .resource = resources_sps,
561 .dev.platform_data = &msm_sps_pdata,
562};
563
Jeff Hugo0c0f5e92011-09-28 13:55:45 -0600564struct platform_device msm_device_smd_apq8064 = {
565 .name = "msm_smd",
566 .id = -1,
567};
568
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700569static struct clk_lookup msm_clocks_8064_dummy[] = {
570 CLK_DUMMY("pll2", PLL2, NULL, 0),
571 CLK_DUMMY("pll8", PLL8, NULL, 0),
572 CLK_DUMMY("pll4", PLL4, NULL, 0),
573
574 CLK_DUMMY("afab_clk", AFAB_CLK, NULL, 0),
575 CLK_DUMMY("afab_a_clk", AFAB_A_CLK, NULL, 0),
576 CLK_DUMMY("cfpb_clk", CFPB_CLK, NULL, 0),
577 CLK_DUMMY("cfpb_a_clk", CFPB_A_CLK, NULL, 0),
578 CLK_DUMMY("dfab_clk", DFAB_CLK, NULL, 0),
579 CLK_DUMMY("dfab_a_clk", DFAB_A_CLK, NULL, 0),
580 CLK_DUMMY("ebi1_clk", EBI1_CLK, NULL, 0),
581 CLK_DUMMY("ebi1_a_clk", EBI1_A_CLK, NULL, 0),
582 CLK_DUMMY("mmfab_clk", MMFAB_CLK, NULL, 0),
583 CLK_DUMMY("mmfab_a_clk", MMFAB_A_CLK, NULL, 0),
584 CLK_DUMMY("mmfpb_clk", MMFPB_CLK, NULL, 0),
585 CLK_DUMMY("mmfpb_a_clk", MMFPB_A_CLK, NULL, 0),
586 CLK_DUMMY("sfab_clk", SFAB_CLK, NULL, 0),
587 CLK_DUMMY("sfab_a_clk", SFAB_A_CLK, NULL, 0),
588 CLK_DUMMY("sfpb_clk", SFPB_CLK, NULL, 0),
589 CLK_DUMMY("sfpb_a_clk", SFPB_A_CLK, NULL, 0),
590
Matt Wagantalle2522372011-08-17 14:52:21 -0700591 CLK_DUMMY("core_clk", GSBI1_UART_CLK, NULL, OFF),
592 CLK_DUMMY("core_clk", GSBI2_UART_CLK, NULL, OFF),
593 CLK_DUMMY("core_clk", GSBI3_UART_CLK,
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700594 "msm_serial_hsl.0", OFF),
Matt Wagantalle2522372011-08-17 14:52:21 -0700595 CLK_DUMMY("core_clk", GSBI4_UART_CLK, NULL, OFF),
596 CLK_DUMMY("core_clk", GSBI5_UART_CLK, NULL, OFF),
597 CLK_DUMMY("core_clk", GSBI6_UART_CLK, NULL, OFF),
598 CLK_DUMMY("core_clk", GSBI7_UART_CLK, NULL, OFF),
599 CLK_DUMMY("core_clk", GSBI8_UART_CLK, NULL, OFF),
600 CLK_DUMMY("core_clk", GSBI9_UART_CLK, NULL, OFF),
601 CLK_DUMMY("core_clk", GSBI10_UART_CLK, NULL, OFF),
602 CLK_DUMMY("core_clk", GSBI11_UART_CLK, NULL, OFF),
603 CLK_DUMMY("core_clk", GSBI12_UART_CLK, NULL, OFF),
Matt Wagantall62cf63e2011-08-17 16:34:47 -0700604 CLK_DUMMY("core_clk", GSBI1_QUP_CLK, NULL, OFF),
605 CLK_DUMMY("core_clk", GSBI2_QUP_CLK, NULL, OFF),
606 CLK_DUMMY("core_clk", GSBI3_QUP_CLK, NULL, OFF),
Matt Wagantallac294852011-08-17 15:44:58 -0700607 CLK_DUMMY("core_clk", GSBI4_QUP_CLK, "qup_i2c.4", OFF),
608 CLK_DUMMY("core_clk", GSBI5_QUP_CLK, "spi_qsd.0", OFF),
Matt Wagantall62cf63e2011-08-17 16:34:47 -0700609 CLK_DUMMY("core_clk", GSBI6_QUP_CLK, NULL, OFF),
610 CLK_DUMMY("core_clk", GSBI7_QUP_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700611 CLK_DUMMY("pdm_clk", PDM_CLK, NULL, OFF),
Matt Wagantalld86d6832011-08-17 14:06:55 -0700612 CLK_DUMMY("mem_clk", PMEM_CLK, NULL, OFF),
Matt Wagantallc1205292011-08-11 17:19:31 -0700613 CLK_DUMMY("core_clk", PRNG_CLK, NULL, OFF),
Matt Wagantall37ce3842011-08-17 16:00:36 -0700614 CLK_DUMMY("core_clk", SDC1_CLK, NULL, OFF),
615 CLK_DUMMY("core_clk", SDC2_CLK, NULL, OFF),
616 CLK_DUMMY("core_clk", SDC3_CLK, NULL, OFF),
617 CLK_DUMMY("core_clk", SDC4_CLK, NULL, OFF),
Matt Wagantall640e5fd2011-08-17 16:08:53 -0700618 CLK_DUMMY("ref_clk", TSIF_REF_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700619 CLK_DUMMY("tssc_clk", TSSC_CLK, NULL, OFF),
620 CLK_DUMMY("usb_hs_clk", USB_HS1_XCVR_CLK, NULL, OFF),
Tianyi Gou86bb4722011-08-09 13:28:02 -0700621 CLK_DUMMY("usb_hs_clk", USB_HS3_XCVR_CLK, NULL, OFF),
622 CLK_DUMMY("usb_hs_clk", USB_HS4_XCVR_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700623 CLK_DUMMY("usb_phy_clk", USB_PHY0_CLK, NULL, OFF),
624 CLK_DUMMY("usb_fs_src_clk", USB_FS1_SRC_CLK, NULL, OFF),
625 CLK_DUMMY("usb_fs_clk", USB_FS1_XCVR_CLK, NULL, OFF),
626 CLK_DUMMY("usb_fs_sys_clk", USB_FS1_SYS_CLK, NULL, OFF),
Matt Wagantallc4b3a4d2011-08-17 16:58:39 -0700627 CLK_DUMMY("core_clk", CE2_CLK, NULL, OFF),
628 CLK_DUMMY("core_clk", CE1_CORE_CLK, NULL, OFF),
629 CLK_DUMMY("core_clk", CE3_CORE_CLK, NULL, OFF),
630 CLK_DUMMY("iface_clk", CE3_P_CLK, NULL, OFF),
Tianyi Gou86bb4722011-08-09 13:28:02 -0700631 CLK_DUMMY("pcie_pclk", PCIE_P_CLK, NULL, OFF),
632 CLK_DUMMY("pcie_alt_ref_clk", PCIE_ALT_REF_CLK, NULL, OFF),
633 CLK_DUMMY("sata_rxoob_clk", SATA_RXOOB_CLK, NULL, OFF),
634 CLK_DUMMY("sata_pmalive_clk", SATA_PMALIVE_CLK, NULL, OFF),
635 CLK_DUMMY("sata_phy_ref_clk", SATA_PHY_REF_CLK, NULL, OFF),
Matt Wagantall62cf63e2011-08-17 16:34:47 -0700636 CLK_DUMMY("iface_clk", GSBI1_P_CLK, NULL, OFF),
637 CLK_DUMMY("iface_clk", GSBI2_P_CLK, NULL, OFF),
Matt Wagantalle2522372011-08-17 14:52:21 -0700638 CLK_DUMMY("iface_clk", GSBI3_P_CLK, "msm_serial_hsl.0", OFF),
Matt Wagantallac294852011-08-17 15:44:58 -0700639 CLK_DUMMY("iface_clk", GSBI4_P_CLK, "qup_i2c.4", OFF),
640 CLK_DUMMY("iface_clk", GSBI5_P_CLK, "spi_qsd.0", OFF),
Matt Wagantalle2522372011-08-17 14:52:21 -0700641 CLK_DUMMY("iface_clk", GSBI6_P_CLK, NULL, OFF),
Matt Wagantall62cf63e2011-08-17 16:34:47 -0700642 CLK_DUMMY("iface_clk", GSBI7_P_CLK, NULL, OFF),
Matt Wagantall640e5fd2011-08-17 16:08:53 -0700643 CLK_DUMMY("iface_clk", TSIF_P_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700644 CLK_DUMMY("usb_fs_pclk", USB_FS1_P_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700645 CLK_DUMMY("usb_hs_pclk", USB_HS1_P_CLK, NULL, OFF),
Tianyi Gou86bb4722011-08-09 13:28:02 -0700646 CLK_DUMMY("usb_hs_pclk", USB_HS3_P_CLK, NULL, OFF),
647 CLK_DUMMY("usb_hs_pclk", USB_HS4_P_CLK, NULL, OFF),
Matt Wagantall37ce3842011-08-17 16:00:36 -0700648 CLK_DUMMY("iface_clk", SDC1_P_CLK, NULL, OFF),
649 CLK_DUMMY("iface_clk", SDC2_P_CLK, NULL, OFF),
650 CLK_DUMMY("iface_clk", SDC3_P_CLK, NULL, OFF),
651 CLK_DUMMY("iface_clk", SDC4_P_CLK, NULL, OFF),
Matt Wagantalle1a86062011-08-18 17:46:10 -0700652 CLK_DUMMY("core_clk", ADM0_CLK, NULL, OFF),
653 CLK_DUMMY("iface_clk", ADM0_P_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700654 CLK_DUMMY("pmic_arb_pclk", PMIC_ARB0_P_CLK, NULL, OFF),
655 CLK_DUMMY("pmic_arb_pclk", PMIC_ARB1_P_CLK, NULL, OFF),
656 CLK_DUMMY("pmic_ssbi2", PMIC_SSBI2_CLK, NULL, OFF),
657 CLK_DUMMY("rpm_msg_ram_pclk", RPM_MSG_RAM_P_CLK, NULL, OFF),
658 CLK_DUMMY("amp_clk", AMP_CLK, NULL, OFF),
659 CLK_DUMMY("cam_clk", CAM0_CLK, NULL, OFF),
660 CLK_DUMMY("cam_clk", CAM1_CLK, NULL, OFF),
661 CLK_DUMMY("csi_src_clk", CSI0_SRC_CLK, NULL, OFF),
662 CLK_DUMMY("csi_src_clk", CSI1_SRC_CLK, NULL, OFF),
663 CLK_DUMMY("csi_clk", CSI0_CLK, NULL, OFF),
664 CLK_DUMMY("csi_clk", CSI1_CLK, NULL, OFF),
665 CLK_DUMMY("csi_pix_clk", CSI_PIX_CLK, NULL, OFF),
666 CLK_DUMMY("csi_rdi_clk", CSI_RDI_CLK, NULL, OFF),
667 CLK_DUMMY("csiphy_timer_src_clk", CSIPHY_TIMER_SRC_CLK, NULL, OFF),
668 CLK_DUMMY("csi0phy_timer_clk", CSIPHY0_TIMER_CLK, NULL, OFF),
669 CLK_DUMMY("csi1phy_timer_clk", CSIPHY1_TIMER_CLK, NULL, OFF),
670 CLK_DUMMY("dsi_byte_div_clk", DSI1_BYTE_CLK, NULL, OFF),
671 CLK_DUMMY("dsi_byte_div_clk", DSI2_BYTE_CLK, NULL, OFF),
672 CLK_DUMMY("dsi_esc_clk", DSI1_ESC_CLK, NULL, OFF),
673 CLK_DUMMY("dsi_esc_clk", DSI2_ESC_CLK, NULL, OFF),
Matt Wagantall9dc01632011-08-17 18:55:04 -0700674 CLK_DUMMY("core_clk", VCAP_CLK, NULL, OFF),
675 CLK_DUMMY("npl_clk", VCAP_NPL_CLK, NULL, OFF),
676 CLK_DUMMY("core_clk", GFX3D_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700677 CLK_DUMMY("ijpeg_clk", IJPEG_CLK, NULL, OFF),
Matt Wagantall9dc01632011-08-17 18:55:04 -0700678 CLK_DUMMY("mem_clk", IMEM_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700679 CLK_DUMMY("jpegd_clk", JPEGD_CLK, NULL, OFF),
680 CLK_DUMMY("mdp_clk", MDP_CLK, NULL, OFF),
681 CLK_DUMMY("mdp_vsync_clk", MDP_VSYNC_CLK, NULL, OFF),
682 CLK_DUMMY("lut_mdp", LUT_MDP_CLK, NULL, OFF),
683 CLK_DUMMY("rot_clk", ROT_CLK, NULL, OFF),
684 CLK_DUMMY("tv_src_clk", TV_SRC_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700685 CLK_DUMMY("vcodec_clk", VCODEC_CLK, NULL, OFF),
686 CLK_DUMMY("mdp_tv_clk", MDP_TV_CLK, NULL, OFF),
Tianyi Gou86bb4722011-08-09 13:28:02 -0700687 CLK_DUMMY("rgb_tv_clk", RGB_TV_CLK, NULL, OFF),
688 CLK_DUMMY("npl_tv_clk", NPL_TV_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700689 CLK_DUMMY("hdmi_clk", HDMI_TV_CLK, NULL, OFF),
Matt Wagantall5a4f1ba2011-08-18 18:13:03 -0700690 CLK_DUMMY("core_clk", HDMI_APP_CLK, "hdmi_msm.1", OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700691 CLK_DUMMY("vpe_clk", VPE_CLK, NULL, OFF),
692 CLK_DUMMY("vfe_clk", VFE_CLK, NULL, OFF),
693 CLK_DUMMY("csi_vfe_clk", CSI0_VFE_CLK, NULL, OFF),
694 CLK_DUMMY("vfe_axi_clk", VFE_AXI_CLK, NULL, OFF),
695 CLK_DUMMY("ijpeg_axi_clk", IJPEG_AXI_CLK, NULL, OFF),
696 CLK_DUMMY("mdp_axi_clk", MDP_AXI_CLK, NULL, OFF),
697 CLK_DUMMY("rot_axi_clk", ROT_AXI_CLK, NULL, OFF),
698 CLK_DUMMY("vcodec_axi_clk", VCODEC_AXI_CLK, NULL, OFF),
699 CLK_DUMMY("vcodec_axi_a_clk", VCODEC_AXI_A_CLK, NULL, OFF),
700 CLK_DUMMY("vcodec_axi_b_clk", VCODEC_AXI_B_CLK, NULL, OFF),
701 CLK_DUMMY("vpe_axi_clk", VPE_AXI_CLK, NULL, OFF),
Matt Wagantall9dc01632011-08-17 18:55:04 -0700702 CLK_DUMMY("bus_clk", GFX3D_AXI_CLK, NULL, OFF),
Tianyi Gou86bb4722011-08-09 13:28:02 -0700703 CLK_DUMMY("vcap_axi_clk", VCAP_AXI_CLK, NULL, OFF),
704 CLK_DUMMY("vcap_ahb_clk", VCAP_AHB_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700705 CLK_DUMMY("amp_pclk", AMP_P_CLK, NULL, OFF),
706 CLK_DUMMY("csi_pclk", CSI0_P_CLK, NULL, OFF),
707 CLK_DUMMY("dsi_m_pclk", DSI1_M_P_CLK, NULL, OFF),
708 CLK_DUMMY("dsi_s_pclk", DSI1_S_P_CLK, NULL, OFF),
709 CLK_DUMMY("dsi_m_pclk", DSI2_M_P_CLK, NULL, OFF),
710 CLK_DUMMY("dsi_s_pclk", DSI2_S_P_CLK, NULL, OFF),
Tianyi Gou86bb4722011-08-09 13:28:02 -0700711 CLK_DUMMY("lvds_clk", LVDS_CLK, NULL, OFF),
712 CLK_DUMMY("mdp_p2clk", MDP_P2CLK, NULL, OFF),
713 CLK_DUMMY("dsi2_pixel_clk", DSI2_PIXEL_CLK, NULL, OFF),
714 CLK_DUMMY("lvds_ref_clk", LVDS_REF_CLK, NULL, OFF),
Matt Wagantall9dc01632011-08-17 18:55:04 -0700715 CLK_DUMMY("iface_clk", GFX3D_P_CLK, NULL, OFF),
Matt Wagantall5a4f1ba2011-08-18 18:13:03 -0700716 CLK_DUMMY("master_iface_clk", HDMI_M_P_CLK, "hdmi_msm.1", OFF),
717 CLK_DUMMY("slave_iface_clk", HDMI_S_P_CLK, "hdmi_msm.1", OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700718 CLK_DUMMY("ijpeg_pclk", IJPEG_P_CLK, NULL, OFF),
719 CLK_DUMMY("jpegd_pclk", JPEGD_P_CLK, NULL, OFF),
Matt Wagantall9dc01632011-08-17 18:55:04 -0700720 CLK_DUMMY("mem_iface_clk", IMEM_P_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700721 CLK_DUMMY("mdp_pclk", MDP_P_CLK, NULL, OFF),
722 CLK_DUMMY("smmu_pclk", SMMU_P_CLK, NULL, OFF),
723 CLK_DUMMY("rotator_pclk", ROT_P_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700724 CLK_DUMMY("vcodec_pclk", VCODEC_P_CLK, NULL, OFF),
725 CLK_DUMMY("vfe_pclk", VFE_P_CLK, NULL, OFF),
726 CLK_DUMMY("vpe_pclk", VPE_P_CLK, NULL, OFF),
727 CLK_DUMMY("mi2s_osr_clk", MI2S_OSR_CLK, NULL, OFF),
728 CLK_DUMMY("mi2s_bit_clk", MI2S_BIT_CLK, NULL, OFF),
729 CLK_DUMMY("i2s_mic_osr_clk", CODEC_I2S_MIC_OSR_CLK, NULL, OFF),
730 CLK_DUMMY("i2s_mic_bit_clk", CODEC_I2S_MIC_BIT_CLK, NULL, OFF),
731 CLK_DUMMY("i2s_mic_osr_clk", SPARE_I2S_MIC_OSR_CLK, NULL, OFF),
732 CLK_DUMMY("i2s_mic_bit_clk", SPARE_I2S_MIC_BIT_CLK, NULL, OFF),
733 CLK_DUMMY("i2s_spkr_osr_clk", CODEC_I2S_SPKR_OSR_CLK, NULL, OFF),
734 CLK_DUMMY("i2s_spkr_bit_clk", CODEC_I2S_SPKR_BIT_CLK, NULL, OFF),
735 CLK_DUMMY("i2s_spkr_osr_clk", SPARE_I2S_SPKR_OSR_CLK, NULL, OFF),
736 CLK_DUMMY("i2s_spkr_bit_clk", SPARE_I2S_SPKR_BIT_CLK, NULL, OFF),
737 CLK_DUMMY("pcm_clk", PCM_CLK, NULL, OFF),
Tianyi Gou142b8db2011-09-21 18:01:54 -0700738 CLK_DUMMY("audio_slimbus_clk", AUDIO_SLIMBUS_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700739 CLK_DUMMY("iommu_clk", JPEGD_AXI_CLK, NULL, 0),
740 CLK_DUMMY("iommu_clk", VFE_AXI_CLK, NULL, 0),
741 CLK_DUMMY("iommu_clk", VCODEC_AXI_CLK, NULL, 0),
742 CLK_DUMMY("iommu_clk", GFX3D_CLK, NULL, 0),
743 CLK_DUMMY("iommu_clk", GFX2D0_CLK, NULL, 0),
744 CLK_DUMMY("iommu_clk", GFX2D1_CLK, NULL, 0),
745
746 CLK_DUMMY("dfab_dsps_clk", DFAB_DSPS_CLK, NULL, 0),
747 CLK_DUMMY("dfab_usb_hs_clk", DFAB_USB_HS_CLK, NULL, 0),
Matt Wagantall37ce3842011-08-17 16:00:36 -0700748 CLK_DUMMY("bus_clk", DFAB_SDC1_CLK, NULL, 0),
749 CLK_DUMMY("bus_clk", DFAB_SDC2_CLK, NULL, 0),
750 CLK_DUMMY("bus_clk", DFAB_SDC3_CLK, NULL, 0),
751 CLK_DUMMY("bus_clk", DFAB_SDC4_CLK, NULL, 0),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700752 CLK_DUMMY("dfab_clk", DFAB_CLK, NULL, 0),
753 CLK_DUMMY("dma_bam_pclk", DMA_BAM_P_CLK, NULL, 0),
754};
755
Stephen Boydbb600ae2011-08-02 20:11:40 -0700756struct clock_init_data apq8064_dummy_clock_init_data __initdata = {
757 .table = msm_clocks_8064_dummy,
758 .size = ARRAY_SIZE(msm_clocks_8064_dummy),
759};