Commit 95c9773b authored by David Eccher's avatar David Eccher Committed by Thadeu Lima de Souza Cascardo

usb: gadget: inode.c: fix unbalanced spin_lock in ep0_write

BugLink: http://bugs.launchpad.net/bugs/1724783

commit b7bd98b7 upstream.

Fix bad unlock balance: ep0_write enter with the locks locked from
inode.c:1769, hence it must exit with spinlock held to avoid double
unlock in dev_config.
Signed-off-by: default avatarDavid Eccher <d.eccher@gmail.com>
Signed-off-by: default avatarFelipe Balbi <balbi@ti.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarStefan Bader <stefan.bader@canonical.com>
Signed-off-by: default avatarThadeu Lima de Souza Cascardo <cascardo@canonical.com>
parent 33c94e10
...@@ -1140,10 +1140,9 @@ ep0_write (struct file *fd, const char __user *buf, size_t len, loff_t *ptr) ...@@ -1140,10 +1140,9 @@ ep0_write (struct file *fd, const char __user *buf, size_t len, loff_t *ptr)
dev->gadget->ep0, dev->req, dev->gadget->ep0, dev->req,
GFP_KERNEL); GFP_KERNEL);
} }
spin_lock_irq(&dev->lock);
if (retval < 0) { if (retval < 0) {
spin_lock_irq (&dev->lock);
clean_req (dev->gadget->ep0, dev->req); clean_req (dev->gadget->ep0, dev->req);
spin_unlock_irq (&dev->lock);
} else } else
retval = len; retval = len;
......
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