blob: 5376b6d799d5db1f1bcab121984d0359934f3bde [file] [log] [blame]
Thomas Gleixner2874c5f2019-05-27 08:55:01 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Neil Zhangdde34cc2011-10-12 16:49:24 +08002/*
3 * Copyright (C) 2011 Marvell International Ltd. All rights reserved.
Neil Zhangdde34cc2011-10-12 16:49:24 +08004 */
5
6#ifndef __MV_PLATFORM_USB_H
7#define __MV_PLATFORM_USB_H
8
9enum pxa_ehci_type {
10 EHCI_UNDEFINED = 0,
11 PXA_U2OEHCI, /* pxa 168, 9xx */
12 PXA_SPH, /* pxa 168, 9xx SPH */
13 MMP3_HSIC, /* mmp3 hsic */
14 MMP3_FSIC, /* mmp3 fsic */
15};
16
17enum {
18 MV_USB_MODE_OTG,
19 MV_USB_MODE_HOST,
20};
21
22enum {
23 VBUS_LOW = 0,
24 VBUS_HIGH = 1 << 0,
25};
26
27struct mv_usb_addon_irq {
28 unsigned int irq;
29 int (*poll)(void);
30};
31
32struct mv_usb_platform_data {
Neil Zhangdde34cc2011-10-12 16:49:24 +080033 struct mv_usb_addon_irq *id; /* Only valid for OTG. ID pin change*/
34 struct mv_usb_addon_irq *vbus; /* valid for OTG/UDC. VBUS change*/
35
36 /* only valid for HCD. OTG or Host only*/
37 unsigned int mode;
38
Neil Zhang277164f2011-12-20 13:20:22 +080039 /* This flag is used for that needs id pin checked by otg */
40 unsigned int disable_otg_clock_gating:1;
41 /* Force a_bus_req to be asserted */
42 unsigned int otg_force_a_bus_req:1;
43
Neil Zhang5e6c86b2011-12-20 13:20:21 +080044 int (*phy_init)(void __iomem *regbase);
45 void (*phy_deinit)(void __iomem *regbase);
Neil Zhangdde34cc2011-10-12 16:49:24 +080046 int (*set_vbus)(unsigned int vbus);
47};
Neil Zhangdde34cc2011-10-12 16:49:24 +080048#endif