2006-12-07 15:43:59 -08:00
/* mailbox.h */
# ifndef MAILBOX_H
# define MAILBOX_H
2010-06-11 15:51:49 +00:00
# include <linux/spinlock.h>
2006-12-07 15:43:59 -08:00
# include <linux/workqueue.h>
2009-11-22 10:11:24 -08:00
# include <linux/interrupt.h>
2010-06-11 15:51:49 +00:00
# include <linux/device.h>
2010-05-05 15:33:09 +00:00
# include <linux/kfifo.h>
2006-12-07 15:43:59 -08:00
typedef u32 mbox_msg_t ;
struct omap_mbox ;
typedef int __bitwise omap_mbox_irq_t ;
# define IRQ_TX ((__force omap_mbox_irq_t) 1)
# define IRQ_RX ((__force omap_mbox_irq_t) 2)
typedef int __bitwise omap_mbox_type_t ;
# define OMAP_MBOX_TYPE1 ((__force omap_mbox_type_t) 1)
# define OMAP_MBOX_TYPE2 ((__force omap_mbox_type_t) 2)
struct omap_mbox_ops {
omap_mbox_type_t type ;
int ( * startup ) ( struct omap_mbox * mbox ) ;
void ( * shutdown ) ( struct omap_mbox * mbox ) ;
/* fifo */
mbox_msg_t ( * fifo_read ) ( struct omap_mbox * mbox ) ;
void ( * fifo_write ) ( struct omap_mbox * mbox , mbox_msg_t msg ) ;
int ( * fifo_empty ) ( struct omap_mbox * mbox ) ;
int ( * fifo_full ) ( struct omap_mbox * mbox ) ;
/* irq */
2009-11-22 10:11:24 -08:00
void ( * enable_irq ) ( struct omap_mbox * mbox ,
omap_mbox_irq_t irq ) ;
void ( * disable_irq ) ( struct omap_mbox * mbox ,
omap_mbox_irq_t irq ) ;
2006-12-07 15:43:59 -08:00
void ( * ack_irq ) ( struct omap_mbox * mbox , omap_mbox_irq_t irq ) ;
int ( * is_irq ) ( struct omap_mbox * mbox , omap_mbox_irq_t irq ) ;
2009-03-23 18:07:26 -07:00
/* ctx */
void ( * save_ctx ) ( struct omap_mbox * mbox ) ;
void ( * restore_ctx ) ( struct omap_mbox * mbox ) ;
2006-12-07 15:43:59 -08:00
} ;
struct omap_mbox_queue {
spinlock_t lock ;
2010-05-05 15:33:09 +00:00
struct kfifo fifo ;
2006-12-07 15:43:59 -08:00
struct work_struct work ;
2009-11-22 10:11:24 -08:00
struct tasklet_struct tasklet ;
2006-12-07 15:43:59 -08:00
struct omap_mbox * mbox ;
2010-11-29 20:24:11 +00:00
bool full ;
2006-12-07 15:43:59 -08:00
} ;
struct omap_mbox {
char * name ;
unsigned int irq ;
struct omap_mbox_queue * txq , * rxq ;
struct omap_mbox_ops * ops ;
2009-03-23 18:07:24 -07:00
struct device * dev ;
2006-12-07 15:43:59 -08:00
void * priv ;
2010-11-29 20:24:14 +00:00
int use_count ;
struct blocking_notifier_head notifier ;
2006-12-07 15:43:59 -08:00
} ;
2009-11-22 10:11:20 -08:00
int omap_mbox_msg_send ( struct omap_mbox * , mbox_msg_t msg ) ;
2006-12-07 15:43:59 -08:00
void omap_mbox_init_seq ( struct omap_mbox * ) ;
2010-11-29 20:24:14 +00:00
struct omap_mbox * omap_mbox_get ( const char * , struct notifier_block * nb ) ;
void omap_mbox_put ( struct omap_mbox * mbox , struct notifier_block * nb ) ;
2006-12-07 15:43:59 -08:00
2010-06-11 15:51:46 +00:00
int omap_mbox_register ( struct device * parent , struct omap_mbox * * ) ;
int omap_mbox_unregister ( void ) ;
2006-12-07 15:43:59 -08:00
2009-03-23 18:07:26 -07:00
static inline void omap_mbox_save_ctx ( struct omap_mbox * mbox )
{
if ( ! mbox - > ops - > save_ctx ) {
dev_err ( mbox - > dev , " %s: \t no save \n " , __func__ ) ;
return ;
}
mbox - > ops - > save_ctx ( mbox ) ;
}
static inline void omap_mbox_restore_ctx ( struct omap_mbox * mbox )
{
if ( ! mbox - > ops - > restore_ctx ) {
dev_err ( mbox - > dev , " %s: \t no restore \n " , __func__ ) ;
return ;
}
mbox - > ops - > restore_ctx ( mbox ) ;
}
2009-11-22 10:11:22 -08:00
static inline void omap_mbox_enable_irq ( struct omap_mbox * mbox ,
omap_mbox_irq_t irq )
{
mbox - > ops - > enable_irq ( mbox , irq ) ;
}
static inline void omap_mbox_disable_irq ( struct omap_mbox * mbox ,
omap_mbox_irq_t irq )
{
mbox - > ops - > disable_irq ( mbox , irq ) ;
}
2006-12-07 15:43:59 -08:00
# endif /* MAILBOX_H */