Merge tag 'nfsd-6.10-3' of git://git.kernel.org/pub/scm/linux/kernel/git/cel/linux
[linux-block.git] / drivers / usb / chipidea / ci_hdrc_imx.h
CommitLineData
d9958306 1/* SPDX-License-Identifier: GPL-2.0+ */
d142d6be
RZ
2/*
3 * Copyright 2012 Freescale Semiconductor, Inc.
d142d6be
RZ
4 */
5
292abc90
RB
6#ifndef __DRIVER_USB_CHIPIDEA_CI_HDRC_IMX_H
7#define __DRIVER_USB_CHIPIDEA_CI_HDRC_IMX_H
8
05986ba9 9struct imx_usbmisc_data {
f40017e0 10 struct device *dev;
d142d6be
RZ
11 int index;
12
7b8bc3aa 13 unsigned int disable_oc:1; /* over current detect disabled */
a82bf696
UKK
14
15 /* true if over-current polarity is active low */
16 unsigned int oc_pol_active_low:1;
17
18 /* true if dt specifies polarity */
19 unsigned int oc_pol_configured:1;
20
5f0632c4 21 unsigned int pwr_pol:1; /* power polarity */
a0685330 22 unsigned int evdo:1; /* set external vbus divider option */
d13631bb 23 unsigned int ulpi:1; /* connected to an ULPI phy */
7013b262 24 unsigned int hsic:1; /* HSIC controller */
93c2c733
LJ
25 unsigned int ext_id:1; /* ID from exteranl event */
26 unsigned int ext_vbus:1; /* Vbus from exteranl event */
746f316b 27 struct usb_phy *usb_phy;
d6f93d21 28 enum usb_dr_mode available_role; /* runtime usb dr mode */
58a3cefb
PC
29 int emp_curr_control;
30 int dc_vol_level_adjust;
3bd442e4 31 int rise_fall_time_adjust;
d142d6be
RZ
32};
33
7c8e8909
PC
34int imx_usbmisc_init(struct imx_usbmisc_data *data);
35int imx_usbmisc_init_post(struct imx_usbmisc_data *data);
7c8e8909 36int imx_usbmisc_hsic_set_connect(struct imx_usbmisc_data *data);
746f316b 37int imx_usbmisc_charger_detection(struct imx_usbmisc_data *data, bool connect);
b332d6d5
LJ
38int imx_usbmisc_suspend(struct imx_usbmisc_data *data, bool wakeup);
39int imx_usbmisc_resume(struct imx_usbmisc_data *data, bool wakeup);
292abc90
RB
40
41#endif /* __DRIVER_USB_CHIPIDEA_CI_HDRC_IMX_H */