diff options
-rw-r--r-- | drivers/mtd/maps/Kconfig | 44 | ||||
-rw-r--r-- | drivers/mtd/maps/Makefile | 1 | ||||
-rw-r--r-- | drivers/mtd/maps/cstm_mips_ixx.c | 164 |
3 files changed, 0 insertions, 209 deletions
diff --git a/drivers/mtd/maps/Kconfig b/drivers/mtd/maps/Kconfig index 7aac68a62f8c..3a33b98eb93d 100644 --- a/drivers/mtd/maps/Kconfig +++ b/drivers/mtd/maps/Kconfig | |||
@@ -382,50 +382,6 @@ config MTD_TQM834x | |||
382 | TQ Components TQM834x boards. If you have one of these boards | 382 | TQ Components TQM834x boards. If you have one of these boards |
383 | and would like to use the flash chips on it, say 'Y'. | 383 | and would like to use the flash chips on it, say 'Y'. |
384 | 384 | ||
385 | config MTD_CSTM_MIPS_IXX | ||
386 | tristate "Flash chip mapping on ITE QED-4N-S01B, Globespan IVR or custom board" | ||
387 | depends on MIPS && MTD_CFI && MTD_JEDECPROBE && MTD_PARTITIONS | ||
388 | help | ||
389 | This provides a mapping driver for the Integrated Technology | ||
390 | Express, Inc (ITE) QED-4N-S01B eval board and the Globespan IVR | ||
391 | Reference Board. It provides the necessary addressing, length, | ||
392 | buswidth, vpp code and addition setup of the flash device for | ||
393 | these boards. In addition, this mapping driver can be used for | ||
394 | other boards via setting of the CONFIG_MTD_CSTM_MIPS_IXX_START/ | ||
395 | LEN/BUSWIDTH parameters. This mapping will provide one mtd device | ||
396 | using one partition. The start address can be offset from the | ||
397 | beginning of flash and the len can be less than the total flash | ||
398 | device size to allow a window into the flash. Both CFI and JEDEC | ||
399 | probes are called. | ||
400 | |||
401 | config MTD_CSTM_MIPS_IXX_START | ||
402 | hex "Physical start address of flash mapping" | ||
403 | depends on MTD_CSTM_MIPS_IXX | ||
404 | default "0x8000000" | ||
405 | help | ||
406 | This is the physical memory location that the MTD driver will | ||
407 | use for the flash chips on your particular target board. | ||
408 | Refer to the memory map which should hopefully be in the | ||
409 | documentation for your board. | ||
410 | |||
411 | config MTD_CSTM_MIPS_IXX_LEN | ||
412 | hex "Physical length of flash mapping" | ||
413 | depends on MTD_CSTM_MIPS_IXX | ||
414 | default "0x4000000" | ||
415 | help | ||
416 | This is the total length that the MTD driver will use for the | ||
417 | flash chips on your particular board. Refer to the memory | ||
418 | map which should hopefully be in the documentation for your | ||
419 | board. | ||
420 | |||
421 | config MTD_CSTM_MIPS_IXX_BUSWIDTH | ||
422 | int "Bus width in octets" | ||
423 | depends on MTD_CSTM_MIPS_IXX | ||
424 | default "2" | ||
425 | help | ||
426 | This is the total bus width of the mapping of the flash chips | ||
427 | on your particular board. | ||
428 | |||
429 | config MTD_OCELOT | 385 | config MTD_OCELOT |
430 | tristate "Momenco Ocelot boot flash device" | 386 | tristate "Momenco Ocelot boot flash device" |
431 | depends on MIPS && MOMENCO_OCELOT | 387 | depends on MIPS && MOMENCO_OCELOT |
diff --git a/drivers/mtd/maps/Makefile b/drivers/mtd/maps/Makefile index df019be753e3..071d0bf922b6 100644 --- a/drivers/mtd/maps/Makefile +++ b/drivers/mtd/maps/Makefile | |||
@@ -12,7 +12,6 @@ obj-$(CONFIG_MTD_CDB89712) += cdb89712.o | |||
12 | obj-$(CONFIG_MTD_ARM_INTEGRATOR)+= integrator-flash.o | 12 | obj-$(CONFIG_MTD_ARM_INTEGRATOR)+= integrator-flash.o |
13 | obj-$(CONFIG_MTD_BAST) += bast-flash.o | 13 | obj-$(CONFIG_MTD_BAST) += bast-flash.o |
14 | obj-$(CONFIG_MTD_CFI_FLAGADM) += cfi_flagadm.o | 14 | obj-$(CONFIG_MTD_CFI_FLAGADM) += cfi_flagadm.o |
15 | obj-$(CONFIG_MTD_CSTM_MIPS_IXX) += cstm_mips_ixx.o | ||
16 | obj-$(CONFIG_MTD_DC21285) += dc21285.o | 15 | obj-$(CONFIG_MTD_DC21285) += dc21285.o |
17 | obj-$(CONFIG_MTD_DILNETPC) += dilnetpc.o | 16 | obj-$(CONFIG_MTD_DILNETPC) += dilnetpc.o |
18 | obj-$(CONFIG_MTD_L440GX) += l440gx.o | 17 | obj-$(CONFIG_MTD_L440GX) += l440gx.o |
diff --git a/drivers/mtd/maps/cstm_mips_ixx.c b/drivers/mtd/maps/cstm_mips_ixx.c deleted file mode 100644 index 2ef22a5a1de2..000000000000 --- a/drivers/mtd/maps/cstm_mips_ixx.c +++ /dev/null | |||
@@ -1,164 +0,0 @@ | |||
1 | /* | ||
2 | * $Id: cstm_mips_ixx.c,v 1.14 2005/11/07 11:14:26 gleixner Exp $ | ||
3 | * | ||
4 | * Mapping of a custom board with both AMD CFI and JEDEC flash in partitions. | ||
5 | * Config with both CFI and JEDEC device support. | ||
6 | * | ||
7 | * Basically physmap.c with the addition of partitions and | ||
8 | * an array of mapping info to accomodate more than one flash type per board. | ||
9 | * | ||
10 | * Copyright 2000 MontaVista Software Inc. | ||
11 | * | ||
12 | * This program is free software; you can redistribute it and/or modify it | ||
13 | * under the terms of the GNU General Public License as published by the | ||
14 | * Free Software Foundation; either version 2 of the License, or (at your | ||
15 | * option) any later version. | ||
16 | * | ||
17 | * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED | ||
18 | * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | ||
19 | * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN | ||
20 | * NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, | ||
21 | * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT | ||
22 | * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF | ||
23 | * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON | ||
24 | * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||
25 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||
26 | * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
27 | * | ||
28 | * You should have received a copy of the GNU General Public License along | ||
29 | * with this program; if not, write to the Free Software Foundation, Inc., | ||
30 | * 675 Mass Ave, Cambridge, MA 02139, USA. | ||
31 | */ | ||
32 | |||
33 | #include <linux/module.h> | ||
34 | #include <linux/types.h> | ||
35 | #include <linux/kernel.h> | ||
36 | #include <linux/init.h> | ||
37 | #include <asm/io.h> | ||
38 | #include <linux/mtd/mtd.h> | ||
39 | #include <linux/mtd/map.h> | ||
40 | #include <linux/mtd/partitions.h> | ||
41 | #include <linux/delay.h> | ||
42 | |||
43 | /* board and partition description */ | ||
44 | |||
45 | #define MAX_PHYSMAP_PARTITIONS 8 | ||
46 | struct cstm_mips_ixx_info { | ||
47 | char *name; | ||
48 | unsigned long window_addr; | ||
49 | unsigned long window_size; | ||
50 | int bankwidth; | ||
51 | int num_partitions; | ||
52 | }; | ||
53 | |||
54 | #define PHYSMAP_NUMBER 1 // number of board desc structs needed, one per contiguous flash type | ||
55 | const struct cstm_mips_ixx_info cstm_mips_ixx_board_desc[PHYSMAP_NUMBER] = | ||
56 | { | ||
57 | { | ||
58 | "MTD flash", // name | ||
59 | CONFIG_MTD_CSTM_MIPS_IXX_START, // window_addr | ||
60 | CONFIG_MTD_CSTM_MIPS_IXX_LEN, // window_size | ||
61 | CONFIG_MTD_CSTM_MIPS_IXX_BUSWIDTH, // bankwidth | ||
62 | 1, // num_partitions | ||
63 | }, | ||
64 | |||
65 | }; | ||
66 | static struct mtd_partition cstm_mips_ixx_partitions[PHYSMAP_NUMBER][MAX_PHYSMAP_PARTITIONS] = { | ||
67 | { | ||
68 | { | ||
69 | .name = "main partition", | ||
70 | .size = CONFIG_MTD_CSTM_MIPS_IXX_LEN, | ||
71 | .offset = 0, | ||
72 | }, | ||
73 | }, | ||
74 | }; | ||
75 | |||
76 | struct map_info cstm_mips_ixx_map[PHYSMAP_NUMBER]; | ||
77 | |||
78 | int __init init_cstm_mips_ixx(void) | ||
79 | { | ||
80 | int i; | ||
81 | int jedec; | ||
82 | struct mtd_info *mymtd; | ||
83 | struct mtd_partition *parts; | ||
84 | |||
85 | /* Initialize mapping */ | ||
86 | for (i=0;i<PHYSMAP_NUMBER;i++) { | ||
87 | printk(KERN_NOTICE "cstm_mips_ixx flash device: 0x%lx at 0x%lx\n", | ||
88 | cstm_mips_ixx_board_desc[i].window_size, cstm_mips_ixx_board_desc[i].window_addr); | ||
89 | |||
90 | |||
91 | cstm_mips_ixx_map[i].phys = cstm_mips_ixx_board_desc[i].window_addr; | ||
92 | cstm_mips_ixx_map[i].virt = ioremap(cstm_mips_ixx_board_desc[i].window_addr, cstm_mips_ixx_board_desc[i].window_size); | ||
93 | if (!cstm_mips_ixx_map[i].virt) { | ||
94 | int j = 0; | ||
95 | printk(KERN_WARNING "Failed to ioremap\n"); | ||
96 | for (j = 0; j < i; j++) { | ||
97 | if (cstm_mips_ixx_map[j].virt) { | ||
98 | iounmap(cstm_mips_ixx_map[j].virt); | ||
99 | cstm_mips_ixx_map[j].virt = NULL; | ||
100 | } | ||
101 | } | ||
102 | return -EIO; | ||
103 | } | ||
104 | cstm_mips_ixx_map[i].name = cstm_mips_ixx_board_desc[i].name; | ||
105 | cstm_mips_ixx_map[i].size = cstm_mips_ixx_board_desc[i].window_size; | ||
106 | cstm_mips_ixx_map[i].bankwidth = cstm_mips_ixx_board_desc[i].bankwidth; | ||
107 | simple_map_init(&cstm_mips_ixx_map[i]); | ||
108 | //printk(KERN_NOTICE "cstm_mips_ixx: ioremap is %x\n",(unsigned int)(cstm_mips_ixx_map[i].virt)); | ||
109 | } | ||
110 | |||
111 | for (i=0;i<PHYSMAP_NUMBER;i++) { | ||
112 | parts = &cstm_mips_ixx_partitions[i][0]; | ||
113 | jedec = 0; | ||
114 | mymtd = (struct mtd_info *)do_map_probe("cfi_probe", &cstm_mips_ixx_map[i]); | ||
115 | //printk(KERN_NOTICE "phymap %d cfi_probe: mymtd is %x\n",i,(unsigned int)mymtd); | ||
116 | if (!mymtd) { | ||
117 | jedec = 1; | ||
118 | mymtd = (struct mtd_info *)do_map_probe("jedec_probe", &cstm_mips_ixx_map[i]); | ||
119 | printk(KERN_NOTICE "cstm_mips_ixx %d jedec: mymtd is %x\n",i,(unsigned int)mymtd); | ||
120 | } | ||
121 | if (mymtd) { | ||
122 | mymtd->owner = THIS_MODULE; | ||
123 | |||
124 | cstm_mips_ixx_map[i].map_priv_2 = (unsigned long)mymtd; | ||
125 | add_mtd_partitions(mymtd, parts, cstm_mips_ixx_board_desc[i].num_partitions); | ||
126 | } | ||
127 | else { | ||
128 | for (i = 0; i < PHYSMAP_NUMBER; i++) { | ||
129 | if (cstm_mips_ixx_map[i].virt) { | ||
130 | iounmap(cstm_mips_ixx_map[i].virt); | ||
131 | cstm_mips_ixx_map[i].virt = NULL; | ||
132 | } | ||
133 | } | ||
134 | return -ENXIO; | ||
135 | } | ||
136 | } | ||
137 | return 0; | ||
138 | } | ||
139 | |||
140 | static void __exit cleanup_cstm_mips_ixx(void) | ||
141 | { | ||
142 | int i; | ||
143 | struct mtd_info *mymtd; | ||
144 | |||
145 | for (i=0;i<PHYSMAP_NUMBER;i++) { | ||
146 | mymtd = (struct mtd_info *)cstm_mips_ixx_map[i].map_priv_2; | ||
147 | if (mymtd) { | ||
148 | del_mtd_partitions(mymtd); | ||
149 | map_destroy(mymtd); | ||
150 | } | ||
151 | if (cstm_mips_ixx_map[i].virt) { | ||
152 | iounmap((void *)cstm_mips_ixx_map[i].virt); | ||
153 | cstm_mips_ixx_map[i].virt = 0; | ||
154 | } | ||
155 | } | ||
156 | } | ||
157 | |||
158 | module_init(init_cstm_mips_ixx); | ||
159 | module_exit(cleanup_cstm_mips_ixx); | ||
160 | |||
161 | |||
162 | MODULE_LICENSE("GPL"); | ||
163 | MODULE_AUTHOR("Alice Hennessy <ahennessy@mvista.com>"); | ||
164 | MODULE_DESCRIPTION("MTD map driver for MIPS boards"); | ||