]> git.itanic.dy.fi Git - linux-stable/commitdiff
gadgetfs: ep_io - wait until IRQ finishes
authorJozef Martiniak <jomajm@gmail.com>
Fri, 8 Jul 2022 07:06:44 +0000 (09:06 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 25 Aug 2022 09:38:15 +0000 (11:38 +0200)
[ Upstream commit 04cb742d4d8f30dc2e83b46ac317eec09191c68e ]

after usb_ep_queue() if wait_for_completion_interruptible() is
interrupted we need to wait until IRQ gets finished.

Otherwise complete() from epio_complete() can corrupt stack.

Signed-off-by: Jozef Martiniak <jomajm@gmail.com>
Link: https://lore.kernel.org/r/20220708070645.6130-1-jomajm@gmail.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/usb/gadget/legacy/inode.c

index 454860d52ce77f96b3ea047d37e90da6dc289fe0..cd097474b6c39f8df44f2685c8330aea44f3eeaf 100644 (file)
@@ -362,6 +362,7 @@ ep_io (struct ep_data *epdata, void *buf, unsigned len)
                                spin_unlock_irq (&epdata->dev->lock);
 
                                DBG (epdata->dev, "endpoint gone\n");
+                               wait_for_completion(&done);
                                epdata->status = -ENODEV;
                        }
                }