Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp2982301ybk; Mon, 18 May 2020 12:45:55 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyhxha/PDnTg/Nw3xBpX9B7ObOi8XeDvrqvvUN14e+VuqLiWXuaBwGTTgkJNGVWxkQeSiKd X-Received: by 2002:a17:906:46d3:: with SMTP id k19mr15975670ejs.349.1589831155128; Mon, 18 May 2020 12:45:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1589831155; cv=none; d=google.com; s=arc-20160816; b=oseg0SwbYf93MHpjXQyQAja5KHOEnCEkgms88lW709gQFDhjk2mR4cRm67g1WoG1tg vvow5AZTN+Up2XYN4+QUGU6pMpJ+4XiGV0SARuib3B8TCxa6anx75U0KHOmOl5FaWbY3 J68CbXe200OnRPvSGXsoy+HrSlY5PdZ3CtrE0T4nJKuTfDrEvdHBBka4HX4IHZR3OKlf TMnMG7p3Za9AUWJerxmgyU+YDeQjR6dxImFLiHGE2qoc0qO/0izjYC397DVZ/KRyxkjS 5Lp7oebFSOUo008TFFI7tYwDqsaDIQNPzsCb93DbkCopI3oL+oZqKdBFyLAaeyiyQZq8 JcPA== 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=FDhbIOqMuDR2kKhCHcGgfow+4itn4IOXJACtNZ8FGJ0=; b=K/UdESI4zG6hj/LJhONY4y60Imcepm99p3+Z1YK55eWr7zuCEAP/u5aP/nFZSNCvYv o/7ezGAP5468QoT01MQOU5WsyaO0Nr2SsfC6sgRGjRwaych3fgawX0nAv540M/9Xy1gc PZcwYVdo23Lw8Gp45QaKLpRmCoaboBua8PAAFXkvokeyNl5z8fBnS0+yMRBE7gKtXqdX 9vCyM9u4rigOq0o8SG9dOTNEOpb8xHkCHMFNvrm78X2+aSgYtgfZjPhSD0LgsRlxrtVa JzezUFSeImTl234CD0GV9w/eGgMjcxQLAMrZKBJKer2y9FYXITf9eIiI05ysHX4v5efp eMQg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=BNtWEXTI; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bx1si863688edb.573.2020.05.18.12.45.30; Mon, 18 May 2020 12:45:55 -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=@kernel.org header.s=default header.b=BNtWEXTI; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733110AbgERSJY (ORCPT + 99 others); Mon, 18 May 2020 14:09:24 -0400 Received: from mail.kernel.org ([198.145.29.99]:54900 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1733195AbgERSGk (ORCPT ); Mon, 18 May 2020 14:06:40 -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 17850207D3; Mon, 18 May 2020 18:06:39 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1589825199; bh=jEGs5cCX+TotOoxBhZ01jg/PVeC8CitSbGIkzwa184g=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=BNtWEXTIPo4iiRQsaWAtNGLWcMeho4DRvxnwhKc7/UwToTYCwo3zArAUsBIBFPNik 1mR91hWEQwCskoU+ZYSauI9JPxcJyCzamiq+ET1O7hq610I2C6g6F46TX4t2QCjTFN UUy2VYJku+awP6nBfOGxwourHtp1qI3+RLTgwQVc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, YongQin Liu , Anurag Kumar Vulisha , Yang Fei , Thinh Nguyen , Tejas Joglekar , Andrzej Pietrasiewicz , Jack Pham , Josh Gao , Todd Kjos , Felipe Balbi , linux-usb@vger.kernel.org, John Stultz Subject: [PATCH 5.6 162/194] dwc3: Remove check for HWO flag in dwc3_gadget_ep_reclaim_trb_sg() Date: Mon, 18 May 2020 19:37:32 +0200 Message-Id: <20200518173544.709413214@linuxfoundation.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200518173531.455604187@linuxfoundation.org> References: <20200518173531.455604187@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: John Stultz commit 00e21763f2c8cab21b7befa52996d1b18bde5c42 upstream. The check for the HWO flag in dwc3_gadget_ep_reclaim_trb_sg() causes us to break out of the loop before we call dwc3_gadget_ep_reclaim_completed_trb(), which is what likely should be clearing the HWO flag. This can cause odd behavior where we never reclaim all the trbs in the sg list, so we never call giveback on a usb req, and that will causes transfer stalls. This effectively resovles the adb stalls seen on HiKey960 after userland changes started only using AIO in adbd. Cc: YongQin Liu Cc: Anurag Kumar Vulisha Cc: Yang Fei Cc: Thinh Nguyen Cc: Tejas Joglekar Cc: Andrzej Pietrasiewicz Cc: Jack Pham Cc: Josh Gao Cc: Todd Kjos Cc: Felipe Balbi Cc: Greg Kroah-Hartman Cc: linux-usb@vger.kernel.org Cc: stable@vger.kernel.org #4.20+ 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, 3 deletions(-) --- a/drivers/usb/dwc3/gadget.c +++ b/drivers/usb/dwc3/gadget.c @@ -2483,9 +2483,6 @@ static int dwc3_gadget_ep_reclaim_trb_sg for_each_sg(sg, s, pending, i) { trb = &dep->trb_pool[dep->trb_dequeue]; - if (trb->ctrl & DWC3_TRB_CTRL_HWO) - break; - req->sg = sg_next(s); req->num_pending_sgs--;