Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2521377pxj; Mon, 10 May 2021 05:07:02 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxp/s6wfkMLmzOwyGVdln/WqLfI0gW3XkBdq5vlTRAVR9YpOi8WxwZ1loqT31mE5QPfC0Jn X-Received: by 2002:a05:6638:b14:: with SMTP id a20mr21325330jab.132.1620648325960; Mon, 10 May 2021 05:05:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620648325; cv=none; d=google.com; s=arc-20160816; b=tbJwKBHfWZTuWHAsCCAjxEbt6mXkH58FrpG/HxMgHUB+2YeunRVbc3r8Yed2HJulTp PNaFAv1u/kDJHB02QAoiUI15FSzlIt06BVDwcfTcz17atHdGdT53SNWO8Tsyi2nhA0aD 7ohy2d5nDYg/8vfvbHBen35p/xzXE4VRXDOJuGRdRx2iLVHT8cYmbTxg68i45VlClrRH XoItq4+c2AuO0vreToJL+eTq8wIp/LPjRGvUJ/UMptFBRTy0fKR0OdOLtcM3/0VFt36l AsxadRnA67aztcykrXRH4PMnYIam5W0006pJsgOSPdTHBfz1c+Q1zI5vp8Rp5B4EQ0ij q0UA== 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=MuBqZTLtDJN6ADfGGPMRaGLRSqgQQsH0zaRZlD5TVjdbzq+dHvUlneQV3Wqs7J0fUa 6CIPj1JDQoRZWYrR7u2p98nZCLPiQ/vkB2bG06f7/7VrWEP1oSc/FKN6+K4nzjUB0Vp6 uOUD/eZeLJYwQEm0OUsLww1XbNBbzQn8lnCna+PCFbDBj9YSnBXltNXBSExheIymR/D+ o5GINvzA63WMnkYk1k1ZQ5LYP+f/fXS9nzI/LrRj6+dKPmQfaYp72z0erGAud3VGmIut CVQaNxhPW3F4Sa6uM3VAXOpj54VBF62Hgz4TwriDFZJwHVTlmzPkE2zrv8ktYoz17Yo8 5hVg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=qSrm0c4G; 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 o8si15319459ilu.133.2021.05.10.05.05.12; Mon, 10 May 2021 05:05:25 -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=qSrm0c4G; 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 S244632AbhEJL7l (ORCPT + 99 others); Mon, 10 May 2021 07:59:41 -0400 Received: from mail.kernel.org ([198.145.29.99]:46276 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235956AbhEJLHE (ORCPT ); Mon, 10 May 2021 07:07:04 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 4BBEB61971; Mon, 10 May 2021 10:57:10 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620644230; bh=xYtFkeN39Orcq0WeEDTUJpCePQ2GI+uIcpy5yH+7+II=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=qSrm0c4GyCtgwygApo5WkY+sSgmtFfmmC+zUqGIXZXMNmjsjw3M0rWtQmSD86wrYF 73IEB8E80CUEuU5quGOzxs9udAdD33D4rwmoEDzNoSn/ncXDmds32OxY9ITnAjTKFr Gdrn8EjMT/7XkK1eNFHOILT7mGixXiTL3filcuTg= 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.11 323/342] usb: gadget: Fix double free of device descriptor pointers Date: Mon, 10 May 2021 12:21:53 +0200 Message-Id: <20210510102020.787064356@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210510102010.096403571@linuxfoundation.org> References: <20210510102010.096403571@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);