Greg Kroah-Hartman | 41dceed | 2008-01-30 15:21:33 -0800 | [diff] [blame] | 1 | /* USB OTG (On The Go) defines */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | /* |
Robert P. J. Day | dda43a0 | 2008-03-07 13:45:32 -0500 | [diff] [blame] | 3 | * |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 4 | * These APIs may be used between USB controllers. USB device drivers |
| 5 | * (for either host or peripheral roles) don't use these calls; they |
| 6 | * continue to use just usb_device and usb_gadget. |
| 7 | */ |
| 8 | |
Robert P. J. Day | dda43a0 | 2008-03-07 13:45:32 -0500 | [diff] [blame] | 9 | #ifndef __LINUX_USB_OTG_H |
| 10 | #define __LINUX_USB_OTG_H |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 11 | |
Venu Byravarasu | de4217d | 2012-09-04 14:25:58 +0530 | [diff] [blame] | 12 | #include <linux/usb/phy.h> |
Felipe Balbi | e9a2017 | 2009-12-17 13:01:36 +0200 | [diff] [blame] | 13 | |
Heikki Krogerus | 7a8a3a9 | 2012-02-13 13:24:04 +0200 | [diff] [blame] | 14 | struct usb_otg { |
| 15 | u8 default_a; |
| 16 | |
| 17 | struct usb_phy *phy; |
| 18 | struct usb_bus *host; |
| 19 | struct usb_gadget *gadget; |
| 20 | |
| 21 | /* bind/unbind the host controller */ |
| 22 | int (*set_host)(struct usb_otg *otg, struct usb_bus *host); |
| 23 | |
| 24 | /* bind/unbind the peripheral controller */ |
| 25 | int (*set_peripheral)(struct usb_otg *otg, |
| 26 | struct usb_gadget *gadget); |
| 27 | |
| 28 | /* effective for A-peripheral, ignored for B devices */ |
| 29 | int (*set_vbus)(struct usb_otg *otg, bool enabled); |
| 30 | |
| 31 | /* for B devices only: start session with A-Host */ |
| 32 | int (*start_srp)(struct usb_otg *otg); |
| 33 | |
| 34 | /* start or continue HNP role switch */ |
| 35 | int (*start_hnp)(struct usb_otg *otg); |
| 36 | |
| 37 | }; |
| 38 | |
Grazvydas Ignotas | 748eee0 | 2010-09-27 15:17:18 +0300 | [diff] [blame] | 39 | #ifdef CONFIG_USB_OTG_UTILS |
Anatolij Gustschin | 3df0045 | 2011-05-05 12:11:21 +0200 | [diff] [blame] | 40 | extern const char *otg_state_string(enum usb_otg_state state); |
Grazvydas Ignotas | 748eee0 | 2010-09-27 15:17:18 +0300 | [diff] [blame] | 41 | #else |
Anatolij Gustschin | 3df0045 | 2011-05-05 12:11:21 +0200 | [diff] [blame] | 42 | static inline const char *otg_state_string(enum usb_otg_state state) |
| 43 | { |
| 44 | return NULL; |
| 45 | } |
Grazvydas Ignotas | 748eee0 | 2010-09-27 15:17:18 +0300 | [diff] [blame] | 46 | #endif |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 47 | |
Robert Jarzmik | c2344f1 | 2009-01-24 23:54:31 -0800 | [diff] [blame] | 48 | /* Context: can sleep */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 49 | static inline int |
Heikki Krogerus | 6e13c65 | 2012-02-13 13:24:20 +0200 | [diff] [blame] | 50 | otg_start_hnp(struct usb_otg *otg) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 51 | { |
Heikki Krogerus | 6e13c65 | 2012-02-13 13:24:20 +0200 | [diff] [blame] | 52 | if (otg && otg->start_hnp) |
| 53 | return otg->start_hnp(otg); |
Heikki Krogerus | 7a8a3a9 | 2012-02-13 13:24:04 +0200 | [diff] [blame] | 54 | |
Heikki Krogerus | 136ced8 | 2012-02-13 13:24:19 +0200 | [diff] [blame] | 55 | return -ENOTSUPP; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 56 | } |
| 57 | |
Daniel Mack | 91c8a5a | 2009-10-15 17:09:34 +0300 | [diff] [blame] | 58 | /* Context: can sleep */ |
| 59 | static inline int |
Heikki Krogerus | 6e13c65 | 2012-02-13 13:24:20 +0200 | [diff] [blame] | 60 | otg_set_vbus(struct usb_otg *otg, bool enabled) |
Daniel Mack | 91c8a5a | 2009-10-15 17:09:34 +0300 | [diff] [blame] | 61 | { |
Heikki Krogerus | 6e13c65 | 2012-02-13 13:24:20 +0200 | [diff] [blame] | 62 | if (otg && otg->set_vbus) |
| 63 | return otg->set_vbus(otg, enabled); |
Heikki Krogerus | 7a8a3a9 | 2012-02-13 13:24:04 +0200 | [diff] [blame] | 64 | |
Heikki Krogerus | 136ced8 | 2012-02-13 13:24:19 +0200 | [diff] [blame] | 65 | return -ENOTSUPP; |
Daniel Mack | 91c8a5a | 2009-10-15 17:09:34 +0300 | [diff] [blame] | 66 | } |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 67 | |
| 68 | /* for HCDs */ |
| 69 | static inline int |
Heikki Krogerus | 6e13c65 | 2012-02-13 13:24:20 +0200 | [diff] [blame] | 70 | otg_set_host(struct usb_otg *otg, struct usb_bus *host) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 71 | { |
Heikki Krogerus | 6e13c65 | 2012-02-13 13:24:20 +0200 | [diff] [blame] | 72 | if (otg && otg->set_host) |
| 73 | return otg->set_host(otg, host); |
Heikki Krogerus | 7a8a3a9 | 2012-02-13 13:24:04 +0200 | [diff] [blame] | 74 | |
Heikki Krogerus | 136ced8 | 2012-02-13 13:24:19 +0200 | [diff] [blame] | 75 | return -ENOTSUPP; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 76 | } |
| 77 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 78 | /* for usb peripheral controller drivers */ |
Robert Jarzmik | c2344f1 | 2009-01-24 23:54:31 -0800 | [diff] [blame] | 79 | |
| 80 | /* Context: can sleep */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 81 | static inline int |
Heikki Krogerus | 6e13c65 | 2012-02-13 13:24:20 +0200 | [diff] [blame] | 82 | otg_set_peripheral(struct usb_otg *otg, struct usb_gadget *periph) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 83 | { |
Heikki Krogerus | 6e13c65 | 2012-02-13 13:24:20 +0200 | [diff] [blame] | 84 | if (otg && otg->set_peripheral) |
| 85 | return otg->set_peripheral(otg, periph); |
Heikki Krogerus | 7a8a3a9 | 2012-02-13 13:24:04 +0200 | [diff] [blame] | 86 | |
Heikki Krogerus | 136ced8 | 2012-02-13 13:24:19 +0200 | [diff] [blame] | 87 | return -ENOTSUPP; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 88 | } |
| 89 | |
| 90 | static inline int |
Heikki Krogerus | 6e13c65 | 2012-02-13 13:24:20 +0200 | [diff] [blame] | 91 | otg_start_srp(struct usb_otg *otg) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 92 | { |
Heikki Krogerus | 6e13c65 | 2012-02-13 13:24:20 +0200 | [diff] [blame] | 93 | if (otg && otg->start_srp) |
| 94 | return otg->start_srp(otg); |
Heikki Krogerus | 7a8a3a9 | 2012-02-13 13:24:04 +0200 | [diff] [blame] | 95 | |
Heikki Krogerus | 136ced8 | 2012-02-13 13:24:19 +0200 | [diff] [blame] | 96 | return -ENOTSUPP; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 97 | } |
| 98 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 99 | /* for OTG controller drivers (and maybe other stuff) */ |
| 100 | extern int usb_bus_start_enum(struct usb_bus *bus, unsigned port_num); |
Robert P. J. Day | dda43a0 | 2008-03-07 13:45:32 -0500 | [diff] [blame] | 101 | |
| 102 | #endif /* __LINUX_USB_OTG_H */ |