2 * Flash memory support for various TI OMAP boards
4 * Copyright (C) 2001-2002 MontaVista Software Inc.
5 * Copyright (C) 2003-2004 Texas Instruments
6 * Copyright (C) 2004 Nokia Corporation
8 * Assembled using driver code copyright the companies above
9 * and written by David Brownell, Jian Zhang <jzhang@ti.com>,
10 * Tony Lindgren <tony@atomide.com> and others.
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.
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.
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.
33 #include <linux/device.h>
34 #include <linux/module.h>
35 #include <linux/types.h>
36 #include <linux/kernel.h>
37 #include <linux/init.h>
38 #include <linux/ioport.h>
39 #include <linux/mtd/mtd.h>
40 #include <linux/mtd/map.h>
41 #include <linux/mtd/partitions.h>
44 #include <asm/hardware.h>
45 #include <asm/mach-types.h>
46 #include <asm/mach/flash.h>
47 #include <asm/arch/tc.h>
49 #ifdef CONFIG_MTD_PARTITIONS
50 static const char *part_probes
[] = { /* "RedBoot", */ "cmdlinepart", NULL
};
53 struct omapflash_info
{
54 struct mtd_partition
*parts
;
59 static void omap_set_vpp(struct map_info
*map
, int enable
)
65 OMAP_EMIFS_CONFIG_REG
|= OMAP_EMIFS_CONFIG_WP
;
67 if (count
&& (--count
== 0))
68 OMAP_EMIFS_CONFIG_REG
&= ~OMAP_EMIFS_CONFIG_WP
;
72 static int __devinit
omapflash_probe(struct device
*dev
)
75 struct omapflash_info
*info
;
76 struct platform_device
*pdev
= to_platform_device(dev
);
77 struct flash_platform_data
*pdata
= pdev
->dev
.platform_data
;
78 struct resource
*res
= pdev
->resource
;
79 unsigned long size
= res
->end
- res
->start
+ 1;
81 info
= kmalloc(sizeof(struct omapflash_info
), GFP_KERNEL
);
85 memset(info
, 0, sizeof(struct omapflash_info
));
87 if (!request_mem_region(res
->start
, size
, "flash")) {
92 info
->map
.virt
= ioremap(res
->start
, size
);
93 if (!info
->map
.virt
) {
95 goto out_release_mem_region
;
97 info
->map
.name
= pdev
->dev
.bus_id
;
98 info
->map
.phys
= res
->start
;
99 info
->map
.size
= size
;
100 info
->map
.bankwidth
= pdata
->width
;
101 info
->map
.set_vpp
= omap_set_vpp
;
103 simple_map_init(&info
->map
);
104 info
->mtd
= do_map_probe(pdata
->map_name
, &info
->map
);
109 info
->mtd
->owner
= THIS_MODULE
;
111 #ifdef CONFIG_MTD_PARTITIONS
112 err
= parse_mtd_partitions(info
->mtd
, part_probes
, &info
->parts
, 0);
114 add_mtd_partitions(info
->mtd
, info
->parts
, err
);
115 else if (err
< 0 && pdata
->parts
)
116 add_mtd_partitions(info
->mtd
, pdata
->parts
, pdata
->nr_parts
);
119 add_mtd_device(info
->mtd
);
121 dev_set_drvdata(&pdev
->dev
, info
);
126 iounmap(info
->map
.virt
);
127 out_release_mem_region
:
128 release_mem_region(res
->start
, size
);
135 static int __devexit
omapflash_remove(struct device
*dev
)
137 struct platform_device
*pdev
= to_platform_device(dev
);
138 struct omapflash_info
*info
= dev_get_drvdata(&pdev
->dev
);
140 dev_set_drvdata(&pdev
->dev
, NULL
);
144 del_mtd_partitions(info
->mtd
);
147 del_mtd_device(info
->mtd
);
148 map_destroy(info
->mtd
);
149 release_mem_region(info
->map
.phys
, info
->map
.size
);
150 iounmap((void __iomem
*) info
->map
.virt
);
157 static struct device_driver omapflash_driver
= {
159 .bus
= &platform_bus_type
,
160 .probe
= omapflash_probe
,
161 .remove
= __devexit_p(omapflash_remove
),
164 static int __init
omapflash_init(void)
166 return driver_register(&omapflash_driver
);
169 static void __exit
omapflash_exit(void)
171 driver_unregister(&omapflash_driver
);
174 module_init(omapflash_init
);
175 module_exit(omapflash_exit
);
177 MODULE_LICENSE("GPL");
178 MODULE_DESCRIPTION("MTD NOR map driver for TI OMAP boards");