2005-04-16 15:20:36 -07:00
/*
* ( C ) 2003 David Woodhouse < dwmw2 @ infradead . org >
*
* Simple read - only ( writable only for RAM ) mtdblock driver
*/
# include <linux/init.h>
# include <linux/slab.h>
# include <linux/mtd/mtd.h>
# include <linux/mtd/blktrans.h>
static int mtdblock_readsect ( struct mtd_blktrans_dev * dev ,
unsigned long block , char * buf )
{
size_t retlen ;
if ( dev - > mtd - > read ( dev - > mtd , ( block * 512 ) , 512 , & retlen , buf ) )
return 1 ;
return 0 ;
}
static int mtdblock_writesect ( struct mtd_blktrans_dev * dev ,
unsigned long block , char * buf )
{
size_t retlen ;
if ( dev - > mtd - > write ( dev - > mtd , ( block * 512 ) , 512 , & retlen , buf ) )
return 1 ;
return 0 ;
}
static void mtdblock_add_mtd ( struct mtd_blktrans_ops * tr , struct mtd_info * mtd )
{
2006-11-15 21:10:29 +02:00
struct mtd_blktrans_dev * dev = kzalloc ( sizeof ( * dev ) , GFP_KERNEL ) ;
2005-04-16 15:20:36 -07:00
if ( ! dev )
return ;
dev - > mtd = mtd ;
dev - > devnum = mtd - > index ;
2006-10-27 09:09:33 +01:00
2005-04-16 15:20:36 -07:00
dev - > size = mtd - > size > > 9 ;
dev - > tr = tr ;
2006-04-13 18:53:55 +02:00
dev - > readonly = 1 ;
2005-04-16 15:20:36 -07:00
add_mtd_blktrans_dev ( dev ) ;
}
static void mtdblock_remove_dev ( struct mtd_blktrans_dev * dev )
{
del_mtd_blktrans_dev ( dev ) ;
kfree ( dev ) ;
}
static struct mtd_blktrans_ops mtdblock_tr = {
. name = " mtdblock " ,
. major = 31 ,
. part_bits = 0 ,
2006-10-27 09:09:33 +01:00
. blksize = 512 ,
2005-04-16 15:20:36 -07:00
. readsect = mtdblock_readsect ,
. writesect = mtdblock_writesect ,
. add_mtd = mtdblock_add_mtd ,
. remove_dev = mtdblock_remove_dev ,
. owner = THIS_MODULE ,
} ;
static int __init mtdblock_init ( void )
{
return register_mtd_blktrans ( & mtdblock_tr ) ;
}
static void __exit mtdblock_exit ( void )
{
deregister_mtd_blktrans ( & mtdblock_tr ) ;
}
module_init ( mtdblock_init ) ;
module_exit ( mtdblock_exit ) ;
MODULE_LICENSE ( " GPL " ) ;
MODULE_AUTHOR ( " David Woodhouse <dwmw2@infradead.org> " ) ;
MODULE_DESCRIPTION ( " Simple read-only block device emulation access to MTD devices " ) ;