From: Ming Lei <tom.leiming@xxxxxxxxx> This patch fix kernel panic during s2ram, which is caused by mistaken definition of glue_to_musb. Signed-off-by: Ming Lei <tom.leiming@xxxxxxxxx> --- drivers/usb/musb/am35x.c | 1 - drivers/usb/musb/blackfin.c | 1 - drivers/usb/musb/musb_core.c | 13 ------------- drivers/usb/musb/musb_core.h | 12 ++++++++++++ drivers/usb/musb/omap2430.c | 1 - 5 files changed, 12 insertions(+), 16 deletions(-) diff --git a/drivers/usb/musb/am35x.c b/drivers/usb/musb/am35x.c index d5a3da3..79b7021 100644 --- a/drivers/usb/musb/am35x.c +++ b/drivers/usb/musb/am35x.c @@ -87,7 +87,6 @@ struct am35x_glue { struct clk *phy_clk; struct clk *clk; }; -#define glue_to_musb(g) platform_get_drvdata(g->musb) /* * am35x_musb_enable - enable interrupts diff --git a/drivers/usb/musb/blackfin.c b/drivers/usb/musb/blackfin.c index eeba228..7e82a17 100644 --- a/drivers/usb/musb/blackfin.c +++ b/drivers/usb/musb/blackfin.c @@ -27,7 +27,6 @@ struct bfin_glue { struct device *dev; struct platform_device *musb; }; -#define glue_to_musb(g) platform_get_drvdata(g->musb) /* * Load an endpoint's FIFO diff --git a/drivers/usb/musb/musb_core.c b/drivers/usb/musb/musb_core.c index 07cf394..b916c48 100644 --- a/drivers/usb/musb/musb_core.c +++ b/drivers/usb/musb/musb_core.c @@ -124,19 +124,6 @@ MODULE_LICENSE("GPL"); MODULE_ALIAS("platform:" MUSB_DRIVER_NAME); -/*-------------------------------------------------------------------------*/ - -static inline struct musb *dev_to_musb(struct device *dev) -{ -#ifdef CONFIG_USB_MUSB_HDRC_HCD - /* usbcore insists dev->driver_data is a "struct hcd *" */ - return hcd_to_musb(dev_get_drvdata(dev)); -#else - return dev_get_drvdata(dev); -#endif -} - -/*-------------------------------------------------------------------------*/ #ifndef CONFIG_BLACKFIN static int musb_ulpi_read(struct otg_transceiver *otg, u32 offset) diff --git a/drivers/usb/musb/musb_core.h b/drivers/usb/musb/musb_core.h index d0c236f..5c52478 100644 --- a/drivers/usb/musb/musb_core.h +++ b/drivers/usb/musb/musb_core.h @@ -577,6 +577,16 @@ static inline void musb_configure_ep0(struct musb *musb) } #endif /* CONFIG_BLACKFIN */ +static inline struct musb *dev_to_musb(struct device *dev) +{ +#ifdef CONFIG_USB_MUSB_HDRC_HCD + /* usbcore insists dev->driver_data is a "struct hcd *" */ + return hcd_to_musb(dev_get_drvdata(dev)); +#else + return dev_get_drvdata(dev); +#endif +} + /***************************** Glue it together *****************************/ @@ -594,6 +604,8 @@ extern irqreturn_t musb_interrupt(struct musb *); extern void musb_hnp_stop(struct musb *musb); +#define glue_to_musb(g) dev_to_musb(&g->musb->dev) + static inline void musb_platform_set_vbus(struct musb *musb, int is_on) { if (musb->ops->set_vbus) diff --git a/drivers/usb/musb/omap2430.c b/drivers/usb/musb/omap2430.c index a3f1233..b7bebda 100644 --- a/drivers/usb/musb/omap2430.c +++ b/drivers/usb/musb/omap2430.c @@ -42,7 +42,6 @@ struct omap2430_glue { struct platform_device *musb; struct clk *clk; }; -#define glue_to_musb(g) platform_get_drvdata(g->musb) static struct timer_list musb_idle_timer; -- 1.7.3 -- 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