2019-05-23 11:14:39 +02:00
// SPDX-License-Identifier: GPL-2.0-or-later
2005-04-16 15:20:36 -07:00
/*
* Simple read - only ( writable only for RAM ) mtdblock driver
2010-08-08 20:58:20 +01:00
*
* Copyright © 2001 - 2010 David Woodhouse < dwmw2 @ infradead . org >
2005-04-16 15:20:36 -07:00
*/
# include <linux/init.h>
# include <linux/slab.h>
# include <linux/mtd/mtd.h>
# include <linux/mtd/blktrans.h>
2011-07-03 15:17:31 -04:00
# include <linux/module.h>
2013-10-13 18:05:23 -03:00
# include <linux/major.h>
2005-04-16 15:20:36 -07:00
static int mtdblock_readsect ( struct mtd_blktrans_dev * dev ,
unsigned long block , char * buf )
{
size_t retlen ;
2011-12-23 17:30:16 +02:00
if ( mtd_read ( dev - > mtd , ( block * 512 ) , 512 , & retlen , buf ) )
2005-04-16 15:20:36 -07:00
return 1 ;
return 0 ;
}
static int mtdblock_writesect ( struct mtd_blktrans_dev * dev ,
unsigned long block , char * buf )
{
size_t retlen ;
2011-12-23 17:35:41 +02:00
if ( mtd_write ( dev - > mtd , ( block * 512 ) , 512 , & retlen , buf ) )
2005-04-16 15:20:36 -07:00
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
2010-02-22 20:39:31 +02:00
if ( add_mtd_blktrans_dev ( dev ) )
kfree ( dev ) ;
2005-04-16 15:20:36 -07:00
}
static void mtdblock_remove_dev ( struct mtd_blktrans_dev * dev )
{
del_mtd_blktrans_dev ( dev ) ;
}
static struct mtd_blktrans_ops mtdblock_tr = {
. name = " mtdblock " ,
2013-10-08 20:59:08 -03:00
. major = MTD_BLOCK_MAJOR ,
2005-04-16 15:20:36 -07:00
. 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 " ) ;