forked from ~ljy/RK356X_SDK_RELEASE

hc
2024-05-10 748e4f3d702def1a4bff191e0cf93b6a05340f01
kernel/arch/arm/mach-davinci/devices.c
....@@ -1,31 +1,25 @@
1
+// SPDX-License-Identifier: GPL-2.0-or-later
12 /*
23 * mach-davinci/devices.c
34 *
45 * DaVinci platform device setup/initialization
5
- *
6
- * This program is free software; you can redistribute it and/or modify
7
- * it under the terms of the GNU General Public License as published by
8
- * the Free Software Foundation; either version 2 of the License, or
9
- * (at your option) any later version.
106 */
117
128 #include <linux/init.h>
139 #include <linux/platform_device.h>
10
+#include <linux/platform_data/i2c-davinci.h>
11
+#include <linux/platform_data/mmc-davinci.h>
12
+#include <linux/platform_data/edma.h>
1413 #include <linux/dma-mapping.h>
1514 #include <linux/io.h>
1615 #include <linux/reboot.h>
1716
1817 #include <mach/hardware.h>
19
-#include <linux/platform_data/i2c-davinci.h>
20
-#include <mach/irqs.h>
2118 #include <mach/cputype.h>
2219 #include <mach/mux.h>
23
-#include <linux/platform_data/mmc-davinci.h>
24
-#include <mach/time.h>
25
-#include <linux/platform_data/edma.h>
26
-
2720
2821 #include "davinci.h"
22
+#include "irqs.h"
2923
3024 #define DAVINCI_I2C_BASE 0x01C21000
3125 #define DAVINCI_ATA_BASE 0x01C66000
....@@ -39,7 +33,7 @@
3933
4034 void davinci_map_sysmod(void)
4135 {
42
- davinci_sysmod_base = ioremap_nocache(DAVINCI_SYSTEM_MODULE_BASE,
36
+ davinci_sysmod_base = ioremap(DAVINCI_SYSTEM_MODULE_BASE,
4337 0x800);
4438 /*
4539 * Throw a bug since a lot of board initialization code depends
....@@ -56,7 +50,7 @@
5650 .flags = IORESOURCE_MEM,
5751 },
5852 {
59
- .start = IRQ_I2C,
53
+ .start = DAVINCI_INTC_IRQ(IRQ_I2C),
6054 .flags = IORESOURCE_IRQ,
6155 },
6256 };
....@@ -84,8 +78,8 @@
8478 .flags = IORESOURCE_MEM,
8579 },
8680 {
87
- .start = IRQ_IDE,
88
- .end = IRQ_IDE,
81
+ .start = DAVINCI_INTC_IRQ(IRQ_IDE),
82
+ .end = DAVINCI_INTC_IRQ(IRQ_IDE),
8983 .flags = IORESOURCE_IRQ,
9084 },
9185 };
....@@ -133,11 +127,11 @@
133127 },
134128 /* IRQs: MMC/SD, then SDIO */
135129 {
136
- .start = IRQ_MMCINT,
130
+ .start = DAVINCI_INTC_IRQ(IRQ_MMCINT),
137131 .flags = IORESOURCE_IRQ,
138132 }, {
139133 /* different on dm355 */
140
- .start = IRQ_SDIOINT,
134
+ .start = DAVINCI_INTC_IRQ(IRQ_SDIOINT),
141135 .flags = IORESOURCE_IRQ,
142136 },
143137 };
....@@ -163,10 +157,10 @@
163157 },
164158 /* IRQs: MMC/SD, then SDIO */
165159 {
166
- .start = IRQ_DM355_MMCINT1,
160
+ .start = DAVINCI_INTC_IRQ(IRQ_DM355_MMCINT1),
167161 .flags = IORESOURCE_IRQ,
168162 }, {
169
- .start = IRQ_DM355_SDIOINT1,
163
+ .start = DAVINCI_INTC_IRQ(IRQ_DM355_SDIOINT1),
170164 .flags = IORESOURCE_IRQ,
171165 },
172166 };
....@@ -219,7 +213,8 @@
219213 mmcsd1_resources[0].start = DM365_MMCSD1_BASE;
220214 mmcsd1_resources[0].end = DM365_MMCSD1_BASE +
221215 SZ_4K - 1;
222
- mmcsd1_resources[2].start = IRQ_DM365_SDIOINT1;
216
+ mmcsd1_resources[2].start = DAVINCI_INTC_IRQ(
217
+ IRQ_DM365_SDIOINT1);
223218 davinci_mmcsd1_device.name = "da830-mmc";
224219 } else
225220 break;
....@@ -230,7 +225,8 @@
230225 if (cpu_is_davinci_dm355()) {
231226 mmcsd0_resources[0].start = DM355_MMCSD0_BASE;
232227 mmcsd0_resources[0].end = DM355_MMCSD0_BASE + SZ_4K - 1;
233
- mmcsd0_resources[2].start = IRQ_DM355_SDIOINT0;
228
+ mmcsd0_resources[2].start = DAVINCI_INTC_IRQ(
229
+ IRQ_DM355_SDIOINT0);
234230
235231 /* expose all 6 MMC0 signals: CLK, CMD, DATA[0..3] */
236232 davinci_cfg_reg(DM355_MMCSD0);
....@@ -241,7 +237,8 @@
241237 mmcsd0_resources[0].start = DM365_MMCSD0_BASE;
242238 mmcsd0_resources[0].end = DM365_MMCSD0_BASE +
243239 SZ_4K - 1;
244
- mmcsd0_resources[2].start = IRQ_DM365_SDIOINT0;
240
+ mmcsd0_resources[2].start = DAVINCI_INTC_IRQ(
241
+ IRQ_DM365_SDIOINT0);
245242 davinci_mmcsd0_device.name = "da830-mmc";
246243 } else if (cpu_is_davinci_dm644x()) {
247244 /* REVISIT: should this be in board-init code? */
....@@ -305,21 +302,3 @@
305302 davinci_gpio_device.dev.platform_data = pdata;
306303 return platform_device_register(&davinci_gpio_device);
307304 }
308
-
309
-/*-------------------------------------------------------------------------*/
310
-
311
-/*-------------------------------------------------------------------------*/
312
-
313
-struct davinci_timer_instance davinci_timer_instance[2] = {
314
- {
315
- .base = DAVINCI_TIMER0_BASE,
316
- .bottom_irq = IRQ_TINT0_TINT12,
317
- .top_irq = IRQ_TINT0_TINT34,
318
- },
319
- {
320
- .base = DAVINCI_TIMER1_BASE,
321
- .bottom_irq = IRQ_TINT1_TINT12,
322
- .top_irq = IRQ_TINT1_TINT34,
323
- },
324
-};
325
-