Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2468134pxj; Mon, 10 May 2021 03:50:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy7+nSiU6hM8iOMpa9lL70NzZ+8mr7tfLxGYsmiUP96Im4LC1IZnUA6cpQpXTveCYQpysZx X-Received: by 2002:a02:caa3:: with SMTP id e3mr20842368jap.57.1620643817675; Mon, 10 May 2021 03:50:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620643817; cv=none; d=google.com; s=arc-20160816; b=fRqwNUePskYt2t2sUn1uNGsVyFb0TGVmIDyww2Rmg41/G1MLof3LZUvxPW8Bc7j2Cl Ox2DG+n0EwELUmNacg/AS/PCzHO5xMOFso7ethCjlivG+LbpbN1tVsGNK0J4fAXNbJiy BkJsEd5qN117SUBsjPQ6pzIpj2ikZdmzgLRnunWxzEWfnsS1rDQrAIdOUpkN5lxBsQ3w EZGbv/Ia55dTiID2YN4l/tYz161/QHzPztYmGTIFdfaqCls4GawDGw9BVe979HYUbAJr 6wqAMPPLbDWq9BYe8jPgGq0+SSNJ9Fv4X8pIZnjB79EkAZL1PwKIQf/hFP50GUQOTWie 9XWg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=Q5Cbcl15b3Ju6cV26FVaXxiepfxn0x3YN/YrQ7Ehayg=; b=USuPMBa3J55UapTbdN5+2cjZ2NSTURTwKU54H41VTshRkpVebh+3y0VkxV7thm0wNO mzl/08h1ShRmg3FtqJiTBYJANcojCtQ3oFNhK7JxQys6y3cRZDFUDjj0WCdHEY22O+mc eYw+wzSdRLvCZ6fLqkG0nGcTbJg4rx0FYKILUujprCSJB/zAmyAV+J1++m0rZU/uXDhT j1JJPIg4tn4VaE+GGYonLeyBRGmhYDIMlbNbob63D6L3EGhd2lXW/ELiNM1uy2Ulcj2g xQcAzpuMs3u4ThoImEQlBWbn6dyHZjECGuntmt1XLGaHVYd0iiGOJdycvERKIH2QGVPa ozCg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=Seq59Jm6; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s11si15061419jaj.108.2021.05.10.03.50.05; Mon, 10 May 2021 03:50:17 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=Seq59Jm6; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233129AbhEJKth (ORCPT + 99 others); Mon, 10 May 2021 06:49:37 -0400 Received: from mail.kernel.org ([198.145.29.99]:48240 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232321AbhEJKjm (ORCPT ); Mon, 10 May 2021 06:39:42 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 24E2261952; Mon, 10 May 2021 10:30:28 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620642629; bh=xYtFkeN39Orcq0WeEDTUJpCePQ2GI+uIcpy5yH+7+II=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Seq59Jm6Z8pArmrZpGcCd98t6gTOZzDPBzqF+x8Bl/mzyAE1VTWaHU72XQJR/AKlD IuBtL06n3hTNB/BT39ZT1h3GJkbqa6dsvuejbe5Dloeq1hQTOIgyk0VuJMULU8FpTo MejnW0wfTJH7UtyRL8tRFZ9ff85mAqgufkC3ED2Q= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Peter Chen , Hemant Kumar , Wesley Cheng Subject: [PATCH 5.4 173/184] usb: gadget: Fix double free of device descriptor pointers Date: Mon, 10 May 2021 12:21:07 +0200 Message-Id: <20210510101955.793674771@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210510101950.200777181@linuxfoundation.org> References: <20210510101950.200777181@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Hemant Kumar commit 43c4cab006f55b6ca549dd1214e22f5965a8675f upstream. 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 Signed-off-by: Hemant Kumar Signed-off-by: Wesley Cheng Link: https://lore.kernel.org/r/1619034452-17334-1-git-send-email-wcheng@codeaurora.org Signed-off-by: Greg Kroah-Hartman --- drivers/usb/gadget/config.c | 4 ++++ 1 file changed, 4 insertions(+) --- a/drivers/usb/gadget/config.c +++ b/drivers/usb/gadget/config.c @@ -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);