aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMagnus Damm <damm@igel.co.jp>2009-05-01 02:58:52 -0400
committerPaul Mundt <lethal@linux-sh.org>2009-05-03 04:41:37 -0400
commitd43a41bf8b504a1d9f0b4ce7e17d803f4ef39d84 (patch)
tree4021999f16ac221e7478f43b7ee4fea6de863b28
parent9570ef20423b549757aa484ad388f9a7d5bdc4d9 (diff)
sh: TMU platform data for sh7722
This patch adds TMU platform data for sh7722. Only clockevent mode is enabled for now, clocksource requires this patch: "clocksource: setup mult_orig in clocksource_enable()" Signed-off-by: Magnus Damm <damm@igel.co.jp> Signed-off-by: Paul Mundt <lethal@linux-sh.org>
-rw-r--r--arch/sh/Kconfig1
-rw-r--r--arch/sh/kernel/cpu/sh4a/setup-sh7722.c99
2 files changed, 100 insertions, 0 deletions
diff --git a/arch/sh/Kconfig b/arch/sh/Kconfig
index 1f74737c4f20..c3e9455498a0 100644
--- a/arch/sh/Kconfig
+++ b/arch/sh/Kconfig
@@ -423,6 +423,7 @@ config CPU_SUBTYPE_SH7722
423 select ARCH_SPARSEMEM_ENABLE 423 select ARCH_SPARSEMEM_ENABLE
424 select SYS_SUPPORTS_NUMA 424 select SYS_SUPPORTS_NUMA
425 select SYS_SUPPORTS_CMT 425 select SYS_SUPPORTS_CMT
426 select SYS_SUPPORTS_TMU
426 427
427config CPU_SUBTYPE_SH7366 428config CPU_SUBTYPE_SH7366
428 bool "Support SH7366 processor" 429 bool "Support SH7366 processor"
diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7722.c b/arch/sh/kernel/cpu/sh4a/setup-sh7722.c
index 793c50da6a84..512735c5cc86 100644
--- a/arch/sh/kernel/cpu/sh4a/setup-sh7722.c
+++ b/arch/sh/kernel/cpu/sh4a/setup-sh7722.c
@@ -14,6 +14,7 @@
14#include <linux/mm.h> 14#include <linux/mm.h>
15#include <linux/uio_driver.h> 15#include <linux/uio_driver.h>
16#include <linux/sh_cmt.h> 16#include <linux/sh_cmt.h>
17#include <linux/sh_tmu.h>
17#include <asm/clock.h> 18#include <asm/clock.h>
18#include <asm/mmzone.h> 19#include <asm/mmzone.h>
19 20
@@ -209,6 +210,98 @@ static struct platform_device cmt_device = {
209 .num_resources = ARRAY_SIZE(cmt_resources), 210 .num_resources = ARRAY_SIZE(cmt_resources),
210}; 211};
211 212
213static struct sh_tmu_config tmu0_platform_data = {
214 .name = "TMU0",
215 .channel_offset = 0x04,
216 .timer_bit = 0,
217 .clk = "tmu0",
218 .clockevent_rating = 200,
219};
220
221static struct resource tmu0_resources[] = {
222 [0] = {
223 .name = "TMU0",
224 .start = 0xffd80008,
225 .end = 0xffd80013,
226 .flags = IORESOURCE_MEM,
227 },
228 [1] = {
229 .start = 16,
230 .flags = IORESOURCE_IRQ,
231 },
232};
233
234static struct platform_device tmu0_device = {
235 .name = "sh_tmu",
236 .id = 0,
237 .dev = {
238 .platform_data = &tmu0_platform_data,
239 },
240 .resource = tmu0_resources,
241 .num_resources = ARRAY_SIZE(tmu0_resources),
242};
243
244static struct sh_tmu_config tmu1_platform_data = {
245 .name = "TMU1",
246 .channel_offset = 0x10,
247 .timer_bit = 1,
248 .clk = "tmu0",
249 .clocksource_rating = 0, /* disabled for now */
250};
251
252static struct resource tmu1_resources[] = {
253 [0] = {
254 .name = "TMU1",
255 .start = 0xffd80014,
256 .end = 0xffd8001f,
257 .flags = IORESOURCE_MEM,
258 },
259 [1] = {
260 .start = 17,
261 .flags = IORESOURCE_IRQ,
262 },
263};
264
265static struct platform_device tmu1_device = {
266 .name = "sh_tmu",
267 .id = 1,
268 .dev = {
269 .platform_data = &tmu1_platform_data,
270 },
271 .resource = tmu1_resources,
272 .num_resources = ARRAY_SIZE(tmu1_resources),
273};
274
275static struct sh_tmu_config tmu2_platform_data = {
276 .name = "TMU2",
277 .channel_offset = 0x1c,
278 .timer_bit = 2,
279 .clk = "tmu0",
280};
281
282static struct resource tmu2_resources[] = {
283 [0] = {
284 .name = "TMU2",
285 .start = 0xffd80020,
286 .end = 0xffd8002b,
287 .flags = IORESOURCE_MEM,
288 },
289 [1] = {
290 .start = 18,
291 .flags = IORESOURCE_IRQ,
292 },
293};
294
295static struct platform_device tmu2_device = {
296 .name = "sh_tmu",
297 .id = 2,
298 .dev = {
299 .platform_data = &tmu2_platform_data,
300 },
301 .resource = tmu2_resources,
302 .num_resources = ARRAY_SIZE(tmu2_resources),
303};
304
212static struct plat_sci_port sci_platform_data[] = { 305static struct plat_sci_port sci_platform_data[] = {
213 { 306 {
214 .mapbase = 0xffe00000, 307 .mapbase = 0xffe00000,
@@ -243,6 +336,9 @@ static struct platform_device sci_device = {
243 336
244static struct platform_device *sh7722_devices[] __initdata = { 337static struct platform_device *sh7722_devices[] __initdata = {
245 &cmt_device, 338 &cmt_device,
339 &tmu0_device,
340 &tmu1_device,
341 &tmu2_device,
246 &rtc_device, 342 &rtc_device,
247 &usbf_device, 343 &usbf_device,
248 &iic_device, 344 &iic_device,
@@ -271,6 +367,9 @@ __initcall(sh7722_devices_setup);
271 367
272static struct platform_device *sh7722_early_devices[] __initdata = { 368static struct platform_device *sh7722_early_devices[] __initdata = {
273 &cmt_device, 369 &cmt_device,
370 &tmu0_device,
371 &tmu1_device,
372 &tmu2_device,
274}; 373};
275 374
276void __init plat_early_device_setup(void) 375void __init plat_early_device_setup(void)