2011-04-04 13:44:59 +09:00
/*
* Renesas USB driver
*
* Copyright ( C ) 2011 Renesas Solutions Corp .
* Kuninori Morimoto < kuninori . morimoto . gx @ renesas . com >
*
* 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 St , Fifth Floor , Boston , MA 02110 - 1301 USA
*
*/
# ifndef RENESAS_USB_MOD_H
# define RENESAS_USB_MOD_H
# include <linux/spinlock.h>
# include <linux/usb/renesas_usbhs.h>
2012-06-03 18:39:13 +02:00
# include "common.h"
2011-04-04 13:44:59 +09:00
/*
* struct
*/
struct usbhs_irq_state {
u16 intsts0 ;
u16 intsts1 ;
u16 brdysts ;
u16 nrdysts ;
u16 bempsts ;
} ;
struct usbhs_mod {
char * name ;
/*
* entry point from common . c
*/
int ( * start ) ( struct usbhs_priv * priv ) ;
int ( * stop ) ( struct usbhs_priv * priv ) ;
2011-10-10 22:06:57 -07:00
/*
* INTSTS0
*/
/* DVST (DVSQ) */
2011-04-04 13:44:59 +09:00
int ( * irq_dev_state ) ( struct usbhs_priv * priv ,
struct usbhs_irq_state * irq_state ) ;
2011-10-10 22:06:57 -07:00
/* CTRT (CTSQ) */
2011-04-04 13:44:59 +09:00
int ( * irq_ctrl_stage ) ( struct usbhs_priv * priv ,
struct usbhs_irq_state * irq_state ) ;
2011-10-10 22:06:57 -07:00
/* BEMP / BEMPSTS */
2011-04-04 13:44:59 +09:00
int ( * irq_empty ) ( struct usbhs_priv * priv ,
struct usbhs_irq_state * irq_state ) ;
u16 irq_bempsts ;
2011-10-10 22:06:57 -07:00
/* BRDY / BRDYSTS */
2011-04-04 13:44:59 +09:00
int ( * irq_ready ) ( struct usbhs_priv * priv ,
struct usbhs_irq_state * irq_state ) ;
u16 irq_brdysts ;
2011-10-10 22:06:57 -07:00
/*
* INTSTS1
*/
/* ATTCHE */
int ( * irq_attch ) ( struct usbhs_priv * priv ,
struct usbhs_irq_state * irq_state ) ;
/* DTCHE */
int ( * irq_dtch ) ( struct usbhs_priv * priv ,
struct usbhs_irq_state * irq_state ) ;
/* SIGN */
int ( * irq_sign ) ( struct usbhs_priv * priv ,
struct usbhs_irq_state * irq_state ) ;
/* SACK */
int ( * irq_sack ) ( struct usbhs_priv * priv ,
struct usbhs_irq_state * irq_state ) ;
2011-04-04 13:44:59 +09:00
struct usbhs_priv * priv ;
} ;
struct usbhs_mod_info {
struct usbhs_mod * mod [ USBHS_MAX ] ;
struct usbhs_mod * curt ; /* current mod */
2011-04-28 16:41:20 +09:00
/*
* INTSTS0 : : VBINT
*
* This function will be used as autonomy mode
* when platform cannot call notify_hotplug .
*
* This callback cannot be member of " struct usbhs_mod "
* because it will be used even though
* host / gadget has not been selected .
*/
int ( * irq_vbus ) ( struct usbhs_priv * priv ,
struct usbhs_irq_state * irq_state ) ;
2011-04-04 13:44:59 +09:00
} ;
/*
* for host / gadget module
*/
struct usbhs_mod * usbhs_mod_get ( struct usbhs_priv * priv , int id ) ;
struct usbhs_mod * usbhs_mod_get_current ( struct usbhs_priv * priv ) ;
void usbhs_mod_register ( struct usbhs_priv * priv , struct usbhs_mod * usb , int id ) ;
2011-10-10 22:02:45 -07:00
int usbhs_mod_is_host ( struct usbhs_priv * priv ) ;
2011-04-04 13:44:59 +09:00
int usbhs_mod_change ( struct usbhs_priv * priv , int id ) ;
int usbhs_mod_probe ( struct usbhs_priv * priv ) ;
void usbhs_mod_remove ( struct usbhs_priv * priv ) ;
2011-04-28 16:41:20 +09:00
void usbhs_mod_autonomy_mode ( struct usbhs_priv * priv ) ;
2011-04-04 13:44:59 +09:00
/*
* status functions
*/
int usbhs_status_get_device_state ( struct usbhs_irq_state * irq_state ) ;
int usbhs_status_get_ctrl_stage ( struct usbhs_irq_state * irq_state ) ;
/*
* callback functions
*/
void usbhs_irq_callback_update ( struct usbhs_priv * priv , struct usbhs_mod * mod ) ;
# define usbhs_mod_call(priv, func, param...) \
( { \
struct usbhs_mod * mod ; \
mod = usbhs_mod_get_current ( priv ) ; \
! mod ? - ENODEV : \
! mod - > func ? 0 : \
mod - > func ( param ) ; \
} )
2011-04-05 11:40:54 +09:00
/*
2011-10-10 22:07:40 -07:00
* host / gadget control
2011-04-05 11:40:54 +09:00
*/
2011-10-12 21:02:44 -07:00
# if defined(CONFIG_USB_RENESAS_USBHS_HCD) || \
defined ( CONFIG_USB_RENESAS_USBHS_HCD_MODULE )
2011-10-26 19:33:49 -07:00
extern int usbhs_mod_host_probe ( struct usbhs_priv * priv ) ;
extern int usbhs_mod_host_remove ( struct usbhs_priv * priv ) ;
2011-10-10 22:07:40 -07:00
# else
static inline int usbhs_mod_host_probe ( struct usbhs_priv * priv )
{
return 0 ;
}
static inline void usbhs_mod_host_remove ( struct usbhs_priv * priv )
{
}
# endif
2011-10-12 21:02:44 -07:00
# if defined(CONFIG_USB_RENESAS_USBHS_UDC) || \
defined ( CONFIG_USB_RENESAS_USBHS_UDC_MODULE )
2011-10-26 19:33:49 -07:00
extern int usbhs_mod_gadget_probe ( struct usbhs_priv * priv ) ;
extern void usbhs_mod_gadget_remove ( struct usbhs_priv * priv ) ;
2011-04-05 11:40:54 +09:00
# else
static inline int usbhs_mod_gadget_probe ( struct usbhs_priv * priv )
{
return 0 ;
}
static inline void usbhs_mod_gadget_remove ( struct usbhs_priv * priv )
{
}
# endif
2011-04-04 13:44:59 +09:00
# endif /* RENESAS_USB_MOD_H */