Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp1517969ybb; Sat, 11 Apr 2020 05:28:48 -0700 (PDT) X-Google-Smtp-Source: APiQypLmRIVosIW2wgGKkv4X07sd0FUnABJCIpCOWu7ktWxC1q787gpS7t2FdDMYtcM6T+brxHYZ X-Received: by 2002:ac8:554a:: with SMTP id o10mr3467041qtr.221.1586608127873; Sat, 11 Apr 2020 05:28:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586608127; cv=none; d=google.com; s=arc-20160816; b=kc0vRIofWZkuZpkqAtALqSTpmiCGAD+3SarCSElpxn7dUWISHVigu3vtrKrz4k8xGQ 11zvtANVIy6r96yFN6+oDaq/RLQm4xIWfX98tnSsMeN/vOxYSQQmEUi4bx7fnaeRzlHG SRuxRQ6vImipfigxoQDdChlP5GyL1/kBpy5413S96iTFWkWRE2ZyrwfGA1DLuX+nGMKl +Vc4eoXJyj3kiWqsq/rLIkN1H80WglKsifqHRT6PKNX6haamycjE1ChwwWg7vVop/FP5 yF1TP7A+tiNP2bN71WVB3mw8726MTiLQjUNQ+0T+L+B4NOtlrg5aDFhGyLKgZfIsyw7L sklg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=WhdX6yTtJXwSbIGuZm2OWiUsg7pLxZV8ZfXzEzYcsz4=; b=ofgLQRgm/k9APL+xOsGHWIGPBXh7Yf7Jrn0kJ2EPHj5xNyznpNbMpfgfqLfX5FZTdE EErZsASrPETJSCLCRWguj9h2H+SB7yDRVaYQ/f6FtmtCzHZuULrb9NulPnJnCFH/POxf fECNKskUiAI8e5o/TuvppgJ/gd0Hrl0KEEgIvJ2oRenoriCLw/s3zu8309DgwF/az38a piD9Ob43fTqgRreg28w0Key7MFEVe1l74cEFxSzqayuk+H3lrUeNc6b8UQb3pWuzQLaS iH9TJ3b4Eijtpf6MlcNJIuUICYw82Cp2l3UpXvOx5LcsRGFJgLVWXmRNCEK49BeAsLNc YO9Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=MabmURGB; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 18si3102354qkp.339.2020.04.11.05.28.34; Sat, 11 Apr 2020 05:28:47 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=MabmURGB; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726245AbgDKMPt (ORCPT + 99 others); Sat, 11 Apr 2020 08:15:49 -0400 Received: from mail.kernel.org ([198.145.29.99]:49850 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728184AbgDKMPq (ORCPT ); Sat, 11 Apr 2020 08:15:46 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 686D820644; Sat, 11 Apr 2020 12:15:46 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1586607346; bh=eDlxJIK+ajyAnrucoaBRW3ShFGqsrmf8FtcH3vNKYgc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=MabmURGBp/Mz2S0P6QWurpIWiOYQHg8GxL/9r+NuavWUIGXoF3D1KRUzrBf/tOt97 UgLoex0fGKsb7Q7+3vpkYXsq/S/KuGv3USz6iJW/wbam2qJhG8FA7xKA5nw/FQT4td JP/mhoR6z9WUWHy3v1/vGxk82JSMd0Ue7UXxQXmg= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Thinh Nguyen , Felipe Balbi Subject: [PATCH 4.19 36/54] usb: dwc3: gadget: Wrap around when skip TRBs Date: Sat, 11 Apr 2020 14:09:18 +0200 Message-Id: <20200411115512.087843119@linuxfoundation.org> X-Mailer: git-send-email 2.26.0 In-Reply-To: <20200411115508.284500414@linuxfoundation.org> References: <20200411115508.284500414@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Thinh Nguyen commit 2dedea035ae82c5af0595637a6eda4655532b21e upstream. When skipping TRBs, we need to account for wrapping around the ring buffer and not modifying some invalid TRBs. Without this fix, dwc3 won't be able to check for available TRBs. Cc: stable Fixes: 7746a8dfb3f9 ("usb: dwc3: gadget: extract dwc3_gadget_ep_skip_trbs()") Signed-off-by: Thinh Nguyen Signed-off-by: Felipe Balbi Signed-off-by: Greg Kroah-Hartman --- drivers/usb/dwc3/gadget.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) --- a/drivers/usb/dwc3/gadget.c +++ b/drivers/usb/dwc3/gadget.c @@ -1369,7 +1369,7 @@ static void dwc3_gadget_ep_skip_trbs(str for (i = 0; i < req->num_trbs; i++) { struct dwc3_trb *trb; - trb = req->trb + i; + trb = &dep->trb_pool[dep->trb_dequeue]; trb->ctrl &= ~DWC3_TRB_CTRL_HWO; dwc3_ep_inc_deq(dep); }