2011-10-12 16:49:24 +08:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2011 Marvell International Ltd. All rights reserved.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __MV_PLATFORM_USB_H
|
|
|
|
#define __MV_PLATFORM_USB_H
|
|
|
|
|
|
|
|
enum pxa_ehci_type {
|
|
|
|
EHCI_UNDEFINED = 0,
|
|
|
|
PXA_U2OEHCI, /* pxa 168, 9xx */
|
|
|
|
PXA_SPH, /* pxa 168, 9xx SPH */
|
|
|
|
MMP3_HSIC, /* mmp3 hsic */
|
|
|
|
MMP3_FSIC, /* mmp3 fsic */
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
MV_USB_MODE_OTG,
|
|
|
|
MV_USB_MODE_HOST,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
VBUS_LOW = 0,
|
|
|
|
VBUS_HIGH = 1 << 0,
|
|
|
|
};
|
|
|
|
|
|
|
|
struct mv_usb_addon_irq {
|
|
|
|
unsigned int irq;
|
|
|
|
int (*poll)(void);
|
|
|
|
};
|
|
|
|
|
|
|
|
struct mv_usb_platform_data {
|
|
|
|
struct mv_usb_addon_irq *id; /* Only valid for OTG. ID pin change*/
|
|
|
|
struct mv_usb_addon_irq *vbus; /* valid for OTG/UDC. VBUS change*/
|
|
|
|
|
|
|
|
/* only valid for HCD. OTG or Host only*/
|
|
|
|
unsigned int mode;
|
|
|
|
|
2011-12-20 13:20:22 +08:00
|
|
|
/* This flag is used for that needs id pin checked by otg */
|
|
|
|
unsigned int disable_otg_clock_gating:1;
|
|
|
|
/* Force a_bus_req to be asserted */
|
|
|
|
unsigned int otg_force_a_bus_req:1;
|
|
|
|
|
2011-12-20 13:20:21 +08:00
|
|
|
int (*phy_init)(void __iomem *regbase);
|
|
|
|
void (*phy_deinit)(void __iomem *regbase);
|
2011-10-12 16:49:24 +08:00
|
|
|
int (*set_vbus)(unsigned int vbus);
|
2011-12-20 13:20:23 +08:00
|
|
|
int (*private_init)(void __iomem *opregs, void __iomem *phyregs);
|
2011-10-12 16:49:24 +08:00
|
|
|
};
|
|
|
|
#endif
|