]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
usb: gadget: Fix double free of device descriptor pointers
authorHemant Kumar <hemantk@codeaurora.org>
Wed, 21 Apr 2021 19:47:32 +0000 (12:47 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 22 Apr 2021 06:57:48 +0000 (08:57 +0200)
Upon driver unbind usb_free_all_descriptors() function frees all
speed descriptor pointers without setting them to NULL. In case
gadget speed changes (i.e from super speed plus to super speed)
after driver unbind only upto super speed descriptor pointers get
populated. Super speed plus desc still holds the stale (already
freed) pointer. Fix this issue by setting all descriptor pointers
to NULL after freeing them in usb_free_all_descriptors().

Fixes: f5c61225cf29 ("usb: gadget: Update function for SuperSpeedPlus")
cc: stable@vger.kernel.org
Reviewed-by: Peter Chen <peter.chen@kernel.org>
Signed-off-by: Hemant Kumar <hemantk@codeaurora.org>
Signed-off-by: Wesley Cheng <wcheng@codeaurora.org>
Link: https://lore.kernel.org/r/1619034452-17334-1-git-send-email-wcheng@codeaurora.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/gadget/config.c

index 2d115353424c2cb073d07251f67a574a4407188e..8bb25773b61e91e83ee5a48fefe25a1566418640 100644 (file)
@@ -194,9 +194,13 @@ EXPORT_SYMBOL_GPL(usb_assign_descriptors);
 void usb_free_all_descriptors(struct usb_function *f)
 {
        usb_free_descriptors(f->fs_descriptors);
+       f->fs_descriptors = NULL;
        usb_free_descriptors(f->hs_descriptors);
+       f->hs_descriptors = NULL;
        usb_free_descriptors(f->ss_descriptors);
+       f->ss_descriptors = NULL;
        usb_free_descriptors(f->ssp_descriptors);
+       f->ssp_descriptors = NULL;
 }
 EXPORT_SYMBOL_GPL(usb_free_all_descriptors);