usb-omap.h 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * usb-omap.h - Platform data for the various OMAP USB IPs
  4. *
  5. * Copyright (C) 2012 Texas Instruments Incorporated - https://www.ti.com
  6. */
  7. #define OMAP3_HS_USB_PORTS 3
  8. enum usbhs_omap_port_mode {
  9. OMAP_USBHS_PORT_MODE_UNUSED,
  10. OMAP_EHCI_PORT_MODE_PHY,
  11. OMAP_EHCI_PORT_MODE_TLL,
  12. OMAP_EHCI_PORT_MODE_HSIC,
  13. OMAP_OHCI_PORT_MODE_PHY_6PIN_DATSE0,
  14. OMAP_OHCI_PORT_MODE_PHY_6PIN_DPDM,
  15. OMAP_OHCI_PORT_MODE_PHY_3PIN_DATSE0,
  16. OMAP_OHCI_PORT_MODE_PHY_4PIN_DPDM,
  17. OMAP_OHCI_PORT_MODE_TLL_6PIN_DATSE0,
  18. OMAP_OHCI_PORT_MODE_TLL_6PIN_DPDM,
  19. OMAP_OHCI_PORT_MODE_TLL_3PIN_DATSE0,
  20. OMAP_OHCI_PORT_MODE_TLL_4PIN_DPDM,
  21. OMAP_OHCI_PORT_MODE_TLL_2PIN_DATSE0,
  22. OMAP_OHCI_PORT_MODE_TLL_2PIN_DPDM
  23. };
  24. struct usbtll_omap_platform_data {
  25. enum usbhs_omap_port_mode port_mode[OMAP3_HS_USB_PORTS];
  26. };
  27. struct ehci_hcd_omap_platform_data {
  28. enum usbhs_omap_port_mode port_mode[OMAP3_HS_USB_PORTS];
  29. int reset_gpio_port[OMAP3_HS_USB_PORTS];
  30. struct regulator *regulator[OMAP3_HS_USB_PORTS];
  31. unsigned phy_reset:1;
  32. };
  33. struct ohci_hcd_omap_platform_data {
  34. enum usbhs_omap_port_mode port_mode[OMAP3_HS_USB_PORTS];
  35. unsigned es2_compatibility:1;
  36. };
  37. struct usbhs_omap_platform_data {
  38. int nports;
  39. enum usbhs_omap_port_mode port_mode[OMAP3_HS_USB_PORTS];
  40. int reset_gpio_port[OMAP3_HS_USB_PORTS];
  41. struct regulator *regulator[OMAP3_HS_USB_PORTS];
  42. struct ehci_hcd_omap_platform_data *ehci_data;
  43. struct ohci_hcd_omap_platform_data *ohci_data;
  44. /* OMAP3 <= ES2.1 have a single ulpi bypass control bit */
  45. unsigned single_ulpi_bypass:1;
  46. unsigned es2_compatibility:1;
  47. unsigned phy_reset:1;
  48. };
  49. /*-------------------------------------------------------------------------*/
  50. struct omap_musb_board_data {
  51. u8 interface_type;
  52. u8 mode;
  53. u16 power;
  54. unsigned extvbus:1;
  55. void (*set_phy_power)(u8 on);
  56. void (*clear_irq)(void);
  57. void (*set_mode)(u8 mode);
  58. void (*reset)(void);
  59. };
  60. enum musb_interface {
  61. MUSB_INTERFACE_ULPI,
  62. MUSB_INTERFACE_UTMI
  63. };