Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit c723bd6e authored by Tony Lindgren's avatar Tony Lindgren Committed by Greg Kroah-Hartman
Browse files

usb: musb: Fix broken use of static variable for multiple instances



We can't use static variable first for checking when musb is
initialized when we have multiple musb instances like on am335x.

Tested-by: default avatarLadislav Michl <ladis@linux-mips.org>
Reviewed-by: default avatarJohan Hovold <johan@hovoldconsulting.com>
Tested-by: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: default avatarTony Lindgren <tony@atomide.com>
Signed-off-by: default avatarBin Liu <b-liu@ti.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent a5d906bb
Loading
Loading
Loading
Loading
+5 −4
Original line number Diff line number Diff line
@@ -2291,6 +2291,7 @@ musb_init_controller(struct device *dev, int nIrq, void __iomem *ctrl)
	if (status)
		goto fail5;

	musb->is_initialized = 1;
	pm_runtime_mark_last_busy(musb->controller);
	pm_runtime_put_autosuspend(musb->controller);

@@ -2629,7 +2630,6 @@ static int musb_runtime_suspend(struct device *dev)
static int musb_runtime_resume(struct device *dev)
{
	struct musb	*musb = dev_to_musb(dev);
	static int	first = 1;

	/*
	 * When pm_runtime_get_sync called for the first time in driver
@@ -2640,9 +2640,10 @@ static int musb_runtime_resume(struct device *dev)
	 * Also context restore without save does not make
	 * any sense
	 */
	if (!first)
	if (!musb->is_initialized)
		return 0;

	musb_restore_context(musb);
	first = 0;

	if (musb->need_finish_resume) {
		musb->need_finish_resume = 0;
+2 −0
Original line number Diff line number Diff line
@@ -385,6 +385,8 @@ struct musb {
	int			a_wait_bcon;	/* VBUS timeout in msecs */
	unsigned long		idle_timeout;	/* Next timeout in jiffies */

	unsigned		is_initialized:1;

	/* active means connected and not suspended */
	unsigned		is_active:1;