2005-04-16 15:20:36 -07:00
/*
2006-10-03 23:01:26 +02:00
* drivers / mtd / maps / dmv182 . c
2005-11-07 11:15:40 +00:00
*
2005-04-16 15:20:36 -07:00
* Flash map driver for the Dy4 SVME182 board
2005-11-07 11:15:40 +00:00
*
* $ Id : dmv182 . c , v 1.6 2005 / 11 / 07 11 : 14 : 26 gleixner Exp $
2005-04-16 15:20:36 -07:00
*
* Copyright 2003 - 2004 , TimeSys Corporation
*
* Based on the SVME181 flash map , by Tom Nelson , Dot4 , Inc . for TimeSys Corp .
*
* This program is free software ; you can redistribute it and / or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation ; either version 2 of the License , or ( at your
* option ) any later version .
*/
# include <linux/module.h>
# include <linux/init.h>
# include <linux/types.h>
# include <linux/kernel.h>
# include <asm/io.h>
# include <linux/mtd/mtd.h>
# include <linux/mtd/map.h>
# include <linux/mtd/partitions.h>
# include <linux/errno.h>
/*
* This driver currently handles only the 16 MiB user flash bank 1 on the
* board . It does not provide access to bank 0 ( contains the Dy4 FFW ) , bank 2
* ( VxWorks boot ) , or the optional 48 MiB expansion flash .
*
* scott . wood @ timesys . com : On the newer boards with 128 MiB flash , it
* now supports the first 96 MiB ( the boot flash bank containing FFW
* is excluded ) . The VxWorks loader is in partition 1.
*/
# define FLASH_BASE_ADDR 0xf0000000
# define FLASH_BANK_SIZE (128*1024*1024)
MODULE_AUTHOR ( " Scott Wood, TimeSys Corporation <scott.wood@timesys.com> " ) ;
MODULE_DESCRIPTION ( " User-programmable flash device on the Dy4 SVME182 board " ) ;
MODULE_LICENSE ( " GPL " ) ;
static struct map_info svme182_map = {
. name = " Dy4 SVME182 " ,
. bankwidth = 32 ,
. size = 128 * 1024 * 1024
} ;
# define BOOTIMAGE_PART_SIZE ((6*1024*1024)-RESERVED_PART_SIZE)
// Allow 6MiB for the kernel
# define NEW_BOOTIMAGE_PART_SIZE (6 * 1024 * 1024)
// Allow 1MiB for the bootloader
# define NEW_BOOTLOADER_PART_SIZE (1024 * 1024)
// Use the remaining 9MiB at the end of flash for the RFS
# define NEW_RFS_PART_SIZE (0x01000000 - NEW_BOOTLOADER_PART_SIZE - \
NEW_BOOTIMAGE_PART_SIZE )
static struct mtd_partition svme182_partitions [ ] = {
// The Lower PABS is only 128KiB, but the partition code doesn't
// like partitions that don't end on the largest erase block
// size of the device, even if all of the erase blocks in the
// partition are small ones. The hardware should prevent
// writes to the actual PABS areas.
{
name : " Lower PABS and CPU 0 bootloader or kernel " ,
size : 6 * 1024 * 1024 ,
offset : 0 ,
} ,
{
name : " Root Filesystem " ,
size : 10 * 1024 * 1024 ,
offset : MTDPART_OFS_NXTBLK
} ,
{
name : " CPU1 Bootloader " ,
size : 1024 * 1024 ,
offset : MTDPART_OFS_NXTBLK ,
} ,
{
name : " Extra " ,
size : 110 * 1024 * 1024 ,
offset : MTDPART_OFS_NXTBLK
} ,
{
name : " Foundation Firmware and Upper PABS " ,
size : 1024 * 1024 ,
offset : MTDPART_OFS_NXTBLK ,
mask_flags : MTD_WRITEABLE // read-only
}
} ;
static struct mtd_info * this_mtd ;
static int __init init_svme182 ( void )
{
struct mtd_partition * partitions ;
2006-03-31 02:29:45 -08:00
int num_parts = ARRAY_SIZE ( svme182_partitions ) ;
2005-04-16 15:20:36 -07:00
partitions = svme182_partitions ;
svme182_map . virt = ioremap ( FLASH_BASE_ADDR , svme182_map . size ) ;
2005-11-07 11:15:40 +00:00
2005-04-16 15:20:36 -07:00
if ( svme182_map . virt = = 0 ) {
printk ( " Failed to ioremap FLASH memory area. \n " ) ;
return - EIO ;
}
simple_map_init ( & svme182_map ) ;
this_mtd = do_map_probe ( " cfi_probe " , & svme182_map ) ;
if ( ! this_mtd )
{
iounmap ( ( void * ) svme182_map . virt ) ;
return - ENXIO ;
}
printk ( KERN_NOTICE " SVME182 flash device: %dMiB at 0x%08x \n " ,
this_mtd - > size > > 20 , FLASH_BASE_ADDR ) ;
this_mtd - > owner = THIS_MODULE ;
add_mtd_partitions ( this_mtd , partitions , num_parts ) ;
return 0 ;
}
static void __exit cleanup_svme182 ( void )
{
if ( this_mtd )
{
del_mtd_partitions ( this_mtd ) ;
map_destroy ( this_mtd ) ;
}
if ( svme182_map . virt )
{
iounmap ( ( void * ) svme182_map . virt ) ;
svme182_map . virt = 0 ;
}
return ;
}
module_init ( init_svme182 ) ;
module_exit ( cleanup_svme182 ) ;