Commit e9a20171 authored by Felipe Balbi's avatar Felipe Balbi Committed by Greg Kroah-Hartman

USB: otg: add notifier support

The notifier will be used to communicate usb events
to other drivers like the charger chip.

This can be used as source of information to kick
usb charger detection as described by the USB
Battery Charging Specification 1.1 and/or to
pass bMaxPower field of selected usb_configuration
to charger chip in order to use that information
as input current on the charging profile
setup.
Signed-off-by: default avatarFelipe Balbi <felipe.balbi@nokia.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 8bc1d217
...@@ -9,6 +9,8 @@ ...@@ -9,6 +9,8 @@
#ifndef __LINUX_USB_OTG_H #ifndef __LINUX_USB_OTG_H
#define __LINUX_USB_OTG_H #define __LINUX_USB_OTG_H
#include <linux/notifier.h>
/* OTG defines lots of enumeration states before device reset */ /* OTG defines lots of enumeration states before device reset */
enum usb_otg_state { enum usb_otg_state {
OTG_STATE_UNDEFINED = 0, OTG_STATE_UNDEFINED = 0,
...@@ -33,6 +35,14 @@ enum usb_otg_state { ...@@ -33,6 +35,14 @@ enum usb_otg_state {
OTG_STATE_A_VBUS_ERR, OTG_STATE_A_VBUS_ERR,
}; };
enum usb_xceiv_events {
USB_EVENT_NONE, /* no events or cable disconnected */
USB_EVENT_VBUS, /* vbus valid event */
USB_EVENT_ID, /* id was grounded */
USB_EVENT_CHARGER, /* usb dedicated charger */
USB_EVENT_ENUMERATED, /* gadget driver enumerated */
};
#define USB_OTG_PULLUP_ID (1 << 0) #define USB_OTG_PULLUP_ID (1 << 0)
#define USB_OTG_PULLDOWN_DP (1 << 1) #define USB_OTG_PULLDOWN_DP (1 << 1)
#define USB_OTG_PULLDOWN_DM (1 << 2) #define USB_OTG_PULLDOWN_DM (1 << 2)
...@@ -70,6 +80,9 @@ struct otg_transceiver { ...@@ -70,6 +80,9 @@ struct otg_transceiver {
struct otg_io_access_ops *io_ops; struct otg_io_access_ops *io_ops;
void __iomem *io_priv; void __iomem *io_priv;
/* for notification of usb_xceiv_events */
struct blocking_notifier_head notifier;
/* to pass extra port status to the root hub */ /* to pass extra port status to the root hub */
u16 port_status; u16 port_status;
u16 port_change; u16 port_change;
...@@ -203,6 +216,18 @@ otg_start_srp(struct otg_transceiver *otg) ...@@ -203,6 +216,18 @@ otg_start_srp(struct otg_transceiver *otg)
return otg->start_srp(otg); return otg->start_srp(otg);
} }
/* notifiers */
static inline int
otg_register_notifier(struct otg_transceiver *otg, struct notifier_block *nb)
{
return blocking_notifier_chain_register(&otg->notifier, nb);
}
static inline void
otg_unregister_notifier(struct otg_transceiver *otg, struct notifier_block *nb)
{
blocking_notifier_chain_unregister(&otg->notifier, nb);
}
/* for OTG controller drivers (and maybe other stuff) */ /* for OTG controller drivers (and maybe other stuff) */
extern int usb_bus_start_enum(struct usb_bus *bus, unsigned port_num); extern int usb_bus_start_enum(struct usb_bus *bus, unsigned port_num);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment