diff options
-rw-r--r-- | arch/mips/au1000/mtx-1/platform.c | 51 | ||||
-rw-r--r-- | drivers/mtd/maps/Kconfig | 7 | ||||
-rw-r--r-- | drivers/mtd/maps/Makefile | 1 | ||||
-rw-r--r-- | drivers/mtd/maps/mtx-1_flash.c | 95 |
4 files changed, 50 insertions, 104 deletions
diff --git a/arch/mips/au1000/mtx-1/platform.c b/arch/mips/au1000/mtx-1/platform.c index 9807be37c32f..8b5914d1241f 100644 --- a/arch/mips/au1000/mtx-1/platform.c +++ b/arch/mips/au1000/mtx-1/platform.c | |||
@@ -24,6 +24,9 @@ | |||
24 | #include <linux/gpio.h> | 24 | #include <linux/gpio.h> |
25 | #include <linux/gpio_keys.h> | 25 | #include <linux/gpio_keys.h> |
26 | #include <linux/input.h> | 26 | #include <linux/input.h> |
27 | #include <linux/mtd/partitions.h> | ||
28 | #include <linux/mtd/physmap.h> | ||
29 | #include <mtd/mtd-abi.h> | ||
27 | 30 | ||
28 | static struct gpio_keys_button mtx1_gpio_button[] = { | 31 | static struct gpio_keys_button mtx1_gpio_button[] = { |
29 | { | 32 | { |
@@ -85,10 +88,56 @@ static struct platform_device mtx1_gpio_leds = { | |||
85 | } | 88 | } |
86 | }; | 89 | }; |
87 | 90 | ||
91 | static struct mtd_partition mtx1_mtd_partitions[] = { | ||
92 | { | ||
93 | .name = "filesystem", | ||
94 | .size = 0x01C00000, | ||
95 | .offset = 0, | ||
96 | }, | ||
97 | { | ||
98 | .name = "yamon", | ||
99 | .size = 0x00100000, | ||
100 | .offset = MTDPART_OFS_APPEND, | ||
101 | .mask_flags = MTD_WRITEABLE, | ||
102 | }, | ||
103 | { | ||
104 | .name = "kernel", | ||
105 | .size = 0x002c0000, | ||
106 | .offset = MTDPART_OFS_APPEND, | ||
107 | }, | ||
108 | { | ||
109 | .name = "yamon env", | ||
110 | .size = 0x00040000, | ||
111 | .offset = MTDPART_OFS_APPEND, | ||
112 | }, | ||
113 | }; | ||
114 | |||
115 | static struct physmap_flash_data mtx1_flash_data = { | ||
116 | .width = 4, | ||
117 | .nr_parts = 4, | ||
118 | .parts = mtx1_mtd_partitions, | ||
119 | }; | ||
120 | |||
121 | static struct resource mtx1_mtd_resource = { | ||
122 | .start = 0x1e000000, | ||
123 | .end = 0x1fffffff, | ||
124 | .flags = IORESOURCE_MEM, | ||
125 | }; | ||
126 | |||
127 | static struct platform_device mtx1_mtd = { | ||
128 | .name = "physmap-flash", | ||
129 | .dev = { | ||
130 | .platform_data = &mtx1_flash_data, | ||
131 | }, | ||
132 | .num_resources = 1, | ||
133 | .resource = &mtx1_mtd_resource, | ||
134 | }; | ||
135 | |||
88 | static struct __initdata platform_device * mtx1_devs[] = { | 136 | static struct __initdata platform_device * mtx1_devs[] = { |
89 | &mtx1_gpio_leds, | 137 | &mtx1_gpio_leds, |
90 | &mtx1_wdt, | 138 | &mtx1_wdt, |
91 | &mtx1_button | 139 | &mtx1_button, |
140 | &mtx1_mtd, | ||
92 | }; | 141 | }; |
93 | 142 | ||
94 | static int __init mtx1_register_devices(void) | 143 | static int __init mtx1_register_devices(void) |
diff --git a/drivers/mtd/maps/Kconfig b/drivers/mtd/maps/Kconfig index 17bc87a43ff4..d2fbc2964523 100644 --- a/drivers/mtd/maps/Kconfig +++ b/drivers/mtd/maps/Kconfig | |||
@@ -258,13 +258,6 @@ config MTD_ALCHEMY | |||
258 | help | 258 | help |
259 | Flash memory access on AMD Alchemy Pb/Db/RDK Reference Boards | 259 | Flash memory access on AMD Alchemy Pb/Db/RDK Reference Boards |
260 | 260 | ||
261 | config MTD_MTX1 | ||
262 | tristate "4G Systems MTX-1 Flash device" | ||
263 | depends on MIPS_MTX1 && MTD_CFI | ||
264 | help | ||
265 | Flash memory access on 4G Systems MTX-1 Board. If you have one of | ||
266 | these boards and would like to use the flash chips on it, say 'Y'. | ||
267 | |||
268 | config MTD_DILNETPC | 261 | config MTD_DILNETPC |
269 | tristate "CFI Flash device mapped on DIL/Net PC" | 262 | tristate "CFI Flash device mapped on DIL/Net PC" |
270 | depends on X86 && MTD_CONCAT && MTD_PARTITIONS && MTD_CFI_INTELEXT | 263 | depends on X86 && MTD_CONCAT && MTD_PARTITIONS && MTD_CFI_INTELEXT |
diff --git a/drivers/mtd/maps/Makefile b/drivers/mtd/maps/Makefile index 957fb5f70f5e..c6ce8673dab2 100644 --- a/drivers/mtd/maps/Makefile +++ b/drivers/mtd/maps/Makefile | |||
@@ -65,5 +65,4 @@ obj-$(CONFIG_MTD_DMV182) += dmv182.o | |||
65 | obj-$(CONFIG_MTD_SHARP_SL) += sharpsl-flash.o | 65 | obj-$(CONFIG_MTD_SHARP_SL) += sharpsl-flash.o |
66 | obj-$(CONFIG_MTD_PLATRAM) += plat-ram.o | 66 | obj-$(CONFIG_MTD_PLATRAM) += plat-ram.o |
67 | obj-$(CONFIG_MTD_OMAP_NOR) += omap_nor.o | 67 | obj-$(CONFIG_MTD_OMAP_NOR) += omap_nor.o |
68 | obj-$(CONFIG_MTD_MTX1) += mtx-1_flash.o | ||
69 | obj-$(CONFIG_MTD_INTEL_VR_NOR) += intel_vr_nor.o | 68 | obj-$(CONFIG_MTD_INTEL_VR_NOR) += intel_vr_nor.o |
diff --git a/drivers/mtd/maps/mtx-1_flash.c b/drivers/mtd/maps/mtx-1_flash.c deleted file mode 100644 index 2a8fde9b92f0..000000000000 --- a/drivers/mtd/maps/mtx-1_flash.c +++ /dev/null | |||
@@ -1,95 +0,0 @@ | |||
1 | /* | ||
2 | * Flash memory access on 4G Systems MTX-1 boards | ||
3 | * | ||
4 | * $Id: mtx-1_flash.c,v 1.2 2005/11/07 11:14:27 gleixner Exp $ | ||
5 | * | ||
6 | * (C) 2005 Bruno Randolf <bruno.randolf@4g-systems.biz> | ||
7 | * (C) 2005 Joern Engel <joern@wohnheim.fh-wedel.de> | ||
8 | * | ||
9 | */ | ||
10 | |||
11 | #include <linux/module.h> | ||
12 | #include <linux/types.h> | ||
13 | #include <linux/init.h> | ||
14 | #include <linux/kernel.h> | ||
15 | |||
16 | #include <linux/mtd/mtd.h> | ||
17 | #include <linux/mtd/map.h> | ||
18 | #include <linux/mtd/partitions.h> | ||
19 | |||
20 | #include <asm/io.h> | ||
21 | |||
22 | static struct map_info mtx1_map = { | ||
23 | .name = "MTX-1 flash", | ||
24 | .bankwidth = 4, | ||
25 | .size = 0x2000000, | ||
26 | .phys = 0x1E000000, | ||
27 | }; | ||
28 | |||
29 | static struct mtd_partition mtx1_partitions[] = { | ||
30 | { | ||
31 | .name = "filesystem", | ||
32 | .size = 0x01C00000, | ||
33 | .offset = 0, | ||
34 | },{ | ||
35 | .name = "yamon", | ||
36 | .size = 0x00100000, | ||
37 | .offset = MTDPART_OFS_APPEND, | ||
38 | .mask_flags = MTD_WRITEABLE, | ||
39 | },{ | ||
40 | .name = "kernel", | ||
41 | .size = 0x002c0000, | ||
42 | .offset = MTDPART_OFS_APPEND, | ||
43 | },{ | ||
44 | .name = "yamon env", | ||
45 | .size = 0x00040000, | ||
46 | .offset = MTDPART_OFS_APPEND, | ||
47 | } | ||
48 | }; | ||
49 | |||
50 | static struct mtd_info *mtx1_mtd; | ||
51 | |||
52 | int __init mtx1_mtd_init(void) | ||
53 | { | ||
54 | int ret = -ENXIO; | ||
55 | |||
56 | simple_map_init(&mtx1_map); | ||
57 | |||
58 | mtx1_map.virt = ioremap(mtx1_map.phys, mtx1_map.size); | ||
59 | if (!mtx1_map.virt) | ||
60 | return -EIO; | ||
61 | |||
62 | mtx1_mtd = do_map_probe("cfi_probe", &mtx1_map); | ||
63 | if (!mtx1_mtd) | ||
64 | goto err; | ||
65 | |||
66 | mtx1_mtd->owner = THIS_MODULE; | ||
67 | |||
68 | ret = add_mtd_partitions(mtx1_mtd, mtx1_partitions, | ||
69 | ARRAY_SIZE(mtx1_partitions)); | ||
70 | if (ret) | ||
71 | goto err; | ||
72 | |||
73 | return 0; | ||
74 | |||
75 | err: | ||
76 | iounmap(mtx1_map.virt); | ||
77 | return ret; | ||
78 | } | ||
79 | |||
80 | static void __exit mtx1_mtd_cleanup(void) | ||
81 | { | ||
82 | if (mtx1_mtd) { | ||
83 | del_mtd_partitions(mtx1_mtd); | ||
84 | map_destroy(mtx1_mtd); | ||
85 | } | ||
86 | if (mtx1_map.virt) | ||
87 | iounmap(mtx1_map.virt); | ||
88 | } | ||
89 | |||
90 | module_init(mtx1_mtd_init); | ||
91 | module_exit(mtx1_mtd_cleanup); | ||
92 | |||
93 | MODULE_AUTHOR("Bruno Randolf <bruno.randolf@4g-systems.biz>"); | ||
94 | MODULE_DESCRIPTION("MTX-1 flash map"); | ||
95 | MODULE_LICENSE("GPL"); | ||