Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp1180717ybf; Thu, 27 Feb 2020 06:25:30 -0800 (PST) X-Google-Smtp-Source: APXvYqz3xiV05lsEEwDW+v5UBngtRrpEaEWQ9E9UZQsKJLuph1wpm8BMasvTLXGuGKBcEU6esYpY X-Received: by 2002:a54:4396:: with SMTP id u22mr3574564oiv.128.1582813530439; Thu, 27 Feb 2020 06:25:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582813530; cv=none; d=google.com; s=arc-20160816; b=S5iQhSb+hgSdeISdD15NuNEQsJwTJuJ3mtDb54eUx7Et5i2Lffoi3Jz9AaJgrNfbLF J3NbLTflKwKqKMHathvPvseNYZAsTaeDbxrsN98IEBXBV5PuMoQMFFiVE4gaeca6uZCT IEBZa8ca/CyCt8+VCvtHzDukjKKkAEKdVXs+9QGc3Q1bBPrRy/eyoyRhqHATAYQeXE64 yG7uNqxpNg0BHHylPl0lmdjwdAZgQIpNR5qB5ZTyS6VoRsSlxDS6dpVdDzc2SYZQrrMl 893zeXG4Xv0VXUgjngQICfrx6p5WfWPob+0j8fJ9XsFl/52F8B+UaWY9dDXx0kZyz36d gADA== 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=fewqWTnEyMMk7TI1Ahht1uc1mDuePhBJBaQSDreHYC4=; b=TEro936eVEC8+7jkGAEjz8bmKi5CQ6BfQzYKHcP95UH8fCucdqDkqCghnzx1RCIj5D 2ojxfdvjhuuD/Wut3lFQlYS7I0Fg5u7hNILVxw1AxDAqJgRC6+zenWEVnS5c2HC9xWyy P5azL6fqKvZLnKbz1omRaKlnwFiNtg4gTQU6uOGPuOO4FYiyyCTowq+uXkRb1C5nozyJ fGu+vIf5LpBakmHAEHRqa5YM1GyR6mevrsVXGTFdAuvZ3KRnp345vFJiMZcNYpT8caQO xMqzYoCzO0tauGNc33AxN3+IPWPIULtGJGL6rnXW32yq349MYKIVfWtmvKyFQ4kdHWq3 HT+A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=VaYxrrnU; 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 l19si1644214otp.4.2020.02.27.06.25.18; Thu, 27 Feb 2020 06:25:30 -0800 (PST) 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=VaYxrrnU; 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 S2388813AbgB0OOX (ORCPT + 99 others); Thu, 27 Feb 2020 09:14:23 -0500 Received: from mail.kernel.org ([198.145.29.99]:53462 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389105AbgB0OOT (ORCPT ); Thu, 27 Feb 2020 09:14:19 -0500 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 D740B24697; Thu, 27 Feb 2020 14:14:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1582812857; bh=Dqe8peYwQwuHYE4wE7HzqKcEV4TelEPWey30f3hiVvk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=VaYxrrnUVztyfLYJ/Dhq4e7af7CMcAnaCqrHofBQmf5YokhRNO1SHDERZ9kQgwzyK o8YYHlt0x+ztB4jTQQ3R+ZwCE/jdJxSqSGABOKb6SXjBz7egLUVzM/BbAiPNcrR8vx 9bc+7D0JlMDJIQMlYSQiSunSVkxeyBjk9eWoeteQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Felipe Balbi , Yang Fei , Thinh Nguyen , Tejas Joglekar , Andrzej Pietrasiewicz , Jack Pham , Todd Kjos , Linux USB List , Anurag Kumar Vulisha , John Stultz Subject: [PATCH 5.5 042/150] usb: dwc3: gadget: Check for IOC/LST bit in TRB->ctrl fields Date: Thu, 27 Feb 2020 14:36:19 +0100 Message-Id: <20200227132239.087998024@linuxfoundation.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200227132232.815448360@linuxfoundation.org> References: <20200227132232.815448360@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: Anurag Kumar Vulisha commit 5ee858975b13a9b40db00f456989a689fdbb296c upstream. The current code in dwc3_gadget_ep_reclaim_completed_trb() will check for IOC/LST bit in the event->status and returns if IOC/LST bit is set. This logic doesn't work if multiple TRBs are queued per request and the IOC/LST bit is set on the last TRB of that request. Consider an example where a queued request has multiple queued TRBs and IOC/LST bit is set only for the last TRB. In this case, the core generates XferComplete/XferInProgress events only for the last TRB (since IOC/LST are set only for the last TRB). As per the logic in dwc3_gadget_ep_reclaim_completed_trb() event->status is checked for IOC/LST bit and returns on the first TRB. This leaves the remaining TRBs left unhandled. Similarly, if the gadget function enqueues an unaligned request with sglist already in it, it should fail the same way, since we will append another TRB to something that already uses more than one TRB. To aviod this, this patch changes the code to check for IOC/LST bits in TRB->ctrl instead. At a practical level, this patch resolves USB transfer stalls seen with adb on dwc3 based HiKey960 after functionfs gadget added scatter-gather support around v4.20. Cc: Felipe Balbi Cc: Yang Fei Cc: Thinh Nguyen Cc: Tejas Joglekar Cc: Andrzej Pietrasiewicz Cc: Jack Pham Cc: Todd Kjos Cc: Greg KH Cc: Linux USB List Cc: stable Tested-by: Tejas Joglekar Reviewed-by: Thinh Nguyen Signed-off-by: Anurag Kumar Vulisha [jstultz: forward ported to mainline, reworded commit log, reworked to only check trb->ctrl as suggested by Felipe] Signed-off-by: John Stultz Signed-off-by: Felipe Balbi Signed-off-by: Greg Kroah-Hartman --- drivers/usb/dwc3/gadget.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) --- a/drivers/usb/dwc3/gadget.c +++ b/drivers/usb/dwc3/gadget.c @@ -2426,7 +2426,8 @@ static int dwc3_gadget_ep_reclaim_comple if (event->status & DEPEVT_STATUS_SHORT && !chain) return 1; - if (event->status & DEPEVT_STATUS_IOC) + if ((trb->ctrl & DWC3_TRB_CTRL_IOC) || + (trb->ctrl & DWC3_TRB_CTRL_LST)) return 1; return 0;