2009-03-04 12:01:34 -08:00
/*
* rbtx4939 - flash ( based on physmap . c )
*
* This is a simplified physmap driver with map_init callback function .
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation .
*
* Copyright ( C ) 2009 Atsushi Nemoto < anemo @ mba . ocn . ne . jp >
*/
# include <linux/module.h>
# include <linux/types.h>
# include <linux/kernel.h>
# include <linux/slab.h>
# include <linux/device.h>
# include <linux/platform_device.h>
# include <linux/mtd/mtd.h>
# include <linux/mtd/map.h>
# include <linux/mtd/partitions.h>
# include <asm/txx9/rbtx4939.h>
struct rbtx4939_flash_info {
struct mtd_info * mtd ;
struct map_info map ;
} ;
static int rbtx4939_flash_remove ( struct platform_device * dev )
{
struct rbtx4939_flash_info * info ;
info = platform_get_drvdata ( dev ) ;
if ( ! info )
return 0 ;
if ( info - > mtd ) {
2011-05-23 10:23:08 +01:00
mtd_device_unregister ( info - > mtd ) ;
2009-03-04 12:01:34 -08:00
map_destroy ( info - > mtd ) ;
}
return 0 ;
}
2013-03-12 10:46:37 +02:00
static const char * const rom_probe_types [ ] = {
" cfi_probe " , " jedec_probe " , NULL } ;
2009-03-04 12:01:34 -08:00
static int rbtx4939_flash_probe ( struct platform_device * dev )
{
struct rbtx4939_flash_data * pdata ;
struct rbtx4939_flash_info * info ;
struct resource * res ;
2013-03-12 10:46:37 +02:00
const char * const * probe_type ;
2009-03-04 12:01:34 -08:00
int err = 0 ;
unsigned long size ;
2013-07-30 17:18:06 +09:00
pdata = dev_get_platdata ( & dev - > dev ) ;
2009-03-04 12:01:34 -08:00
if ( ! pdata )
return - ENODEV ;
res = platform_get_resource ( dev , IORESOURCE_MEM , 0 ) ;
if ( ! res )
return - ENODEV ;
info = devm_kzalloc ( & dev - > dev , sizeof ( struct rbtx4939_flash_info ) ,
GFP_KERNEL ) ;
if ( ! info )
return - ENOMEM ;
platform_set_drvdata ( dev , info ) ;
size = resource_size ( res ) ;
pr_notice ( " rbtx4939 platform flash device: %pR \n " , res ) ;
if ( ! devm_request_mem_region ( & dev - > dev , res - > start , size ,
dev_name ( & dev - > dev ) ) )
return - EBUSY ;
info - > map . name = dev_name ( & dev - > dev ) ;
info - > map . phys = res - > start ;
info - > map . size = size ;
info - > map . bankwidth = pdata - > width ;
info - > map . virt = devm_ioremap ( & dev - > dev , info - > map . phys , size ) ;
if ( ! info - > map . virt )
return - EBUSY ;
if ( pdata - > map_init )
( * pdata - > map_init ) ( & info - > map ) ;
else
simple_map_init ( & info - > map ) ;
probe_type = rom_probe_types ;
for ( ; ! info - > mtd & & * probe_type ; probe_type + + )
info - > mtd = do_map_probe ( * probe_type , & info - > map ) ;
if ( ! info - > mtd ) {
dev_err ( & dev - > dev , " map_probe failed \n " ) ;
err = - ENXIO ;
goto err_out ;
}
2015-06-10 22:38:34 +02:00
info - > mtd . dev . parent = & dev - > dev ;
mtd: do not use plain 0 as NULL
The first 3 arguments of 'mtd_device_parse_register()' are pointers,
but many callers pass '0' instead of 'NULL'. Fix this globally. Thanks
to coccinelle for making it easy to do with the following semantic patch:
@@
expression mtd, types, parser_data, parts, nr_parts;
@@
(
-mtd_device_parse_register(mtd, 0, parser_data, parts, nr_parts)
+mtd_device_parse_register(mtd, NULL, parser_data, parts, nr_parts)
|
-mtd_device_parse_register(mtd, types, 0, parts, nr_parts)
+mtd_device_parse_register(mtd, types, NULL, parts, nr_parts)
|
-mtd_device_parse_register(mtd, types, parser_data, 0, nr_parts)
+mtd_device_parse_register(mtd, types, parser_data, NULL, nr_parts)
)
Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
2012-03-09 19:24:26 +02:00
err = mtd_device_parse_register ( info - > mtd , NULL , NULL , pdata - > parts ,
pdata - > nr_parts ) ;
2009-03-04 12:01:34 -08:00
2011-06-02 18:00:04 +04:00
if ( err )
goto err_out ;
2009-03-04 12:01:34 -08:00
return 0 ;
err_out :
rbtx4939_flash_remove ( dev ) ;
return err ;
}
# ifdef CONFIG_PM
static void rbtx4939_flash_shutdown ( struct platform_device * dev )
{
struct rbtx4939_flash_info * info = platform_get_drvdata ( dev ) ;
2011-12-30 17:15:59 +02:00
if ( mtd_suspend ( info - > mtd ) = = 0 )
mtd_resume ( info - > mtd ) ;
2009-03-04 12:01:34 -08:00
}
# else
# define rbtx4939_flash_shutdown NULL
# endif
static struct platform_driver rbtx4939_flash_driver = {
. probe = rbtx4939_flash_probe ,
. remove = rbtx4939_flash_remove ,
. shutdown = rbtx4939_flash_shutdown ,
. driver = {
. name = " rbtx4939-flash " ,
} ,
} ;
2011-11-27 20:45:03 +08:00
module_platform_driver ( rbtx4939_flash_driver ) ;
2009-03-04 12:01:34 -08:00
MODULE_LICENSE ( " GPL " ) ;
MODULE_DESCRIPTION ( " RBTX4939 MTD map driver " ) ;
MODULE_ALIAS ( " platform:rbtx4939-flash " ) ;