blob: 9b8d5ac70354091d58800cc12464f16ae9e0be4b [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"
Jeff Ohlstein7e668552011-10-06 16:17:25 -070027#include "msm_watchdog.h"
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070028
29/* Address of GSBI blocks */
Stepan Moskovchenko2701a442011-08-19 13:47:22 -070030#define MSM_GSBI1_PHYS 0x12440000
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070031#define MSM_GSBI3_PHYS 0x16200000
Harini Jayaramanc4c58692011-07-19 14:50:10 -060032#define MSM_GSBI4_PHYS 0x16300000
33#define MSM_GSBI5_PHYS 0x1A200000
34#define MSM_GSBI6_PHYS 0x16500000
35#define MSM_GSBI7_PHYS 0x16600000
36
Kenneth Heitke748593a2011-07-15 15:45:11 -060037/* GSBI UART devices */
Stepan Moskovchenko2701a442011-08-19 13:47:22 -070038#define MSM_UART1DM_PHYS (MSM_GSBI1_PHYS + 0x10000)
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070039#define MSM_UART3DM_PHYS (MSM_GSBI3_PHYS + 0x40000)
40
Harini Jayaramanc4c58692011-07-19 14:50:10 -060041/* GSBI QUP devices */
42#define MSM_GSBI3_QUP_PHYS (MSM_GSBI3_PHYS + 0x80000)
43#define MSM_GSBI4_QUP_PHYS (MSM_GSBI4_PHYS + 0x80000)
44#define MSM_GSBI5_QUP_PHYS (MSM_GSBI5_PHYS + 0x80000)
45#define MSM_GSBI6_QUP_PHYS (MSM_GSBI6_PHYS + 0x80000)
46#define MSM_GSBI7_QUP_PHYS (MSM_GSBI7_PHYS + 0x80000)
47#define MSM_QUP_SIZE SZ_4K
48
Kenneth Heitke36920d32011-07-20 16:44:30 -060049/* Address of SSBI CMD */
50#define MSM_PMIC1_SSBI_CMD_PHYS 0x00500000
51#define MSM_PMIC2_SSBI_CMD_PHYS 0x00C00000
52#define MSM_PMIC_SSBI_SIZE SZ_4K
Harini Jayaramanc4c58692011-07-19 14:50:10 -060053
Hemant Kumarcaa09092011-07-30 00:26:33 -070054/* Address of HS USBOTG1 */
55#define MSM_HSUSB_PHYS 0x12500000
56#define MSM_HSUSB_SIZE SZ_4K
57
Jeff Ohlstein7e668552011-10-06 16:17:25 -070058static struct msm_watchdog_pdata msm_watchdog_pdata = {
59 .pet_time = 10000,
60 .bark_time = 11000,
61 .has_secure = true,
62};
63
64struct platform_device msm8064_device_watchdog = {
65 .name = "msm_watchdog",
66 .id = -1,
67 .dev = {
68 .platform_data = &msm_watchdog_pdata,
69 },
70};
71
Joel King0581896d2011-07-19 16:43:28 -070072static struct resource msm_dmov_resource[] = {
73 {
Jeff Ohlstein4af72692011-11-07 15:59:17 -080074 .start = ADM_0_SCSS_1_IRQ,
Joel King0581896d2011-07-19 16:43:28 -070075 .flags = IORESOURCE_IRQ,
76 },
Jeff Ohlstein905f1ce2011-09-07 18:50:18 -070077 {
Jeff Ohlstein4af72692011-11-07 15:59:17 -080078 .start = 0x18320000,
79 .end = 0x18320000 + SZ_1M - 1,
Jeff Ohlstein905f1ce2011-09-07 18:50:18 -070080 .flags = IORESOURCE_MEM,
81 },
82};
83
84static struct msm_dmov_pdata msm_dmov_pdata = {
Jeff Ohlstein4af72692011-11-07 15:59:17 -080085 .sd = 1,
Jeff Ohlstein905f1ce2011-09-07 18:50:18 -070086 .sd_size = 0x800,
Joel King0581896d2011-07-19 16:43:28 -070087};
88
Stepan Moskovchenkodf13d342011-08-03 19:01:25 -070089struct platform_device apq8064_device_dmov = {
Joel King0581896d2011-07-19 16:43:28 -070090 .name = "msm_dmov",
91 .id = -1,
92 .resource = msm_dmov_resource,
93 .num_resources = ARRAY_SIZE(msm_dmov_resource),
Jeff Ohlstein905f1ce2011-09-07 18:50:18 -070094 .dev = {
95 .platform_data = &msm_dmov_pdata,
96 },
Joel King0581896d2011-07-19 16:43:28 -070097};
98
Stepan Moskovchenko2701a442011-08-19 13:47:22 -070099static struct resource resources_uart_gsbi1[] = {
100 {
101 .start = APQ8064_GSBI1_UARTDM_IRQ,
102 .end = APQ8064_GSBI1_UARTDM_IRQ,
103 .flags = IORESOURCE_IRQ,
104 },
105 {
106 .start = MSM_UART1DM_PHYS,
107 .end = MSM_UART1DM_PHYS + PAGE_SIZE - 1,
108 .name = "uartdm_resource",
109 .flags = IORESOURCE_MEM,
110 },
111 {
112 .start = MSM_GSBI1_PHYS,
113 .end = MSM_GSBI1_PHYS + PAGE_SIZE - 1,
114 .name = "gsbi_resource",
115 .flags = IORESOURCE_MEM,
116 },
117};
118
119struct platform_device apq8064_device_uart_gsbi1 = {
120 .name = "msm_serial_hsl",
121 .id = 0,
122 .num_resources = ARRAY_SIZE(resources_uart_gsbi1),
123 .resource = resources_uart_gsbi1,
124};
125
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700126static struct resource resources_uart_gsbi3[] = {
127 {
128 .start = GSBI3_UARTDM_IRQ,
129 .end = GSBI3_UARTDM_IRQ,
130 .flags = IORESOURCE_IRQ,
131 },
132 {
133 .start = MSM_UART3DM_PHYS,
134 .end = MSM_UART3DM_PHYS + PAGE_SIZE - 1,
135 .name = "uartdm_resource",
136 .flags = IORESOURCE_MEM,
137 },
138 {
139 .start = MSM_GSBI3_PHYS,
140 .end = MSM_GSBI3_PHYS + PAGE_SIZE - 1,
141 .name = "gsbi_resource",
142 .flags = IORESOURCE_MEM,
143 },
144};
145
146struct platform_device apq8064_device_uart_gsbi3 = {
147 .name = "msm_serial_hsl",
148 .id = 0,
149 .num_resources = ARRAY_SIZE(resources_uart_gsbi3),
150 .resource = resources_uart_gsbi3,
151};
152
Kenneth Heitke748593a2011-07-15 15:45:11 -0600153static struct resource resources_qup_i2c_gsbi4[] = {
154 {
155 .name = "gsbi_qup_i2c_addr",
156 .start = MSM_GSBI4_PHYS,
Harini Jayaramane1554a92011-09-15 14:43:02 -0600157 .end = MSM_GSBI4_PHYS + 4 - 1,
Kenneth Heitke748593a2011-07-15 15:45:11 -0600158 .flags = IORESOURCE_MEM,
159 },
160 {
161 .name = "qup_phys_addr",
162 .start = MSM_GSBI4_QUP_PHYS,
Harini Jayaramane1554a92011-09-15 14:43:02 -0600163 .end = MSM_GSBI4_QUP_PHYS + MSM_QUP_SIZE - 1,
Kenneth Heitke748593a2011-07-15 15:45:11 -0600164 .flags = IORESOURCE_MEM,
165 },
166 {
167 .name = "qup_err_intr",
168 .start = GSBI4_QUP_IRQ,
169 .end = GSBI4_QUP_IRQ,
170 .flags = IORESOURCE_IRQ,
171 },
172};
173
174struct platform_device apq8064_device_qup_i2c_gsbi4 = {
175 .name = "qup_i2c",
176 .id = 4,
177 .num_resources = ARRAY_SIZE(resources_qup_i2c_gsbi4),
178 .resource = resources_qup_i2c_gsbi4,
179};
180
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700181static struct resource resources_qup_spi_gsbi5[] = {
182 {
183 .name = "spi_base",
184 .start = MSM_GSBI5_QUP_PHYS,
185 .end = MSM_GSBI5_QUP_PHYS + SZ_4K - 1,
186 .flags = IORESOURCE_MEM,
187 },
188 {
189 .name = "gsbi_base",
190 .start = MSM_GSBI5_PHYS,
191 .end = MSM_GSBI5_PHYS + 4 - 1,
192 .flags = IORESOURCE_MEM,
193 },
194 {
195 .name = "spi_irq_in",
196 .start = GSBI5_QUP_IRQ,
197 .end = GSBI5_QUP_IRQ,
198 .flags = IORESOURCE_IRQ,
199 },
200};
201
202struct platform_device apq8064_device_qup_spi_gsbi5 = {
203 .name = "spi_qsd",
204 .id = 0,
205 .num_resources = ARRAY_SIZE(resources_qup_spi_gsbi5),
206 .resource = resources_qup_spi_gsbi5,
207};
208
209static struct resource resources_ssbi_pmic1[] = {
210 {
211 .start = MSM_PMIC1_SSBI_CMD_PHYS,
212 .end = MSM_PMIC1_SSBI_CMD_PHYS + MSM_PMIC_SSBI_SIZE - 1,
213 .flags = IORESOURCE_MEM,
214 },
215};
216
Sagar Dharia8bdcdaf2011-09-16 16:01:15 -0600217#define LPASS_SLIMBUS_PHYS 0x28080000
218#define LPASS_SLIMBUS_BAM_PHYS 0x28084000
219/* Board info for the slimbus slave device */
220static struct resource slimbus_res[] = {
221 {
222 .start = LPASS_SLIMBUS_PHYS,
223 .end = LPASS_SLIMBUS_PHYS + 8191,
224 .flags = IORESOURCE_MEM,
225 .name = "slimbus_physical",
226 },
227 {
228 .start = LPASS_SLIMBUS_BAM_PHYS,
229 .end = LPASS_SLIMBUS_BAM_PHYS + 8191,
230 .flags = IORESOURCE_MEM,
231 .name = "slimbus_bam_physical",
232 },
233 {
234 .start = SLIMBUS0_CORE_EE1_IRQ,
235 .end = SLIMBUS0_CORE_EE1_IRQ,
236 .flags = IORESOURCE_IRQ,
237 .name = "slimbus_irq",
238 },
239 {
240 .start = SLIMBUS0_BAM_EE1_IRQ,
241 .end = SLIMBUS0_BAM_EE1_IRQ,
242 .flags = IORESOURCE_IRQ,
243 .name = "slimbus_bam_irq",
244 },
245};
246
247struct platform_device apq8064_slim_ctrl = {
248 .name = "msm_slim_ctrl",
249 .id = 1,
250 .num_resources = ARRAY_SIZE(slimbus_res),
251 .resource = slimbus_res,
252 .dev = {
253 .coherent_dma_mask = 0xffffffffULL,
254 },
255};
256
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700257struct platform_device apq8064_device_ssbi_pmic1 = {
258 .name = "msm_ssbi",
259 .id = 0,
260 .resource = resources_ssbi_pmic1,
261 .num_resources = ARRAY_SIZE(resources_ssbi_pmic1),
262};
263
264static struct resource resources_ssbi_pmic2[] = {
265 {
266 .start = MSM_PMIC2_SSBI_CMD_PHYS,
267 .end = MSM_PMIC2_SSBI_CMD_PHYS + MSM_PMIC_SSBI_SIZE - 1,
268 .flags = IORESOURCE_MEM,
269 },
270};
271
272struct platform_device apq8064_device_ssbi_pmic2 = {
273 .name = "msm_ssbi",
274 .id = 1,
275 .resource = resources_ssbi_pmic2,
276 .num_resources = ARRAY_SIZE(resources_ssbi_pmic2),
277};
278
279static struct resource resources_otg[] = {
280 {
281 .start = MSM_HSUSB_PHYS,
282 .end = MSM_HSUSB_PHYS + MSM_HSUSB_SIZE - 1,
283 .flags = IORESOURCE_MEM,
284 },
285 {
286 .start = USB1_HS_IRQ,
287 .end = USB1_HS_IRQ,
288 .flags = IORESOURCE_IRQ,
289 },
290};
291
Stepan Moskovchenko14aa6492011-08-08 15:15:01 -0700292struct platform_device apq8064_device_otg = {
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700293 .name = "msm_otg",
294 .id = -1,
295 .num_resources = ARRAY_SIZE(resources_otg),
296 .resource = resources_otg,
297 .dev = {
298 .coherent_dma_mask = 0xffffffff,
299 },
300};
301
302static struct resource resources_hsusb[] = {
303 {
304 .start = MSM_HSUSB_PHYS,
305 .end = MSM_HSUSB_PHYS + MSM_HSUSB_SIZE - 1,
306 .flags = IORESOURCE_MEM,
307 },
308 {
309 .start = USB1_HS_IRQ,
310 .end = USB1_HS_IRQ,
311 .flags = IORESOURCE_IRQ,
312 },
313};
314
Stepan Moskovchenko14aa6492011-08-08 15:15:01 -0700315struct platform_device apq8064_device_gadget_peripheral = {
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700316 .name = "msm_hsusb",
317 .id = -1,
318 .num_resources = ARRAY_SIZE(resources_hsusb),
319 .resource = resources_hsusb,
320 .dev = {
321 .coherent_dma_mask = 0xffffffff,
322 },
323};
324
325#define MSM_SDC1_BASE 0x12400000
326#define MSM_SDC1_DML_BASE (MSM_SDC1_BASE + 0x800)
327#define MSM_SDC1_BAM_BASE (MSM_SDC1_BASE + 0x2000)
328#define MSM_SDC2_BASE 0x12140000
329#define MSM_SDC2_DML_BASE (MSM_SDC2_BASE + 0x800)
330#define MSM_SDC2_BAM_BASE (MSM_SDC2_BASE + 0x2000)
331#define MSM_SDC3_BASE 0x12180000
332#define MSM_SDC3_DML_BASE (MSM_SDC3_BASE + 0x800)
333#define MSM_SDC3_BAM_BASE (MSM_SDC3_BASE + 0x2000)
334#define MSM_SDC4_BASE 0x121C0000
335#define MSM_SDC4_DML_BASE (MSM_SDC4_BASE + 0x800)
336#define MSM_SDC4_BAM_BASE (MSM_SDC4_BASE + 0x2000)
337
338static struct resource resources_sdc1[] = {
339 {
340 .name = "core_mem",
341 .flags = IORESOURCE_MEM,
342 .start = MSM_SDC1_BASE,
343 .end = MSM_SDC1_DML_BASE - 1,
344 },
345 {
346 .name = "core_irq",
347 .flags = IORESOURCE_IRQ,
348 .start = SDC1_IRQ_0,
349 .end = SDC1_IRQ_0
350 },
351#ifdef CONFIG_MMC_MSM_SPS_SUPPORT
352 {
353 .name = "sdcc_dml_addr",
354 .start = MSM_SDC1_DML_BASE,
355 .end = MSM_SDC1_BAM_BASE - 1,
356 .flags = IORESOURCE_MEM,
357 },
358 {
359 .name = "sdcc_bam_addr",
360 .start = MSM_SDC1_BAM_BASE,
361 .end = MSM_SDC1_BAM_BASE + (2 * SZ_4K) - 1,
362 .flags = IORESOURCE_MEM,
363 },
364 {
365 .name = "sdcc_bam_irq",
366 .start = SDC1_BAM_IRQ,
367 .end = SDC1_BAM_IRQ,
368 .flags = IORESOURCE_IRQ,
369 },
370#endif
371};
372
373static struct resource resources_sdc2[] = {
374 {
375 .name = "core_mem",
376 .flags = IORESOURCE_MEM,
377 .start = MSM_SDC2_BASE,
378 .end = MSM_SDC2_DML_BASE - 1,
379 },
380 {
381 .name = "core_irq",
382 .flags = IORESOURCE_IRQ,
383 .start = SDC2_IRQ_0,
384 .end = SDC2_IRQ_0
385 },
386#ifdef CONFIG_MMC_MSM_SPS_SUPPORT
387 {
388 .name = "sdcc_dml_addr",
389 .start = MSM_SDC2_DML_BASE,
390 .end = MSM_SDC2_BAM_BASE - 1,
391 .flags = IORESOURCE_MEM,
392 },
393 {
394 .name = "sdcc_bam_addr",
395 .start = MSM_SDC2_BAM_BASE,
396 .end = MSM_SDC2_BAM_BASE + (2 * SZ_4K) - 1,
397 .flags = IORESOURCE_MEM,
398 },
399 {
400 .name = "sdcc_bam_irq",
401 .start = SDC2_BAM_IRQ,
402 .end = SDC2_BAM_IRQ,
403 .flags = IORESOURCE_IRQ,
404 },
405#endif
406};
407
408static struct resource resources_sdc3[] = {
409 {
410 .name = "core_mem",
411 .flags = IORESOURCE_MEM,
412 .start = MSM_SDC3_BASE,
413 .end = MSM_SDC3_DML_BASE - 1,
414 },
415 {
416 .name = "core_irq",
417 .flags = IORESOURCE_IRQ,
418 .start = SDC3_IRQ_0,
419 .end = SDC3_IRQ_0
420 },
421#ifdef CONFIG_MMC_MSM_SPS_SUPPORT
422 {
423 .name = "sdcc_dml_addr",
424 .start = MSM_SDC3_DML_BASE,
425 .end = MSM_SDC3_BAM_BASE - 1,
426 .flags = IORESOURCE_MEM,
427 },
428 {
429 .name = "sdcc_bam_addr",
430 .start = MSM_SDC3_BAM_BASE,
431 .end = MSM_SDC3_BAM_BASE + (2 * SZ_4K) - 1,
432 .flags = IORESOURCE_MEM,
433 },
434 {
435 .name = "sdcc_bam_irq",
436 .start = SDC3_BAM_IRQ,
437 .end = SDC3_BAM_IRQ,
438 .flags = IORESOURCE_IRQ,
439 },
440#endif
441};
442
443static struct resource resources_sdc4[] = {
444 {
445 .name = "core_mem",
446 .flags = IORESOURCE_MEM,
447 .start = MSM_SDC4_BASE,
448 .end = MSM_SDC4_DML_BASE - 1,
449 },
450 {
451 .name = "core_irq",
452 .flags = IORESOURCE_IRQ,
453 .start = SDC4_IRQ_0,
454 .end = SDC4_IRQ_0
455 },
456#ifdef CONFIG_MMC_MSM_SPS_SUPPORT
457 {
458 .name = "sdcc_dml_addr",
459 .start = MSM_SDC4_DML_BASE,
460 .end = MSM_SDC4_BAM_BASE - 1,
461 .flags = IORESOURCE_MEM,
462 },
463 {
464 .name = "sdcc_bam_addr",
465 .start = MSM_SDC4_BAM_BASE,
466 .end = MSM_SDC4_BAM_BASE + (2 * SZ_4K) - 1,
467 .flags = IORESOURCE_MEM,
468 },
469 {
470 .name = "sdcc_bam_irq",
471 .start = SDC4_BAM_IRQ,
472 .end = SDC4_BAM_IRQ,
473 .flags = IORESOURCE_IRQ,
474 },
475#endif
476};
477
478struct platform_device apq8064_device_sdc1 = {
479 .name = "msm_sdcc",
480 .id = 1,
481 .num_resources = ARRAY_SIZE(resources_sdc1),
482 .resource = resources_sdc1,
483 .dev = {
484 .coherent_dma_mask = 0xffffffff,
485 },
486};
487
488struct platform_device apq8064_device_sdc2 = {
489 .name = "msm_sdcc",
490 .id = 2,
491 .num_resources = ARRAY_SIZE(resources_sdc2),
492 .resource = resources_sdc2,
493 .dev = {
494 .coherent_dma_mask = 0xffffffff,
495 },
496};
497
498struct platform_device apq8064_device_sdc3 = {
499 .name = "msm_sdcc",
500 .id = 3,
501 .num_resources = ARRAY_SIZE(resources_sdc3),
502 .resource = resources_sdc3,
503 .dev = {
504 .coherent_dma_mask = 0xffffffff,
505 },
506};
507
508struct platform_device apq8064_device_sdc4 = {
509 .name = "msm_sdcc",
510 .id = 4,
511 .num_resources = ARRAY_SIZE(resources_sdc4),
512 .resource = resources_sdc4,
513 .dev = {
514 .coherent_dma_mask = 0xffffffff,
515 },
516};
517
518static struct platform_device *apq8064_sdcc_devices[] __initdata = {
519 &apq8064_device_sdc1,
520 &apq8064_device_sdc2,
521 &apq8064_device_sdc3,
522 &apq8064_device_sdc4,
523};
524
525int __init apq8064_add_sdcc(unsigned int controller,
526 struct mmc_platform_data *plat)
527{
528 struct platform_device *pdev;
529
530 if (!plat)
531 return 0;
532 if (controller < 1 || controller > 4)
533 return -EINVAL;
534
535 pdev = apq8064_sdcc_devices[controller-1];
536 pdev->dev.platform_data = plat;
537 return platform_device_register(pdev);
538}
539
Yan He06913ce2011-08-26 16:33:46 -0700540static struct resource resources_sps[] = {
541 {
542 .name = "pipe_mem",
543 .start = 0x12800000,
544 .end = 0x12800000 + 0x4000 - 1,
545 .flags = IORESOURCE_MEM,
546 },
547 {
548 .name = "bamdma_dma",
549 .start = 0x12240000,
550 .end = 0x12240000 + 0x1000 - 1,
551 .flags = IORESOURCE_MEM,
552 },
553 {
554 .name = "bamdma_bam",
555 .start = 0x12244000,
556 .end = 0x12244000 + 0x4000 - 1,
557 .flags = IORESOURCE_MEM,
558 },
559 {
560 .name = "bamdma_irq",
561 .start = SPS_BAM_DMA_IRQ,
562 .end = SPS_BAM_DMA_IRQ,
563 .flags = IORESOURCE_IRQ,
564 },
565};
566
567static struct msm_sps_platform_data msm_sps_pdata = {
568 .bamdma_restricted_pipes = 0x06,
569};
570
571struct platform_device msm_device_sps_apq8064 = {
572 .name = "msm_sps",
573 .id = -1,
574 .num_resources = ARRAY_SIZE(resources_sps),
575 .resource = resources_sps,
576 .dev.platform_data = &msm_sps_pdata,
577};
578
Jeff Hugo0c0f5e92011-09-28 13:55:45 -0600579struct platform_device msm_device_smd_apq8064 = {
580 .name = "msm_smd",
581 .id = -1,
582};
583
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700584static struct clk_lookup msm_clocks_8064_dummy[] = {
585 CLK_DUMMY("pll2", PLL2, NULL, 0),
586 CLK_DUMMY("pll8", PLL8, NULL, 0),
587 CLK_DUMMY("pll4", PLL4, NULL, 0),
588
589 CLK_DUMMY("afab_clk", AFAB_CLK, NULL, 0),
590 CLK_DUMMY("afab_a_clk", AFAB_A_CLK, NULL, 0),
591 CLK_DUMMY("cfpb_clk", CFPB_CLK, NULL, 0),
592 CLK_DUMMY("cfpb_a_clk", CFPB_A_CLK, NULL, 0),
593 CLK_DUMMY("dfab_clk", DFAB_CLK, NULL, 0),
594 CLK_DUMMY("dfab_a_clk", DFAB_A_CLK, NULL, 0),
595 CLK_DUMMY("ebi1_clk", EBI1_CLK, NULL, 0),
596 CLK_DUMMY("ebi1_a_clk", EBI1_A_CLK, NULL, 0),
597 CLK_DUMMY("mmfab_clk", MMFAB_CLK, NULL, 0),
598 CLK_DUMMY("mmfab_a_clk", MMFAB_A_CLK, NULL, 0),
599 CLK_DUMMY("mmfpb_clk", MMFPB_CLK, NULL, 0),
600 CLK_DUMMY("mmfpb_a_clk", MMFPB_A_CLK, NULL, 0),
601 CLK_DUMMY("sfab_clk", SFAB_CLK, NULL, 0),
602 CLK_DUMMY("sfab_a_clk", SFAB_A_CLK, NULL, 0),
603 CLK_DUMMY("sfpb_clk", SFPB_CLK, NULL, 0),
604 CLK_DUMMY("sfpb_a_clk", SFPB_A_CLK, NULL, 0),
605
Matt Wagantalle2522372011-08-17 14:52:21 -0700606 CLK_DUMMY("core_clk", GSBI1_UART_CLK, NULL, OFF),
607 CLK_DUMMY("core_clk", GSBI2_UART_CLK, NULL, OFF),
608 CLK_DUMMY("core_clk", GSBI3_UART_CLK,
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700609 "msm_serial_hsl.0", OFF),
Matt Wagantalle2522372011-08-17 14:52:21 -0700610 CLK_DUMMY("core_clk", GSBI4_UART_CLK, NULL, OFF),
611 CLK_DUMMY("core_clk", GSBI5_UART_CLK, NULL, OFF),
612 CLK_DUMMY("core_clk", GSBI6_UART_CLK, NULL, OFF),
613 CLK_DUMMY("core_clk", GSBI7_UART_CLK, NULL, OFF),
614 CLK_DUMMY("core_clk", GSBI8_UART_CLK, NULL, OFF),
615 CLK_DUMMY("core_clk", GSBI9_UART_CLK, NULL, OFF),
616 CLK_DUMMY("core_clk", GSBI10_UART_CLK, NULL, OFF),
617 CLK_DUMMY("core_clk", GSBI11_UART_CLK, NULL, OFF),
618 CLK_DUMMY("core_clk", GSBI12_UART_CLK, NULL, OFF),
Matt Wagantall62cf63e2011-08-17 16:34:47 -0700619 CLK_DUMMY("core_clk", GSBI1_QUP_CLK, NULL, OFF),
620 CLK_DUMMY("core_clk", GSBI2_QUP_CLK, NULL, OFF),
621 CLK_DUMMY("core_clk", GSBI3_QUP_CLK, NULL, OFF),
Matt Wagantallac294852011-08-17 15:44:58 -0700622 CLK_DUMMY("core_clk", GSBI4_QUP_CLK, "qup_i2c.4", OFF),
623 CLK_DUMMY("core_clk", GSBI5_QUP_CLK, "spi_qsd.0", OFF),
Matt Wagantall62cf63e2011-08-17 16:34:47 -0700624 CLK_DUMMY("core_clk", GSBI6_QUP_CLK, NULL, OFF),
625 CLK_DUMMY("core_clk", GSBI7_QUP_CLK, NULL, OFF),
Matt Wagantallb86ad262011-10-24 19:50:29 -0700626 CLK_DUMMY("core_clk", PDM_CLK, NULL, OFF),
Matt Wagantalld86d6832011-08-17 14:06:55 -0700627 CLK_DUMMY("mem_clk", PMEM_CLK, NULL, OFF),
Matt Wagantallc1205292011-08-11 17:19:31 -0700628 CLK_DUMMY("core_clk", PRNG_CLK, NULL, OFF),
Matt Wagantall37ce3842011-08-17 16:00:36 -0700629 CLK_DUMMY("core_clk", SDC1_CLK, NULL, OFF),
630 CLK_DUMMY("core_clk", SDC2_CLK, NULL, OFF),
631 CLK_DUMMY("core_clk", SDC3_CLK, NULL, OFF),
632 CLK_DUMMY("core_clk", SDC4_CLK, NULL, OFF),
Matt Wagantall640e5fd2011-08-17 16:08:53 -0700633 CLK_DUMMY("ref_clk", TSIF_REF_CLK, NULL, OFF),
Matt Wagantallb86ad262011-10-24 19:50:29 -0700634 CLK_DUMMY("core_clk", TSSC_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700635 CLK_DUMMY("usb_hs_clk", USB_HS1_XCVR_CLK, NULL, OFF),
Tianyi Gou86bb4722011-08-09 13:28:02 -0700636 CLK_DUMMY("usb_hs_clk", USB_HS3_XCVR_CLK, NULL, OFF),
637 CLK_DUMMY("usb_hs_clk", USB_HS4_XCVR_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700638 CLK_DUMMY("usb_phy_clk", USB_PHY0_CLK, NULL, OFF),
639 CLK_DUMMY("usb_fs_src_clk", USB_FS1_SRC_CLK, NULL, OFF),
640 CLK_DUMMY("usb_fs_clk", USB_FS1_XCVR_CLK, NULL, OFF),
641 CLK_DUMMY("usb_fs_sys_clk", USB_FS1_SYS_CLK, NULL, OFF),
Matt Wagantallc4b3a4d2011-08-17 16:58:39 -0700642 CLK_DUMMY("core_clk", CE2_CLK, NULL, OFF),
643 CLK_DUMMY("core_clk", CE1_CORE_CLK, NULL, OFF),
644 CLK_DUMMY("core_clk", CE3_CORE_CLK, NULL, OFF),
645 CLK_DUMMY("iface_clk", CE3_P_CLK, NULL, OFF),
Tianyi Gou86bb4722011-08-09 13:28:02 -0700646 CLK_DUMMY("pcie_pclk", PCIE_P_CLK, NULL, OFF),
647 CLK_DUMMY("pcie_alt_ref_clk", PCIE_ALT_REF_CLK, NULL, OFF),
648 CLK_DUMMY("sata_rxoob_clk", SATA_RXOOB_CLK, NULL, OFF),
649 CLK_DUMMY("sata_pmalive_clk", SATA_PMALIVE_CLK, NULL, OFF),
Matt Wagantallb86ad262011-10-24 19:50:29 -0700650 CLK_DUMMY("ref_clk", SATA_PHY_REF_CLK, NULL, OFF),
Matt Wagantall62cf63e2011-08-17 16:34:47 -0700651 CLK_DUMMY("iface_clk", GSBI1_P_CLK, NULL, OFF),
652 CLK_DUMMY("iface_clk", GSBI2_P_CLK, NULL, OFF),
Matt Wagantalle2522372011-08-17 14:52:21 -0700653 CLK_DUMMY("iface_clk", GSBI3_P_CLK, "msm_serial_hsl.0", OFF),
Matt Wagantallac294852011-08-17 15:44:58 -0700654 CLK_DUMMY("iface_clk", GSBI4_P_CLK, "qup_i2c.4", OFF),
655 CLK_DUMMY("iface_clk", GSBI5_P_CLK, "spi_qsd.0", OFF),
Matt Wagantalle2522372011-08-17 14:52:21 -0700656 CLK_DUMMY("iface_clk", GSBI6_P_CLK, NULL, OFF),
Matt Wagantall62cf63e2011-08-17 16:34:47 -0700657 CLK_DUMMY("iface_clk", GSBI7_P_CLK, NULL, OFF),
Matt Wagantall640e5fd2011-08-17 16:08:53 -0700658 CLK_DUMMY("iface_clk", TSIF_P_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700659 CLK_DUMMY("usb_fs_pclk", USB_FS1_P_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700660 CLK_DUMMY("usb_hs_pclk", USB_HS1_P_CLK, NULL, OFF),
Tianyi Gou86bb4722011-08-09 13:28:02 -0700661 CLK_DUMMY("usb_hs_pclk", USB_HS3_P_CLK, NULL, OFF),
662 CLK_DUMMY("usb_hs_pclk", USB_HS4_P_CLK, NULL, OFF),
Matt Wagantall37ce3842011-08-17 16:00:36 -0700663 CLK_DUMMY("iface_clk", SDC1_P_CLK, NULL, OFF),
664 CLK_DUMMY("iface_clk", SDC2_P_CLK, NULL, OFF),
665 CLK_DUMMY("iface_clk", SDC3_P_CLK, NULL, OFF),
666 CLK_DUMMY("iface_clk", SDC4_P_CLK, NULL, OFF),
Jin Hong01f2dbb2011-11-03 22:13:51 -0700667 CLK_DUMMY("core_clk", ADM0_CLK, "msm_dmov", OFF),
668 CLK_DUMMY("iface_clk", ADM0_P_CLK, "msm_dmov", OFF),
Matt Wagantallb86ad262011-10-24 19:50:29 -0700669 CLK_DUMMY("iface_clk", PMIC_ARB0_P_CLK, NULL, OFF),
670 CLK_DUMMY("iface_clk", PMIC_ARB1_P_CLK, NULL, OFF),
671 CLK_DUMMY("core_clk", PMIC_SSBI2_CLK, NULL, OFF),
672 CLK_DUMMY("mem_clk", RPM_MSG_RAM_P_CLK, NULL, OFF),
673 CLK_DUMMY("core_clk", AMP_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700674 CLK_DUMMY("cam_clk", CAM0_CLK, NULL, OFF),
675 CLK_DUMMY("cam_clk", CAM1_CLK, NULL, OFF),
676 CLK_DUMMY("csi_src_clk", CSI0_SRC_CLK, NULL, OFF),
677 CLK_DUMMY("csi_src_clk", CSI1_SRC_CLK, NULL, OFF),
678 CLK_DUMMY("csi_clk", CSI0_CLK, NULL, OFF),
679 CLK_DUMMY("csi_clk", CSI1_CLK, NULL, OFF),
680 CLK_DUMMY("csi_pix_clk", CSI_PIX_CLK, NULL, OFF),
681 CLK_DUMMY("csi_rdi_clk", CSI_RDI_CLK, NULL, OFF),
682 CLK_DUMMY("csiphy_timer_src_clk", CSIPHY_TIMER_SRC_CLK, NULL, OFF),
683 CLK_DUMMY("csi0phy_timer_clk", CSIPHY0_TIMER_CLK, NULL, OFF),
684 CLK_DUMMY("csi1phy_timer_clk", CSIPHY1_TIMER_CLK, NULL, OFF),
685 CLK_DUMMY("dsi_byte_div_clk", DSI1_BYTE_CLK, NULL, OFF),
686 CLK_DUMMY("dsi_byte_div_clk", DSI2_BYTE_CLK, NULL, OFF),
687 CLK_DUMMY("dsi_esc_clk", DSI1_ESC_CLK, NULL, OFF),
688 CLK_DUMMY("dsi_esc_clk", DSI2_ESC_CLK, NULL, OFF),
Matt Wagantall9dc01632011-08-17 18:55:04 -0700689 CLK_DUMMY("core_clk", VCAP_CLK, NULL, OFF),
690 CLK_DUMMY("npl_clk", VCAP_NPL_CLK, NULL, OFF),
691 CLK_DUMMY("core_clk", GFX3D_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700692 CLK_DUMMY("ijpeg_clk", IJPEG_CLK, NULL, OFF),
Matt Wagantall9dc01632011-08-17 18:55:04 -0700693 CLK_DUMMY("mem_clk", IMEM_CLK, NULL, OFF),
Matt Wagantallb86ad262011-10-24 19:50:29 -0700694 CLK_DUMMY("core_clk", JPEGD_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700695 CLK_DUMMY("mdp_clk", MDP_CLK, NULL, OFF),
696 CLK_DUMMY("mdp_vsync_clk", MDP_VSYNC_CLK, NULL, OFF),
697 CLK_DUMMY("lut_mdp", LUT_MDP_CLK, NULL, OFF),
Matt Wagantallbb90da92011-10-25 15:07:52 -0700698 CLK_DUMMY("core_clk", ROT_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700699 CLK_DUMMY("tv_src_clk", TV_SRC_CLK, NULL, OFF),
Matt Wagantallb86ad262011-10-24 19:50:29 -0700700 CLK_DUMMY("core_clk", VCODEC_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700701 CLK_DUMMY("mdp_tv_clk", MDP_TV_CLK, NULL, OFF),
Tianyi Gou86bb4722011-08-09 13:28:02 -0700702 CLK_DUMMY("rgb_tv_clk", RGB_TV_CLK, NULL, OFF),
703 CLK_DUMMY("npl_tv_clk", NPL_TV_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700704 CLK_DUMMY("hdmi_clk", HDMI_TV_CLK, NULL, OFF),
Matt Wagantall5a4f1ba2011-08-18 18:13:03 -0700705 CLK_DUMMY("core_clk", HDMI_APP_CLK, "hdmi_msm.1", OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700706 CLK_DUMMY("vpe_clk", VPE_CLK, NULL, OFF),
707 CLK_DUMMY("vfe_clk", VFE_CLK, NULL, OFF),
708 CLK_DUMMY("csi_vfe_clk", CSI0_VFE_CLK, NULL, OFF),
709 CLK_DUMMY("vfe_axi_clk", VFE_AXI_CLK, NULL, OFF),
710 CLK_DUMMY("ijpeg_axi_clk", IJPEG_AXI_CLK, NULL, OFF),
711 CLK_DUMMY("mdp_axi_clk", MDP_AXI_CLK, NULL, OFF),
Matt Wagantallbb90da92011-10-25 15:07:52 -0700712 CLK_DUMMY("bus_clk", ROT_AXI_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700713 CLK_DUMMY("vcodec_axi_clk", VCODEC_AXI_CLK, NULL, OFF),
714 CLK_DUMMY("vcodec_axi_a_clk", VCODEC_AXI_A_CLK, NULL, OFF),
715 CLK_DUMMY("vcodec_axi_b_clk", VCODEC_AXI_B_CLK, NULL, OFF),
716 CLK_DUMMY("vpe_axi_clk", VPE_AXI_CLK, NULL, OFF),
Matt Wagantall9dc01632011-08-17 18:55:04 -0700717 CLK_DUMMY("bus_clk", GFX3D_AXI_CLK, NULL, OFF),
Tianyi Gou86bb4722011-08-09 13:28:02 -0700718 CLK_DUMMY("vcap_axi_clk", VCAP_AXI_CLK, NULL, OFF),
719 CLK_DUMMY("vcap_ahb_clk", VCAP_AHB_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700720 CLK_DUMMY("amp_pclk", AMP_P_CLK, NULL, OFF),
721 CLK_DUMMY("csi_pclk", CSI0_P_CLK, NULL, OFF),
722 CLK_DUMMY("dsi_m_pclk", DSI1_M_P_CLK, NULL, OFF),
723 CLK_DUMMY("dsi_s_pclk", DSI1_S_P_CLK, NULL, OFF),
724 CLK_DUMMY("dsi_m_pclk", DSI2_M_P_CLK, NULL, OFF),
725 CLK_DUMMY("dsi_s_pclk", DSI2_S_P_CLK, NULL, OFF),
Tianyi Gou86bb4722011-08-09 13:28:02 -0700726 CLK_DUMMY("lvds_clk", LVDS_CLK, NULL, OFF),
727 CLK_DUMMY("mdp_p2clk", MDP_P2CLK, NULL, OFF),
728 CLK_DUMMY("dsi2_pixel_clk", DSI2_PIXEL_CLK, NULL, OFF),
729 CLK_DUMMY("lvds_ref_clk", LVDS_REF_CLK, NULL, OFF),
Matt Wagantall9dc01632011-08-17 18:55:04 -0700730 CLK_DUMMY("iface_clk", GFX3D_P_CLK, NULL, OFF),
Matt Wagantall5a4f1ba2011-08-18 18:13:03 -0700731 CLK_DUMMY("master_iface_clk", HDMI_M_P_CLK, "hdmi_msm.1", OFF),
732 CLK_DUMMY("slave_iface_clk", HDMI_S_P_CLK, "hdmi_msm.1", OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700733 CLK_DUMMY("ijpeg_pclk", IJPEG_P_CLK, NULL, OFF),
734 CLK_DUMMY("jpegd_pclk", JPEGD_P_CLK, NULL, OFF),
Matt Wagantall9dc01632011-08-17 18:55:04 -0700735 CLK_DUMMY("mem_iface_clk", IMEM_P_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700736 CLK_DUMMY("mdp_pclk", MDP_P_CLK, NULL, OFF),
Matt Wagantalle604d712011-10-21 15:38:18 -0700737 CLK_DUMMY("iface_clk", SMMU_P_CLK, "msm_smmu", OFF),
Matt Wagantallbb90da92011-10-25 15:07:52 -0700738 CLK_DUMMY("iface_clk", ROT_P_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700739 CLK_DUMMY("vcodec_pclk", VCODEC_P_CLK, NULL, OFF),
740 CLK_DUMMY("vfe_pclk", VFE_P_CLK, NULL, OFF),
741 CLK_DUMMY("vpe_pclk", VPE_P_CLK, NULL, OFF),
742 CLK_DUMMY("mi2s_osr_clk", MI2S_OSR_CLK, NULL, OFF),
743 CLK_DUMMY("mi2s_bit_clk", MI2S_BIT_CLK, NULL, OFF),
744 CLK_DUMMY("i2s_mic_osr_clk", CODEC_I2S_MIC_OSR_CLK, NULL, OFF),
745 CLK_DUMMY("i2s_mic_bit_clk", CODEC_I2S_MIC_BIT_CLK, NULL, OFF),
746 CLK_DUMMY("i2s_mic_osr_clk", SPARE_I2S_MIC_OSR_CLK, NULL, OFF),
747 CLK_DUMMY("i2s_mic_bit_clk", SPARE_I2S_MIC_BIT_CLK, NULL, OFF),
748 CLK_DUMMY("i2s_spkr_osr_clk", CODEC_I2S_SPKR_OSR_CLK, NULL, OFF),
749 CLK_DUMMY("i2s_spkr_bit_clk", CODEC_I2S_SPKR_BIT_CLK, NULL, OFF),
750 CLK_DUMMY("i2s_spkr_osr_clk", SPARE_I2S_SPKR_OSR_CLK, NULL, OFF),
751 CLK_DUMMY("i2s_spkr_bit_clk", SPARE_I2S_SPKR_BIT_CLK, NULL, OFF),
752 CLK_DUMMY("pcm_clk", PCM_CLK, NULL, OFF),
Tianyi Gou142b8db2011-09-21 18:01:54 -0700753 CLK_DUMMY("audio_slimbus_clk", AUDIO_SLIMBUS_CLK, NULL, OFF),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700754
755 CLK_DUMMY("dfab_dsps_clk", DFAB_DSPS_CLK, NULL, 0),
756 CLK_DUMMY("dfab_usb_hs_clk", DFAB_USB_HS_CLK, NULL, 0),
Matt Wagantall37ce3842011-08-17 16:00:36 -0700757 CLK_DUMMY("bus_clk", DFAB_SDC1_CLK, NULL, 0),
758 CLK_DUMMY("bus_clk", DFAB_SDC2_CLK, NULL, 0),
759 CLK_DUMMY("bus_clk", DFAB_SDC3_CLK, NULL, 0),
760 CLK_DUMMY("bus_clk", DFAB_SDC4_CLK, NULL, 0),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700761 CLK_DUMMY("dfab_clk", DFAB_CLK, NULL, 0),
762 CLK_DUMMY("dma_bam_pclk", DMA_BAM_P_CLK, NULL, 0),
Jin Hong01f2dbb2011-11-03 22:13:51 -0700763 CLK_DUMMY("mem_clk", EBI1_ADM_CLK, "msm_dmov", 0),
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700764};
765
Stephen Boydbb600ae2011-08-02 20:11:40 -0700766struct clock_init_data apq8064_dummy_clock_init_data __initdata = {
767 .table = msm_clocks_8064_dummy,
768 .size = ARRAY_SIZE(msm_clocks_8064_dummy),
769};