RE: [PATCH] usb: otg: Move phy interface to separate file.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



> -----Original Message-----
> From: Peter Chen [mailto:hzpeterchen@xxxxxxxxx]
> Sent: Wednesday, August 29, 2012 7:30 AM
> To: Venu Byravarasu
> Cc: gregkh@xxxxxxxxxxxxxxxxxxx; balbi@xxxxxx; linux-
> kernel@xxxxxxxxxxxxxxx; linux-usb@xxxxxxxxxxxxxxx
> Subject: Re: [PATCH] usb: otg: Move phy interface to separate file.
>
> >
> >  #include <linux/notifier.h>
> > +#include <linux/usb/phy.h>
> >
> one small thing:  <linux/notifier.h> is only needed at phy.h.

Thanks Peter, for your comment.
Will send an updated patch.

>
> >  /* OTG defines lots of enumeration states before device reset */
> >  enum usb_otg_state {
> > @@ -35,31 +36,6 @@ enum usb_otg_state {
> >         OTG_STATE_A_VBUS_ERR,
> >  };
> >
> > -enum usb_phy_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 */
> > -};
> > -
> > -/* associate a type with PHY */
> > -enum usb_phy_type {
> > -       USB_PHY_TYPE_UNDEFINED,
> > -       USB_PHY_TYPE_USB2,
> > -       USB_PHY_TYPE_USB3,
> > -};
> > -
> > -struct usb_phy;
> > -
> > -/* for transceivers connected thru an ULPI interface, the user must
> > - * provide access ops
> > - */
> > -struct usb_phy_io_ops {
> > -       int (*read)(struct usb_phy *x, u32 reg);
> > -       int (*write)(struct usb_phy *x, u32 val, u32 reg);
> > -};
> > -
> >  struct usb_otg {
> >         u8                      default_a;
> >
> > @@ -85,134 +61,9 @@ struct usb_otg {
> >
> >  };
> >
> > -/*
> > - * the otg driver needs to interact with both device side and host side
> > - * usb controllers.  it decides which controller is active at a given
> > - * moment, using the transceiver, ID signal, HNP and sometimes static
> > - * configuration information (including "board isn't wired for otg").
> > - */
> > -struct usb_phy {
> > -       struct device           *dev;
> > -       const char              *label;
> > -       unsigned int             flags;
> > -
> > -       enum usb_phy_type       type;
> > -       enum usb_otg_state      state;
> > -       enum usb_phy_events     last_event;
> > -
> > -       struct usb_otg          *otg;
> > -
> > -       struct device           *io_dev;
> > -       struct usb_phy_io_ops   *io_ops;
> > -       void __iomem            *io_priv;
> > -
> > -       /* for notification of usb_phy_events */
> > -       struct atomic_notifier_head     notifier;
> > -
> > -       /* to pass extra port status to the root hub */
> > -       u16                     port_status;
> > -       u16                     port_change;
> > -
> > -       /* to support controllers that have multiple transceivers */
> > -       struct list_head        head;
> > -
> > -       /* initialize/shutdown the OTG controller */
> > -       int     (*init)(struct usb_phy *x);
> > -       void    (*shutdown)(struct usb_phy *x);
> > -
> > -       /* effective for B devices, ignored for A-peripheral */
> > -       int     (*set_power)(struct usb_phy *x,
> > -                               unsigned mA);
> > -
> > -       /* for non-OTG B devices: set transceiver into suspend mode */
> > -       int     (*set_suspend)(struct usb_phy *x,
> > -                               int suspend);
> > -
> > -       /* notify phy connect status change */
> > -       int     (*notify_connect)(struct usb_phy *x, int port);
> > -       int     (*notify_disconnect)(struct usb_phy *x, int port);
> > -};
> > -
> > -
> > -/* for board-specific init logic */
> > -extern int usb_add_phy(struct usb_phy *, enum usb_phy_type type);
> > -extern void usb_remove_phy(struct usb_phy *);
> > -
> > -#if defined(CONFIG_NOP_USB_XCEIV) ||
> (defined(CONFIG_NOP_USB_XCEIV_MODULE) && defined(MODULE))
> > -/* sometimes transceivers are accessed only through e.g. ULPI */
> > -extern void usb_nop_xceiv_register(void);
> > -extern void usb_nop_xceiv_unregister(void);
> > -#else
> > -static inline void usb_nop_xceiv_register(void)
> > -{
> > -}
> > -
> > -static inline void usb_nop_xceiv_unregister(void)
> > -{
> > -}
> > -#endif
> > -
> > -/* helpers for direct access thru low-level io interface */
> > -static inline int usb_phy_io_read(struct usb_phy *x, u32 reg)
> > -{
> > -       if (x->io_ops && x->io_ops->read)
> > -               return x->io_ops->read(x, reg);
> > -
> > -       return -EINVAL;
> > -}
> > -
> > -static inline int usb_phy_io_write(struct usb_phy *x, u32 val, u32 reg)
> > -{
> > -       if (x->io_ops && x->io_ops->write)
> > -               return x->io_ops->write(x, val, reg);
> > -
> > -       return -EINVAL;
> > -}
> > -
> > -static inline int
> > -usb_phy_init(struct usb_phy *x)
> > -{
> > -       if (x->init)
> > -               return x->init(x);
> > -
> > -       return 0;
> > -}
> > -
> > -static inline void
> > -usb_phy_shutdown(struct usb_phy *x)
> > -{
> > -       if (x->shutdown)
> > -               x->shutdown(x);
> > -}
> > -
> > -/* for usb host and peripheral controller drivers */
> >  #ifdef CONFIG_USB_OTG_UTILS
> > -extern struct usb_phy *usb_get_phy(enum usb_phy_type type);
> > -extern struct usb_phy *devm_usb_get_phy(struct device *dev,
> > -       enum usb_phy_type type);
> > -extern void usb_put_phy(struct usb_phy *);
> > -extern void devm_usb_put_phy(struct device *dev, struct usb_phy *x);
> >  extern const char *otg_state_string(enum usb_otg_state state);
> >  #else
> > -static inline struct usb_phy *usb_get_phy(enum usb_phy_type type)
> > -{
> > -       return NULL;
> > -}
> > -
> > -static inline struct usb_phy *devm_usb_get_phy(struct device *dev,
> > -       enum usb_phy_type type)
> > -{
> > -       return NULL;
> > -}
> > -
> > -static inline void usb_put_phy(struct usb_phy *x)
> > -{
> > -}
> > -
> > -static inline void devm_usb_put_phy(struct device *dev, struct usb_phy
> *x)
> > -{
> > -}
> > -
> >  static inline const char *otg_state_string(enum usb_otg_state state)
> >  {
> >         return NULL;
> > @@ -262,42 +113,6 @@ otg_set_peripheral(struct usb_otg *otg, struct
> usb_gadget *periph)
> >  }
> >
> >  static inline int
> > -usb_phy_set_power(struct usb_phy *x, unsigned mA)
> > -{
> > -       if (x && x->set_power)
> > -               return x->set_power(x, mA);
> > -       return 0;
> > -}
> > -
> > -/* Context: can sleep */
> > -static inline int
> > -usb_phy_set_suspend(struct usb_phy *x, int suspend)
> > -{
> > -       if (x->set_suspend != NULL)
> > -               return x->set_suspend(x, suspend);
> > -       else
> > -               return 0;
> > -}
> > -
> > -static inline int
> > -usb_phy_notify_connect(struct usb_phy *x, int port)
> > -{
> > -       if (x->notify_connect)
> > -               return x->notify_connect(x, port);
> > -       else
> > -               return 0;
> > -}
> > -
> > -static inline int
> > -usb_phy_notify_disconnect(struct usb_phy *x, int port)
> > -{
> > -       if (x->notify_disconnect)
> > -               return x->notify_disconnect(x, port);
> > -       else
> > -               return 0;
> > -}
> > -
> > -static inline int
> >  otg_start_srp(struct usb_otg *otg)
> >  {
> >         if (otg && otg->start_srp)
> > @@ -306,31 +121,7 @@ otg_start_srp(struct usb_otg *otg)
> >         return -ENOTSUPP;
> >  }
> >
> > -/* notifiers */
> > -static inline int
> > -usb_register_notifier(struct usb_phy *x, struct notifier_block *nb)
> > -{
> > -       return atomic_notifier_chain_register(&x->notifier, nb);
> > -}
> > -
> > -static inline void
> > -usb_unregister_notifier(struct usb_phy *x, struct notifier_block *nb)
> > -{
> > -       atomic_notifier_chain_unregister(&x->notifier, nb);
> > -}
> > -
> >  /* for OTG controller drivers (and maybe other stuff) */
> >  extern int usb_bus_start_enum(struct usb_bus *bus, unsigned port_num);
> >
> > -static inline const char *usb_phy_type_string(enum usb_phy_type type)
> > -{
> > -       switch (type) {
> > -       case USB_PHY_TYPE_USB2:
> > -               return "USB2 PHY";
> > -       case USB_PHY_TYPE_USB3:
> > -               return "USB3 PHY";
> > -       default:
> > -               return "UNKNOWN PHY TYPE";
> > -       }
> > -}
> >  #endif /* __LINUX_USB_OTG_H */
> > diff --git a/include/linux/usb/phy.h b/include/linux/usb/phy.h
> > new file mode 100644
> > index 0000000..5a2bcbe
> > --- /dev/null
> > +++ b/include/linux/usb/phy.h
> > @@ -0,0 +1,222 @@
> > +/* USB OTG (On The Go) defines */
> > +/*
> > + *
> > + * These APIs may be used between USB controllers.  USB device drivers
> > + * (for either host or peripheral roles) don't use these calls; they
> > + * continue to use just usb_device and usb_gadget.
> > + */
> > +
> > +#ifndef __LINUX_USB_PHY_H
> > +#define __LINUX_USB_PHY_H
> > +
> > +#include <linux/notifier.h>
> > +
> > +enum usb_phy_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 */
> > +};
> > +
> > +/* associate a type with PHY */
> > +enum usb_phy_type {
> > +       USB_PHY_TYPE_UNDEFINED,
> > +       USB_PHY_TYPE_USB2,
> > +       USB_PHY_TYPE_USB3,
> > +};
> > +
> > +struct usb_phy;
> > +struct usb_otg;
> > +
> > +/* for transceivers connected thru an ULPI interface, the user must
> > + * provide access ops
> > + */
> > +struct usb_phy_io_ops {
> > +       int (*read)(struct usb_phy *x, u32 reg);
> > +       int (*write)(struct usb_phy *x, u32 val, u32 reg);
> > +};
> > +
> > +struct usb_phy {
> > +       struct device           *dev;
> > +       const char              *label;
> > +       unsigned int             flags;
> > +
> > +       enum usb_phy_type       type;
> > +       enum usb_phy_events     last_event;
> > +
> > +       struct usb_otg          *otg;
> > +
> > +       struct device           *io_dev;
> > +       struct usb_phy_io_ops   *io_ops;
> > +       void __iomem            *io_priv;
> > +
> > +       /* for notification of usb_phy_events */
> > +       struct atomic_notifier_head     notifier;
> > +
> > +       /* to pass extra port status to the root hub */
> > +       u16                     port_status;
> > +       u16                     port_change;
> > +
> > +       /* to support controllers that have multiple transceivers */
> > +       struct list_head        head;
> > +
> > +       /* initialize/shutdown the OTG controller */
> > +       int     (*init)(struct usb_phy *x);
> > +       void    (*shutdown)(struct usb_phy *x);
> > +
> > +       /* effective for B devices, ignored for A-peripheral */
> > +       int     (*set_power)(struct usb_phy *x,
> > +                               unsigned mA);
> > +
> > +       /* for non-OTG B devices: set transceiver into suspend mode */
> > +       int     (*set_suspend)(struct usb_phy *x,
> > +                               int suspend);
> > +
> > +       /* notify phy connect status change */
> > +       int     (*notify_connect)(struct usb_phy *x, int port);
> > +       int     (*notify_disconnect)(struct usb_phy *x, int port);
> > +};
> > +
> > +
> > +/* for board-specific init logic */
> > +extern int usb_add_phy(struct usb_phy *, enum usb_phy_type type);
> > +extern void usb_remove_phy(struct usb_phy *);
> > +
> > +#if defined(CONFIG_NOP_USB_XCEIV) ||
> (defined(CONFIG_NOP_USB_XCEIV_MODULE) && defined(MODULE))
> > +/* sometimes transceivers are accessed only through e.g. ULPI */
> > +extern void usb_nop_xceiv_register(void);
> > +extern void usb_nop_xceiv_unregister(void);
> > +#else
> > +static inline void usb_nop_xceiv_register(void)
> > +{
> > +}
> > +
> > +static inline void usb_nop_xceiv_unregister(void)
> > +{
> > +}
> > +#endif
> > +
> > +/* helpers for direct access thru low-level io interface */
> > +static inline int usb_phy_io_read(struct usb_phy *x, u32 reg)
> > +{
> > +       if (x->io_ops && x->io_ops->read)
> > +               return x->io_ops->read(x, reg);
> > +
> > +       return -EINVAL;
> > +}
> > +
> > +static inline int usb_phy_io_write(struct usb_phy *x, u32 val, u32 reg)
> > +{
> > +       if (x->io_ops && x->io_ops->write)
> > +               return x->io_ops->write(x, val, reg);
> > +
> > +       return -EINVAL;
> > +}
> > +
> > +static inline int
> > +usb_phy_init(struct usb_phy *x)
> > +{
> > +       if (x->init)
> > +               return x->init(x);
> > +
> > +       return 0;
> > +}
> > +
> > +static inline void
> > +usb_phy_shutdown(struct usb_phy *x)
> > +{
> > +       if (x->shutdown)
> > +               x->shutdown(x);
> > +}
> > +
> > +/* for usb host and peripheral controller drivers */
> > +#ifdef CONFIG_USB_OTG_UTILS
> > +extern struct usb_phy *usb_get_phy(enum usb_phy_type type);
> > +extern struct usb_phy *devm_usb_get_phy(struct device *dev,
> > +       enum usb_phy_type type);
> > +extern void usb_put_phy(struct usb_phy *);
> > +extern void devm_usb_put_phy(struct device *dev, struct usb_phy *x);
> > +#else
> > +static inline struct usb_phy *usb_get_phy(enum usb_phy_type type)
> > +{
> > +       return NULL;
> > +}
> > +
> > +static inline struct usb_phy *devm_usb_get_phy(struct device *dev,
> > +       enum usb_phy_type type)
> > +{
> > +       return NULL;
> > +}
> > +
> > +static inline void usb_put_phy(struct usb_phy *x)
> > +{
> > +}
> > +
> > +static inline void devm_usb_put_phy(struct device *dev, struct usb_phy
> *x)
> > +{
> > +}
> > +
> > +#endif
> > +
> > +static inline int
> > +usb_phy_set_power(struct usb_phy *x, unsigned mA)
> > +{
> > +       if (x && x->set_power)
> > +               return x->set_power(x, mA);
> > +       return 0;
> > +}
> > +
> > +/* Context: can sleep */
> > +static inline int
> > +usb_phy_set_suspend(struct usb_phy *x, int suspend)
> > +{
> > +       if (x->set_suspend != NULL)
> > +               return x->set_suspend(x, suspend);
> > +       else
> > +               return 0;
> > +}
> > +
> > +static inline int
> > +usb_phy_notify_connect(struct usb_phy *x, int port)
> > +{
> > +       if (x->notify_connect)
> > +               return x->notify_connect(x, port);
> > +       else
> > +               return 0;
> > +}
> > +
> > +static inline int
> > +usb_phy_notify_disconnect(struct usb_phy *x, int port)
> > +{
> > +       if (x->notify_disconnect)
> > +               return x->notify_disconnect(x, port);
> > +       else
> > +               return 0;
> > +}
> > +
> > +/* notifiers */
> > +static inline int
> > +usb_register_notifier(struct usb_phy *x, struct notifier_block *nb)
> > +{
> > +       return atomic_notifier_chain_register(&x->notifier, nb);
> > +}
> > +
> > +static inline void
> > +usb_unregister_notifier(struct usb_phy *x, struct notifier_block *nb)
> > +{
> > +       atomic_notifier_chain_unregister(&x->notifier, nb);
> > +}
> > +
> > +static inline const char *usb_phy_type_string(enum usb_phy_type type)
> > +{
> > +       switch (type) {
> > +       case USB_PHY_TYPE_USB2:
> > +               return "USB2 PHY";
> > +       case USB_PHY_TYPE_USB3:
> > +               return "USB3 PHY";
> > +       default:
> > +               return "UNKNOWN PHY TYPE";
> > +       }
> > +}
> > +#endif /* __LINUX_USB_PHY_H */
> > --
> > 1.7.1.1
> >
> > --
> > To unsubscribe from this list: send the line "unsubscribe linux-usb" in
> > the body of a message to majordomo@xxxxxxxxxxxxxxx
> > More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux