2008-09-09 12:19:40 +04:00
/*
* Copyright 2008 Sascha Hauer , kernel @ pengutronix . de
*
* 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 .
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 51 Franklin Street , Fifth Floor ,
* Boston , MA 02110 - 1301 , USA .
*/
# include <linux/kernel.h>
2010-11-02 13:56:54 +03:00
# include <linux/slab.h>
2008-09-09 12:19:40 +04:00
# include <linux/init.h>
2010-06-15 13:31:02 +04:00
# include <linux/err.h>
2008-09-09 12:19:40 +04:00
# include <linux/platform_device.h>
2009-01-26 18:34:51 +03:00
# include <mach/common.h>
2008-09-09 12:19:40 +04:00
int __init mxc_register_device ( struct platform_device * pdev , void * data )
{
int ret ;
pdev - > dev . platform_data = data ;
ret = platform_device_register ( pdev ) ;
if ( ret )
pr_debug ( " Unable to register platform device '%s': %d \n " ,
pdev - > name , ret ) ;
return ret ;
}
2010-11-02 13:56:54 +03:00
struct platform_device * __init imx_add_platform_device_dmamask (
const char * name , int id ,
2010-06-15 13:31:02 +04:00
const struct resource * res , unsigned int num_resources ,
2010-11-02 13:56:54 +03:00
const void * data , size_t size_data , u64 dmamask )
2010-06-15 13:31:02 +04:00
{
int ret = - ENOMEM ;
struct platform_device * pdev ;
pdev = platform_device_alloc ( name , id ) ;
if ( ! pdev )
goto err ;
2010-11-02 13:56:54 +03:00
if ( dmamask ) {
/*
* This memory isn ' t freed when the device is put ,
* I don ' t have a nice idea for that though . Conceptually
* dma_mask in struct device should not be a pointer .
* See http : //thread.gmane.org/gmane.linux.kernel.pci/9081
*/
pdev - > dev . dma_mask =
kmalloc ( sizeof ( * pdev - > dev . dma_mask ) , GFP_KERNEL ) ;
if ( ! pdev - > dev . dma_mask )
/* ret is still -ENOMEM; */
goto err ;
* pdev - > dev . dma_mask = dmamask ;
pdev - > dev . coherent_dma_mask = dmamask ;
}
2010-06-15 13:31:02 +04:00
if ( res ) {
ret = platform_device_add_resources ( pdev , res , num_resources ) ;
if ( ret )
goto err ;
}
if ( data ) {
ret = platform_device_add_data ( pdev , data , size_data ) ;
if ( ret )
goto err ;
}
ret = platform_device_add ( pdev ) ;
if ( ret ) {
err :
2011-02-18 23:59:25 +03:00
if ( dmamask )
kfree ( pdev - > dev . dma_mask ) ;
2010-06-15 13:31:02 +04:00
platform_device_put ( pdev ) ;
return ERR_PTR ( ret ) ;
}
return pdev ;
}
2011-06-05 20:07:55 +04:00
struct device mxc_aips_bus = {
. init_name = " mxc_aips " ,
. parent = & platform_bus ,
} ;
2011-06-22 18:41:30 +04:00
struct device mxc_ahb_bus = {
. init_name = " mxc_ahb " ,
. parent = & platform_bus ,
} ;
2011-06-05 20:07:55 +04:00
static int __init mxc_device_init ( void )
{
2011-06-22 18:41:30 +04:00
int ret ;
ret = device_register ( & mxc_aips_bus ) ;
if ( IS_ERR_VALUE ( ret ) )
goto done ;
ret = device_register ( & mxc_ahb_bus ) ;
done :
return ret ;
2011-06-05 20:07:55 +04:00
}
core_initcall ( mxc_device_init ) ;