diff options
author | Ben Dooks <ben-linux@fluff.org> | 2008-07-03 06:24:39 -0400 |
---|---|---|
committer | Ben Dooks <ben-linux@fluff.org> | 2008-07-03 11:51:28 -0400 |
commit | 9d529c6e7b73088551057445763b2be755a3b82f (patch) | |
tree | eb2784455bdeb0e286c1518a1a1bdc238d7a6767 | |
parent | b9db83af69e4c61107803c85872d01a45949e052 (diff) |
[ARM] S3C24XX: Add physmap device for all Simtec NOR equiped boards.
Move to using the physmap platform device code to attached NOR
flash on Simtec boards so that the old bast-flash driver can be
safely removed.
Signed-off-by: Ben Dooks <ben-linux@fluff.org>
-rw-r--r-- | arch/arm/mach-s3c2410/Kconfig | 7 | ||||
-rw-r--r-- | arch/arm/mach-s3c2410/Makefile | 4 | ||||
-rw-r--r-- | arch/arm/mach-s3c2410/mach-bast.c | 22 | ||||
-rw-r--r-- | arch/arm/mach-s3c2410/mach-vr1000.c | 22 | ||||
-rw-r--r-- | arch/arm/mach-s3c2410/nor-simtec.c | 86 | ||||
-rw-r--r-- | arch/arm/mach-s3c2410/nor-simtec.h | 14 |
6 files changed, 119 insertions, 36 deletions
diff --git a/arch/arm/mach-s3c2410/Kconfig b/arch/arm/mach-s3c2410/Kconfig index 69689701acfc..1a7d01b47440 100644 --- a/arch/arm/mach-s3c2410/Kconfig +++ b/arch/arm/mach-s3c2410/Kconfig | |||
@@ -37,6 +37,11 @@ config S3C2410_CLOCK | |||
37 | help | 37 | help |
38 | Clock code for the S3C2410, and similar processors | 38 | Clock code for the S3C2410, and similar processors |
39 | 39 | ||
40 | config SIMTEC_NOR | ||
41 | bool | ||
42 | help | ||
43 | Internal node to specify machine has simtec NOR mapping | ||
44 | |||
40 | config MACH_BAST_IDE | 45 | config MACH_BAST_IDE |
41 | bool | 46 | bool |
42 | select HAVE_PATA_PLATFORM | 47 | select HAVE_PATA_PLATFORM |
@@ -76,6 +81,7 @@ config ARCH_BAST | |||
76 | bool "Simtec Electronics BAST (EB2410ITX)" | 81 | bool "Simtec Electronics BAST (EB2410ITX)" |
77 | select CPU_S3C2410 | 82 | select CPU_S3C2410 |
78 | select PM_SIMTEC if PM | 83 | select PM_SIMTEC if PM |
84 | select SIMTEC_NOR | ||
79 | select MACH_BAST_IDE | 85 | select MACH_BAST_IDE |
80 | select ISA | 86 | select ISA |
81 | help | 87 | help |
@@ -114,6 +120,7 @@ config MACH_TCT_HAMMER | |||
114 | config MACH_VR1000 | 120 | config MACH_VR1000 |
115 | bool "Thorcom VR1000" | 121 | bool "Thorcom VR1000" |
116 | select PM_SIMTEC if PM | 122 | select PM_SIMTEC if PM |
123 | select SIMTEC_NOR | ||
117 | select MACH_BAST_IDE | 124 | select MACH_BAST_IDE |
118 | select CPU_S3C2410 | 125 | select CPU_S3C2410 |
119 | help | 126 | help |
diff --git a/arch/arm/mach-s3c2410/Makefile b/arch/arm/mach-s3c2410/Makefile index 8a4055dc858b..00f31f8c4e78 100644 --- a/arch/arm/mach-s3c2410/Makefile +++ b/arch/arm/mach-s3c2410/Makefile | |||
@@ -31,6 +31,10 @@ obj-$(CONFIG_MACH_TCT_HAMMER) += mach-tct_hammer.o | |||
31 | obj-$(CONFIG_MACH_VR1000) += mach-vr1000.o usb-simtec.o | 31 | obj-$(CONFIG_MACH_VR1000) += mach-vr1000.o usb-simtec.o |
32 | obj-$(CONFIG_MACH_QT2410) += mach-qt2410.o | 32 | obj-$(CONFIG_MACH_QT2410) += mach-qt2410.o |
33 | 33 | ||
34 | # Common bits of machine support | ||
35 | |||
36 | obj-$(CONFIG_SIMTEC_NOR) += nor-simtec.o | ||
37 | |||
34 | # machine additions | 38 | # machine additions |
35 | 39 | ||
36 | obj-$(CONFIG_MACH_BAST_IDE) += bast-ide.o | 40 | obj-$(CONFIG_MACH_BAST_IDE) += bast-ide.o |
diff --git a/arch/arm/mach-s3c2410/mach-bast.c b/arch/arm/mach-s3c2410/mach-bast.c index 093be00c8eb5..2a512e863141 100644 --- a/arch/arm/mach-s3c2410/mach-bast.c +++ b/arch/arm/mach-s3c2410/mach-bast.c | |||
@@ -57,7 +57,9 @@ | |||
57 | #include <asm/plat-s3c24xx/clock.h> | 57 | #include <asm/plat-s3c24xx/clock.h> |
58 | #include <asm/plat-s3c24xx/devs.h> | 58 | #include <asm/plat-s3c24xx/devs.h> |
59 | #include <asm/plat-s3c24xx/cpu.h> | 59 | #include <asm/plat-s3c24xx/cpu.h> |
60 | |||
60 | #include "usb-simtec.h" | 61 | #include "usb-simtec.h" |
62 | #include "nor-simtec.h" | ||
61 | 63 | ||
62 | #define COPYRIGHT ", (c) 2004-2005 Simtec Electronics" | 64 | #define COPYRIGHT ", (c) 2004-2005 Simtec Electronics" |
63 | 65 | ||
@@ -203,23 +205,6 @@ static struct s3c2410_uartcfg bast_uartcfgs[] __initdata = { | |||
203 | } | 205 | } |
204 | }; | 206 | }; |
205 | 207 | ||
206 | /* NOR Flash on BAST board */ | ||
207 | |||
208 | static struct resource bast_nor_resource[] = { | ||
209 | [0] = { | ||
210 | .start = S3C2410_CS1 + 0x4000000, | ||
211 | .end = S3C2410_CS1 + 0x4000000 + (32*1024*1024) - 1, | ||
212 | .flags = IORESOURCE_MEM, | ||
213 | } | ||
214 | }; | ||
215 | |||
216 | static struct platform_device bast_device_nor = { | ||
217 | .name = "bast-nor", | ||
218 | .id = -1, | ||
219 | .num_resources = ARRAY_SIZE(bast_nor_resource), | ||
220 | .resource = bast_nor_resource, | ||
221 | }; | ||
222 | |||
223 | /* NAND Flash on BAST board */ | 208 | /* NAND Flash on BAST board */ |
224 | 209 | ||
225 | #ifdef CONFIG_PM | 210 | #ifdef CONFIG_PM |
@@ -559,7 +544,6 @@ static struct platform_device *bast_devices[] __initdata = { | |||
559 | &s3c_device_i2c, | 544 | &s3c_device_i2c, |
560 | &s3c_device_rtc, | 545 | &s3c_device_rtc, |
561 | &s3c_device_nand, | 546 | &s3c_device_nand, |
562 | &bast_device_nor, | ||
563 | &bast_device_dm9k, | 547 | &bast_device_dm9k, |
564 | &bast_device_asix, | 548 | &bast_device_asix, |
565 | &bast_device_axpp, | 549 | &bast_device_axpp, |
@@ -608,6 +592,8 @@ static void __init bast_init(void) | |||
608 | 592 | ||
609 | s3c24xx_fb_set_platdata(&bast_fb_info); | 593 | s3c24xx_fb_set_platdata(&bast_fb_info); |
610 | platform_add_devices(bast_devices, ARRAY_SIZE(bast_devices)); | 594 | platform_add_devices(bast_devices, ARRAY_SIZE(bast_devices)); |
595 | |||
596 | nor_simtec_init(); | ||
611 | } | 597 | } |
612 | 598 | ||
613 | MACHINE_START(BAST, "Simtec-BAST") | 599 | MACHINE_START(BAST, "Simtec-BAST") |
diff --git a/arch/arm/mach-s3c2410/mach-vr1000.c b/arch/arm/mach-s3c2410/mach-vr1000.c index 1d0a0284f336..f133ccfc359e 100644 --- a/arch/arm/mach-s3c2410/mach-vr1000.c +++ b/arch/arm/mach-s3c2410/mach-vr1000.c | |||
@@ -46,7 +46,9 @@ | |||
46 | #include <asm/plat-s3c24xx/clock.h> | 46 | #include <asm/plat-s3c24xx/clock.h> |
47 | #include <asm/plat-s3c24xx/devs.h> | 47 | #include <asm/plat-s3c24xx/devs.h> |
48 | #include <asm/plat-s3c24xx/cpu.h> | 48 | #include <asm/plat-s3c24xx/cpu.h> |
49 | |||
49 | #include "usb-simtec.h" | 50 | #include "usb-simtec.h" |
51 | #include "nor-simtec.h" | ||
50 | 52 | ||
51 | /* macros for virtual address mods for the io space entries */ | 53 | /* macros for virtual address mods for the io space entries */ |
52 | #define VA_C5(item) ((unsigned long)(item) + BAST_VAM_CS5) | 54 | #define VA_C5(item) ((unsigned long)(item) + BAST_VAM_CS5) |
@@ -202,23 +204,6 @@ static struct platform_device serial_device = { | |||
202 | }, | 204 | }, |
203 | }; | 205 | }; |
204 | 206 | ||
205 | /* MTD NOR Flash */ | ||
206 | |||
207 | static struct resource vr1000_nor_resource[] = { | ||
208 | [0] = { | ||
209 | .start = S3C2410_CS1 + 0x4000000, | ||
210 | .end = S3C2410_CS1 + 0x4000000 + SZ_16M - 1, | ||
211 | .flags = IORESOURCE_MEM, | ||
212 | } | ||
213 | }; | ||
214 | |||
215 | static struct platform_device vr1000_nor = { | ||
216 | .name = "bast-nor", | ||
217 | .id = -1, | ||
218 | .num_resources = ARRAY_SIZE(vr1000_nor_resource), | ||
219 | .resource = vr1000_nor_resource, | ||
220 | }; | ||
221 | |||
222 | /* DM9000 ethernet devices */ | 207 | /* DM9000 ethernet devices */ |
223 | 208 | ||
224 | static struct resource vr1000_dm9k0_resource[] = { | 209 | static struct resource vr1000_dm9k0_resource[] = { |
@@ -339,7 +324,6 @@ static struct platform_device *vr1000_devices[] __initdata = { | |||
339 | &s3c_device_i2c, | 324 | &s3c_device_i2c, |
340 | &s3c_device_adc, | 325 | &s3c_device_adc, |
341 | &serial_device, | 326 | &serial_device, |
342 | &vr1000_nor, | ||
343 | &vr1000_dm9k0, | 327 | &vr1000_dm9k0, |
344 | &vr1000_dm9k1, | 328 | &vr1000_dm9k1, |
345 | &vr1000_led1, | 329 | &vr1000_led1, |
@@ -388,6 +372,8 @@ static void __init vr1000_map_io(void) | |||
388 | static void __init vr1000_init(void) | 372 | static void __init vr1000_init(void) |
389 | { | 373 | { |
390 | platform_add_devices(vr1000_devices, ARRAY_SIZE(vr1000_devices)); | 374 | platform_add_devices(vr1000_devices, ARRAY_SIZE(vr1000_devices)); |
375 | |||
376 | nor_simtec_init(); | ||
391 | } | 377 | } |
392 | 378 | ||
393 | MACHINE_START(VR1000, "Thorcom-VR1000") | 379 | MACHINE_START(VR1000, "Thorcom-VR1000") |
diff --git a/arch/arm/mach-s3c2410/nor-simtec.c b/arch/arm/mach-s3c2410/nor-simtec.c new file mode 100644 index 000000000000..f44e21b9c3ba --- /dev/null +++ b/arch/arm/mach-s3c2410/nor-simtec.c | |||
@@ -0,0 +1,86 @@ | |||
1 | /* linux/arch/arm/mach-s3c2410/nor-simtec.c | ||
2 | * | ||
3 | * Copyright (c) 2008 Simtec Electronics | ||
4 | * http://armlinux.simtec.co.uk/ | ||
5 | * Ben Dooks <ben@simtec.co.uk> | ||
6 | * | ||
7 | * Simtec NOR mapping | ||
8 | * | ||
9 | * This program is free software; you can redistribute it and/or modify | ||
10 | * it under the terms of the GNU General Public License version 2 as | ||
11 | * published by the Free Software Foundation. | ||
12 | */ | ||
13 | |||
14 | #include <linux/module.h> | ||
15 | #include <linux/types.h> | ||
16 | #include <linux/init.h> | ||
17 | #include <linux/kernel.h> | ||
18 | #include <linux/platform_device.h> | ||
19 | |||
20 | #include <linux/mtd/mtd.h> | ||
21 | #include <linux/mtd/map.h> | ||
22 | #include <linux/mtd/physmap.h> | ||
23 | #include <linux/mtd/partitions.h> | ||
24 | |||
25 | #include <asm/mach/arch.h> | ||
26 | #include <asm/mach/map.h> | ||
27 | #include <asm/mach/irq.h> | ||
28 | |||
29 | #include <asm/arch/map.h> | ||
30 | #include <asm/arch/bast-map.h> | ||
31 | #include <asm/arch/bast-cpld.h> | ||
32 | |||
33 | |||
34 | static void simtec_nor_vpp(struct map_info *map, int vpp) | ||
35 | { | ||
36 | unsigned int val; | ||
37 | unsigned long flags; | ||
38 | |||
39 | local_irq_save(flags); | ||
40 | val = __raw_readb(BAST_VA_CTRL3); | ||
41 | |||
42 | printk(KERN_DEBUG "%s(%d)\n", __func__, vpp); | ||
43 | |||
44 | if (vpp) | ||
45 | val |= BAST_CPLD_CTRL3_ROMWEN; | ||
46 | else | ||
47 | val &= ~BAST_CPLD_CTRL3_ROMWEN; | ||
48 | |||
49 | __raw_writeb(val, BAST_VA_CTRL3); | ||
50 | local_irq_restore(flags); | ||
51 | } | ||
52 | |||
53 | struct physmap_flash_data simtec_nor_pdata = { | ||
54 | .width = 2, | ||
55 | .set_vpp = simtec_nor_vpp, | ||
56 | .nr_parts = 0, | ||
57 | }; | ||
58 | |||
59 | static struct resource simtec_nor_resource[] = { | ||
60 | [0] = { | ||
61 | .start = S3C2410_CS1 + 0x4000000, | ||
62 | .end = S3C2410_CS1 + 0x4000000 + SZ_8M - 1, | ||
63 | .flags = IORESOURCE_MEM, | ||
64 | } | ||
65 | }; | ||
66 | |||
67 | static struct platform_device simtec_device_nor = { | ||
68 | .name = "physmap-flash", | ||
69 | .id = -1, | ||
70 | .num_resources = ARRAY_SIZE(simtec_nor_resource), | ||
71 | .resource = simtec_nor_resource, | ||
72 | .dev = { | ||
73 | .platform_data = &simtec_nor_pdata, | ||
74 | }, | ||
75 | }; | ||
76 | |||
77 | void __init nor_simtec_init(void) | ||
78 | { | ||
79 | int ret; | ||
80 | |||
81 | ret = platform_device_register(&simtec_device_nor); | ||
82 | if (ret < 0) | ||
83 | printk(KERN_ERR "failed to register physmap-flash device\n"); | ||
84 | else | ||
85 | simtec_nor_vpp(NULL, 1); | ||
86 | } | ||
diff --git a/arch/arm/mach-s3c2410/nor-simtec.h b/arch/arm/mach-s3c2410/nor-simtec.h new file mode 100644 index 000000000000..f619c1e0d0c8 --- /dev/null +++ b/arch/arm/mach-s3c2410/nor-simtec.h | |||
@@ -0,0 +1,14 @@ | |||
1 | /* linux/arch/arm/mach-s3c2410/nor-simtec.h | ||
2 | * | ||
3 | * Copyright (c) 2008 Simtec Electronics | ||
4 | * http://armlinux.simtec.co.uk/ | ||
5 | * Ben Dooks <ben@simtec.co.uk> | ||
6 | * | ||
7 | * Simtec NOR mapping | ||
8 | * | ||
9 | * This program is free software; you can redistribute it and/or modify | ||
10 | * it under the terms of the GNU General Public License version 2 as | ||
11 | * published by the Free Software Foundation. | ||
12 | */ | ||
13 | |||
14 | extern void nor_simtec_init(void); | ||