2006-12-07 15:43:59 -08:00
/*
2009-03-23 18:07:23 -07:00
* Mailbox reservation modules for OMAP2 / 3
2006-12-07 15:43:59 -08:00
*
2009-03-23 18:07:23 -07:00
* Copyright ( C ) 2006 - 2009 Nokia Corporation
2006-12-07 15:43:59 -08:00
* Written by : Hiroshi DOYU < Hiroshi . DOYU @ nokia . com >
2009-03-23 18:07:23 -07:00
* and Paul Mundt
2006-12-07 15:43:59 -08:00
*
* This file is subject to the terms and conditions of the GNU General Public
* License . See the file " COPYING " in the main directory of this archive
* for more details .
*/
# include <linux/kernel.h>
# include <linux/clk.h>
# include <linux/err.h>
# include <linux/platform_device.h>
2008-09-06 12:10:45 +01:00
# include <linux/io.h>
2009-10-20 09:40:47 -07:00
# include <plat/mailbox.h>
2008-08-05 16:14:15 +01:00
# include <mach/irqs.h>
2006-12-07 15:43:59 -08:00
2009-11-22 10:11:22 -08:00
# define DRV_NAME "omap2-mailbox"
2009-03-23 18:07:23 -07:00
# define MAILBOX_REVISION 0x000
# define MAILBOX_SYSCONFIG 0x010
# define MAILBOX_SYSSTATUS 0x014
# define MAILBOX_MESSAGE(m) (0x040 + 4 * (m))
# define MAILBOX_FIFOSTATUS(m) (0x080 + 4 * (m))
# define MAILBOX_MSGSTATUS(m) (0x0c0 + 4 * (m))
# define MAILBOX_IRQSTATUS(u) (0x100 + 8 * (u))
# define MAILBOX_IRQENABLE(u) (0x104 + 8 * (u))
2006-12-07 15:43:59 -08:00
2009-11-22 10:11:22 -08:00
# define OMAP4_MAILBOX_IRQSTATUS(u) (0x104 + 10 * (u))
# define OMAP4_MAILBOX_IRQENABLE(u) (0x108 + 10 * (u))
# define OMAP4_MAILBOX_IRQENABLE_CLR(u) (0x10c + 10 * (u))
# define MAILBOX_IRQ_NEWMSG(m) (1 << (2 * (m)))
# define MAILBOX_IRQ_NOTFULL(m) (1 << (2 * (m) + 1))
2006-12-07 15:43:59 -08:00
2009-09-24 16:23:09 -07:00
/* SYSCONFIG: register bit definition */
# define AUTOIDLE (1 << 0)
# define SOFTRESET (1 << 1)
# define SMARTIDLE (2 << 3)
2010-01-26 16:55:29 -06:00
# define OMAP4_SOFTRESET (1 << 0)
2010-02-05 17:20:26 -06:00
# define OMAP4_NOIDLE (1 << 2)
# define OMAP4_SMARTIDLE (2 << 2)
2009-09-24 16:23:09 -07:00
/* SYSSTATUS: register bit definition */
# define RESETDONE (1 << 0)
2009-03-23 18:07:26 -07:00
# define MBOX_REG_SIZE 0x120
2009-11-22 10:11:22 -08:00
# define OMAP4_MBOX_REG_SIZE 0x130
2009-03-23 18:07:26 -07:00
# define MBOX_NR_REGS (MBOX_REG_SIZE / sizeof(u32))
2009-11-22 10:11:22 -08:00
# define OMAP4_MBOX_NR_REGS (OMAP4_MBOX_REG_SIZE / sizeof(u32))
2009-03-23 18:07:26 -07:00
2009-03-23 18:07:23 -07:00
static void __iomem * mbox_base ;
2006-12-07 15:43:59 -08:00
struct omap_mbox2_fifo {
unsigned long msg ;
unsigned long fifo_stat ;
unsigned long msg_stat ;
} ;
struct omap_mbox2_priv {
struct omap_mbox2_fifo tx_fifo ;
struct omap_mbox2_fifo rx_fifo ;
unsigned long irqenable ;
unsigned long irqstatus ;
u32 newmsg_bit ;
u32 notfull_bit ;
2009-11-22 10:11:22 -08:00
u32 ctx [ OMAP4_MBOX_NR_REGS ] ;
unsigned long irqdisable ;
2006-12-07 15:43:59 -08:00
} ;
static struct clk * mbox_ick_handle ;
2007-07-30 14:04:04 +03:00
static void omap2_mbox_enable_irq ( struct omap_mbox * mbox ,
omap_mbox_type_t irq ) ;
2009-03-23 18:07:23 -07:00
static inline unsigned int mbox_read_reg ( size_t ofs )
2006-12-07 15:43:59 -08:00
{
2009-03-23 18:07:23 -07:00
return __raw_readl ( mbox_base + ofs ) ;
2006-12-07 15:43:59 -08:00
}
2009-03-23 18:07:23 -07:00
static inline void mbox_write_reg ( u32 val , size_t ofs )
2006-12-07 15:43:59 -08:00
{
2009-03-23 18:07:23 -07:00
__raw_writel ( val , mbox_base + ofs ) ;
2006-12-07 15:43:59 -08:00
}
/* Mailbox H/W preparations */
2007-07-30 14:04:04 +03:00
static int omap2_mbox_startup ( struct omap_mbox * mbox )
2006-12-07 15:43:59 -08:00
{
2009-09-24 16:23:09 -07:00
u32 l ;
unsigned long timeout ;
2006-12-07 15:43:59 -08:00
mbox_ick_handle = clk_get ( NULL , " mailboxes_ick " ) ;
if ( IS_ERR ( mbox_ick_handle ) ) {
2010-02-15 10:03:33 -08:00
printk ( KERN_ERR " Could not get mailboxes_ick: %ld \n " ,
2009-11-22 10:11:22 -08:00
PTR_ERR ( mbox_ick_handle ) ) ;
return PTR_ERR ( mbox_ick_handle ) ;
2006-12-07 15:43:59 -08:00
}
clk_enable ( mbox_ick_handle ) ;
2010-01-26 16:55:29 -06:00
if ( cpu_is_omap44xx ( ) ) {
mbox_write_reg ( OMAP4_SOFTRESET , MAILBOX_SYSCONFIG ) ;
timeout = jiffies + msecs_to_jiffies ( 20 ) ;
do {
l = mbox_read_reg ( MAILBOX_SYSCONFIG ) ;
if ( ! ( l & OMAP4_SOFTRESET ) )
break ;
} while ( ! time_after ( jiffies , timeout ) ) ;
if ( l & OMAP4_SOFTRESET ) {
pr_err ( " Can't take mailbox out of reset \n " ) ;
return - ENODEV ;
}
} else {
mbox_write_reg ( SOFTRESET , MAILBOX_SYSCONFIG ) ;
timeout = jiffies + msecs_to_jiffies ( 20 ) ;
do {
l = mbox_read_reg ( MAILBOX_SYSSTATUS ) ;
if ( l & RESETDONE )
break ;
} while ( ! time_after ( jiffies , timeout ) ) ;
if ( ! ( l & RESETDONE ) ) {
pr_err ( " Can't take mailbox out of reset \n " ) ;
return - ENODEV ;
}
2009-09-24 16:23:09 -07:00
}
2009-03-23 18:07:24 -07:00
l = mbox_read_reg ( MAILBOX_REVISION ) ;
2010-06-11 15:51:37 +00:00
pr_debug ( " omap mailbox rev %d.%d \n " , ( l & 0xf0 ) > > 4 , ( l & 0x0f ) ) ;
2009-03-23 18:07:24 -07:00
2010-02-05 17:20:26 -06:00
if ( cpu_is_omap44xx ( ) )
l = OMAP4_SMARTIDLE ;
else
l = SMARTIDLE | AUTOIDLE ;
2006-12-07 15:43:59 -08:00
mbox_write_reg ( l , MAILBOX_SYSCONFIG ) ;
2007-07-30 14:04:04 +03:00
omap2_mbox_enable_irq ( mbox , IRQ_RX ) ;
2006-12-07 15:43:59 -08:00
return 0 ;
}
2007-07-30 14:04:04 +03:00
static void omap2_mbox_shutdown ( struct omap_mbox * mbox )
2006-12-07 15:43:59 -08:00
{
clk_disable ( mbox_ick_handle ) ;
clk_put ( mbox_ick_handle ) ;
2009-11-22 10:11:22 -08:00
mbox_ick_handle = NULL ;
2006-12-07 15:43:59 -08:00
}
/* Mailbox FIFO handle functions */
2007-07-30 14:04:04 +03:00
static mbox_msg_t omap2_mbox_fifo_read ( struct omap_mbox * mbox )
2006-12-07 15:43:59 -08:00
{
struct omap_mbox2_fifo * fifo =
& ( ( struct omap_mbox2_priv * ) mbox - > priv ) - > rx_fifo ;
return ( mbox_msg_t ) mbox_read_reg ( fifo - > msg ) ;
}
2007-07-30 14:04:04 +03:00
static void omap2_mbox_fifo_write ( struct omap_mbox * mbox , mbox_msg_t msg )
2006-12-07 15:43:59 -08:00
{
struct omap_mbox2_fifo * fifo =
& ( ( struct omap_mbox2_priv * ) mbox - > priv ) - > tx_fifo ;
mbox_write_reg ( msg , fifo - > msg ) ;
}
2007-07-30 14:04:04 +03:00
static int omap2_mbox_fifo_empty ( struct omap_mbox * mbox )
2006-12-07 15:43:59 -08:00
{
struct omap_mbox2_fifo * fifo =
& ( ( struct omap_mbox2_priv * ) mbox - > priv ) - > rx_fifo ;
return ( mbox_read_reg ( fifo - > msg_stat ) = = 0 ) ;
}
2007-07-30 14:04:04 +03:00
static int omap2_mbox_fifo_full ( struct omap_mbox * mbox )
2006-12-07 15:43:59 -08:00
{
struct omap_mbox2_fifo * fifo =
& ( ( struct omap_mbox2_priv * ) mbox - > priv ) - > tx_fifo ;
2009-11-22 10:11:22 -08:00
return mbox_read_reg ( fifo - > fifo_stat ) ;
2006-12-07 15:43:59 -08:00
}
/* Mailbox IRQ handle functions */
2007-07-30 14:04:04 +03:00
static void omap2_mbox_enable_irq ( struct omap_mbox * mbox ,
2006-12-07 15:43:59 -08:00
omap_mbox_type_t irq )
{
struct omap_mbox2_priv * p = ( struct omap_mbox2_priv * ) mbox - > priv ;
u32 l , bit = ( irq = = IRQ_TX ) ? p - > notfull_bit : p - > newmsg_bit ;
l = mbox_read_reg ( p - > irqenable ) ;
l | = bit ;
mbox_write_reg ( l , p - > irqenable ) ;
}
2007-07-30 14:04:04 +03:00
static void omap2_mbox_disable_irq ( struct omap_mbox * mbox ,
2006-12-07 15:43:59 -08:00
omap_mbox_type_t irq )
{
struct omap_mbox2_priv * p = ( struct omap_mbox2_priv * ) mbox - > priv ;
u32 l , bit = ( irq = = IRQ_TX ) ? p - > notfull_bit : p - > newmsg_bit ;
2009-11-22 10:11:22 -08:00
l = mbox_read_reg ( p - > irqdisable ) ;
2006-12-07 15:43:59 -08:00
l & = ~ bit ;
2009-11-22 10:11:22 -08:00
mbox_write_reg ( l , p - > irqdisable ) ;
2006-12-07 15:43:59 -08:00
}
2007-07-30 14:04:04 +03:00
static void omap2_mbox_ack_irq ( struct omap_mbox * mbox ,
2006-12-07 15:43:59 -08:00
omap_mbox_type_t irq )
{
struct omap_mbox2_priv * p = ( struct omap_mbox2_priv * ) mbox - > priv ;
u32 bit = ( irq = = IRQ_TX ) ? p - > notfull_bit : p - > newmsg_bit ;
mbox_write_reg ( bit , p - > irqstatus ) ;
2009-09-24 16:23:10 -07:00
/* Flush posted write for irq status to avoid spurious interrupts */
mbox_read_reg ( p - > irqstatus ) ;
2006-12-07 15:43:59 -08:00
}
2007-07-30 14:04:04 +03:00
static int omap2_mbox_is_irq ( struct omap_mbox * mbox ,
2006-12-07 15:43:59 -08:00
omap_mbox_type_t irq )
{
struct omap_mbox2_priv * p = ( struct omap_mbox2_priv * ) mbox - > priv ;
u32 bit = ( irq = = IRQ_TX ) ? p - > notfull_bit : p - > newmsg_bit ;
u32 enable = mbox_read_reg ( p - > irqenable ) ;
u32 status = mbox_read_reg ( p - > irqstatus ) ;
2009-11-22 10:11:22 -08:00
return ( int ) ( enable & status & bit ) ;
2006-12-07 15:43:59 -08:00
}
2009-03-23 18:07:26 -07:00
static void omap2_mbox_save_ctx ( struct omap_mbox * mbox )
{
int i ;
struct omap_mbox2_priv * p = mbox - > priv ;
2009-11-22 10:11:22 -08:00
int nr_regs ;
if ( cpu_is_omap44xx ( ) )
nr_regs = OMAP4_MBOX_NR_REGS ;
else
nr_regs = MBOX_NR_REGS ;
for ( i = 0 ; i < nr_regs ; i + + ) {
2009-03-23 18:07:26 -07:00
p - > ctx [ i ] = mbox_read_reg ( i * sizeof ( u32 ) ) ;
dev_dbg ( mbox - > dev , " %s: [%02x] %08x \n " , __func__ ,
i , p - > ctx [ i ] ) ;
}
}
static void omap2_mbox_restore_ctx ( struct omap_mbox * mbox )
{
int i ;
struct omap_mbox2_priv * p = mbox - > priv ;
2009-11-22 10:11:22 -08:00
int nr_regs ;
if ( cpu_is_omap44xx ( ) )
nr_regs = OMAP4_MBOX_NR_REGS ;
else
nr_regs = MBOX_NR_REGS ;
for ( i = 0 ; i < nr_regs ; i + + ) {
2009-03-23 18:07:26 -07:00
mbox_write_reg ( p - > ctx [ i ] , i * sizeof ( u32 ) ) ;
dev_dbg ( mbox - > dev , " %s: [%02x] %08x \n " , __func__ ,
i , p - > ctx [ i ] ) ;
}
}
2006-12-07 15:43:59 -08:00
static struct omap_mbox_ops omap2_mbox_ops = {
. type = OMAP_MBOX_TYPE2 ,
. startup = omap2_mbox_startup ,
. shutdown = omap2_mbox_shutdown ,
. fifo_read = omap2_mbox_fifo_read ,
. fifo_write = omap2_mbox_fifo_write ,
. fifo_empty = omap2_mbox_fifo_empty ,
. fifo_full = omap2_mbox_fifo_full ,
. enable_irq = omap2_mbox_enable_irq ,
. disable_irq = omap2_mbox_disable_irq ,
. ack_irq = omap2_mbox_ack_irq ,
. is_irq = omap2_mbox_is_irq ,
2009-03-23 18:07:26 -07:00
. save_ctx = omap2_mbox_save_ctx ,
. restore_ctx = omap2_mbox_restore_ctx ,
2006-12-07 15:43:59 -08:00
} ;
/*
* MAILBOX 0 : ARM - > DSP ,
* MAILBOX 1 : ARM < - DSP .
* MAILBOX 2 : ARM - > IVA ,
* MAILBOX 3 : ARM < - IVA .
*/
/* FIXME: the following structs should be filled automatically by the user id */
/* DSP */
static struct omap_mbox2_priv omap2_mbox_dsp_priv = {
. tx_fifo = {
2009-03-23 18:07:23 -07:00
. msg = MAILBOX_MESSAGE ( 0 ) ,
. fifo_stat = MAILBOX_FIFOSTATUS ( 0 ) ,
2006-12-07 15:43:59 -08:00
} ,
. rx_fifo = {
2009-03-23 18:07:23 -07:00
. msg = MAILBOX_MESSAGE ( 1 ) ,
. msg_stat = MAILBOX_MSGSTATUS ( 1 ) ,
2006-12-07 15:43:59 -08:00
} ,
2009-03-23 18:07:23 -07:00
. irqenable = MAILBOX_IRQENABLE ( 0 ) ,
. irqstatus = MAILBOX_IRQSTATUS ( 0 ) ,
2006-12-07 15:43:59 -08:00
. notfull_bit = MAILBOX_IRQ_NOTFULL ( 0 ) ,
. newmsg_bit = MAILBOX_IRQ_NEWMSG ( 1 ) ,
2009-11-22 10:11:22 -08:00
. irqdisable = MAILBOX_IRQENABLE ( 0 ) ,
} ;
/* OMAP4 specific data structure. Use the cpu_is_omap4xxx()
to use this */
static struct omap_mbox2_priv omap2_mbox_1_priv = {
. tx_fifo = {
. msg = MAILBOX_MESSAGE ( 0 ) ,
. fifo_stat = MAILBOX_FIFOSTATUS ( 0 ) ,
} ,
. rx_fifo = {
. msg = MAILBOX_MESSAGE ( 1 ) ,
. msg_stat = MAILBOX_MSGSTATUS ( 1 ) ,
} ,
. irqenable = OMAP4_MAILBOX_IRQENABLE ( 0 ) ,
. irqstatus = OMAP4_MAILBOX_IRQSTATUS ( 0 ) ,
. notfull_bit = MAILBOX_IRQ_NOTFULL ( 0 ) ,
. newmsg_bit = MAILBOX_IRQ_NEWMSG ( 1 ) ,
. irqdisable = OMAP4_MAILBOX_IRQENABLE_CLR ( 0 ) ,
2006-12-07 15:43:59 -08:00
} ;
2009-11-22 10:11:22 -08:00
struct omap_mbox mbox_1_info = {
. name = " mailbox-1 " ,
. ops = & omap2_mbox_ops ,
. priv = & omap2_mbox_1_priv ,
} ;
EXPORT_SYMBOL ( mbox_1_info ) ;
2006-12-07 15:43:59 -08:00
struct omap_mbox mbox_dsp_info = {
. name = " dsp " ,
. ops = & omap2_mbox_ops ,
. priv = & omap2_mbox_dsp_priv ,
} ;
EXPORT_SYMBOL ( mbox_dsp_info ) ;
2009-11-22 10:11:22 -08:00
static struct omap_mbox2_priv omap2_mbox_2_priv = {
. tx_fifo = {
. msg = MAILBOX_MESSAGE ( 3 ) ,
. fifo_stat = MAILBOX_FIFOSTATUS ( 3 ) ,
} ,
. rx_fifo = {
. msg = MAILBOX_MESSAGE ( 2 ) ,
. msg_stat = MAILBOX_MSGSTATUS ( 2 ) ,
} ,
. irqenable = OMAP4_MAILBOX_IRQENABLE ( 0 ) ,
. irqstatus = OMAP4_MAILBOX_IRQSTATUS ( 0 ) ,
. notfull_bit = MAILBOX_IRQ_NOTFULL ( 3 ) ,
. newmsg_bit = MAILBOX_IRQ_NEWMSG ( 2 ) ,
. irqdisable = OMAP4_MAILBOX_IRQENABLE_CLR ( 0 ) ,
} ;
struct omap_mbox mbox_2_info = {
. name = " mailbox-2 " ,
. ops = & omap2_mbox_ops ,
. priv = & omap2_mbox_2_priv ,
} ;
EXPORT_SYMBOL ( mbox_2_info ) ;
2009-03-23 18:07:23 -07:00
# if defined(CONFIG_ARCH_OMAP2420) /* IVA */
2006-12-07 15:43:59 -08:00
static struct omap_mbox2_priv omap2_mbox_iva_priv = {
. tx_fifo = {
2009-03-23 18:07:23 -07:00
. msg = MAILBOX_MESSAGE ( 2 ) ,
. fifo_stat = MAILBOX_FIFOSTATUS ( 2 ) ,
2006-12-07 15:43:59 -08:00
} ,
. rx_fifo = {
2009-03-23 18:07:23 -07:00
. msg = MAILBOX_MESSAGE ( 3 ) ,
. msg_stat = MAILBOX_MSGSTATUS ( 3 ) ,
2006-12-07 15:43:59 -08:00
} ,
2009-03-23 18:07:23 -07:00
. irqenable = MAILBOX_IRQENABLE ( 3 ) ,
. irqstatus = MAILBOX_IRQSTATUS ( 3 ) ,
2006-12-07 15:43:59 -08:00
. notfull_bit = MAILBOX_IRQ_NOTFULL ( 2 ) ,
. newmsg_bit = MAILBOX_IRQ_NEWMSG ( 3 ) ,
2009-11-22 10:11:22 -08:00
. irqdisable = MAILBOX_IRQENABLE ( 3 ) ,
2006-12-07 15:43:59 -08:00
} ;
static struct omap_mbox mbox_iva_info = {
. name = " iva " ,
. ops = & omap2_mbox_ops ,
. priv = & omap2_mbox_iva_priv ,
} ;
2009-03-23 18:07:23 -07:00
# endif
2006-12-07 15:43:59 -08:00
2009-03-23 18:07:25 -07:00
static int __devinit omap2_mbox_probe ( struct platform_device * pdev )
2006-12-07 15:43:59 -08:00
{
struct resource * res ;
2009-03-23 18:07:23 -07:00
int ret ;
2006-12-07 15:43:59 -08:00
/* MBOX base */
res = platform_get_resource ( pdev , IORESOURCE_MEM , 0 ) ;
if ( unlikely ( ! res ) ) {
dev_err ( & pdev - > dev , " invalid mem resource \n " ) ;
return - ENODEV ;
}
2009-11-10 18:55:19 -08:00
mbox_base = ioremap ( res - > start , resource_size ( res ) ) ;
2009-03-23 18:07:23 -07:00
if ( ! mbox_base )
return - ENOMEM ;
2006-12-07 15:43:59 -08:00
2009-03-23 18:07:23 -07:00
/* DSP or IVA2 IRQ */
2009-11-22 10:11:22 -08:00
res = platform_get_resource ( pdev , IORESOURCE_IRQ , 0 ) ;
if ( unlikely ( ! res ) ) {
2006-12-07 15:43:59 -08:00
dev_err ( & pdev - > dev , " invalid irq resource \n " ) ;
2009-11-22 10:11:22 -08:00
ret = - ENODEV ;
2009-03-23 18:07:23 -07:00
goto err_dsp ;
2006-12-07 15:43:59 -08:00
}
2009-11-22 10:11:22 -08:00
if ( cpu_is_omap44xx ( ) ) {
mbox_1_info . irq = res - > start ;
ret = omap_mbox_register ( & pdev - > dev , & mbox_1_info ) ;
} else {
mbox_dsp_info . irq = res - > start ;
ret = omap_mbox_register ( & pdev - > dev , & mbox_dsp_info ) ;
}
2009-03-23 18:07:23 -07:00
if ( ret )
goto err_dsp ;
2009-11-22 10:11:22 -08:00
if ( cpu_is_omap44xx ( ) ) {
mbox_2_info . irq = res - > start ;
ret = omap_mbox_register ( & pdev - > dev , & mbox_2_info ) ;
if ( ret ) {
omap_mbox_unregister ( & mbox_1_info ) ;
goto err_dsp ;
}
}
2009-03-23 18:07:23 -07:00
# if defined(CONFIG_ARCH_OMAP2420) /* IVA */
if ( cpu_is_omap2420 ( ) ) {
/* IVA IRQ */
res = platform_get_resource ( pdev , IORESOURCE_IRQ , 1 ) ;
if ( unlikely ( ! res ) ) {
dev_err ( & pdev - > dev , " invalid irq resource \n " ) ;
ret = - ENODEV ;
2010-01-25 18:27:21 -06:00
omap_mbox_unregister ( & mbox_dsp_info ) ;
goto err_dsp ;
2009-03-23 18:07:23 -07:00
}
mbox_iva_info . irq = res - > start ;
2009-03-23 18:07:25 -07:00
ret = omap_mbox_register ( & pdev - > dev , & mbox_iva_info ) ;
2010-01-25 18:27:21 -06:00
if ( ret ) {
omap_mbox_unregister ( & mbox_dsp_info ) ;
goto err_dsp ;
}
2006-12-07 15:43:59 -08:00
}
2009-03-23 18:07:23 -07:00
# endif
return 0 ;
2006-12-07 15:43:59 -08:00
2010-06-11 15:51:37 +00:00
# if defined(CONFIG_ARCH_OMAP2420) /* IVA */
err_iva1 :
omap_mbox_unregister ( & mbox_dsp_info ) ;
# endif
2009-03-23 18:07:23 -07:00
err_dsp :
iounmap ( mbox_base ) ;
2006-12-07 15:43:59 -08:00
return ret ;
}
2009-03-23 18:07:25 -07:00
static int __devexit omap2_mbox_remove ( struct platform_device * pdev )
2006-12-07 15:43:59 -08:00
{
2009-03-23 18:07:23 -07:00
# if defined(CONFIG_ARCH_OMAP2420)
omap_mbox_unregister ( & mbox_iva_info ) ;
# endif
2009-11-22 10:11:22 -08:00
if ( cpu_is_omap44xx ( ) ) {
omap_mbox_unregister ( & mbox_2_info ) ;
omap_mbox_unregister ( & mbox_1_info ) ;
} else
omap_mbox_unregister ( & mbox_dsp_info ) ;
2009-03-23 18:07:23 -07:00
iounmap ( mbox_base ) ;
2006-12-07 15:43:59 -08:00
return 0 ;
}
static struct platform_driver omap2_mbox_driver = {
. probe = omap2_mbox_probe ,
2009-03-23 18:07:25 -07:00
. remove = __devexit_p ( omap2_mbox_remove ) ,
2006-12-07 15:43:59 -08:00
. driver = {
2009-11-22 10:11:22 -08:00
. name = DRV_NAME ,
2006-12-07 15:43:59 -08:00
} ,
} ;
static int __init omap2_mbox_init ( void )
{
return platform_driver_register ( & omap2_mbox_driver ) ;
}
static void __exit omap2_mbox_exit ( void )
{
platform_driver_unregister ( & omap2_mbox_driver ) ;
}
module_init ( omap2_mbox_init ) ;
module_exit ( omap2_mbox_exit ) ;
2009-03-23 18:07:23 -07:00
MODULE_LICENSE ( " GPL v2 " ) ;
2009-11-22 10:11:22 -08:00
MODULE_DESCRIPTION ( " omap mailbox: omap2/3/4 architecture specific functions " ) ;
2010-05-05 15:33:07 +00:00
MODULE_AUTHOR ( " Hiroshi DOYU <Hiroshi.DOYU@nokia.com> " ) ;
MODULE_AUTHOR ( " Paul Mundt " ) ;
2009-11-22 10:11:22 -08:00
MODULE_ALIAS ( " platform: " DRV_NAME ) ;