Received: by 2002:a25:7ec1:0:0:0:0:0 with SMTP id z184csp134945ybc; Mon, 18 Nov 2019 21:56:21 -0800 (PST) X-Google-Smtp-Source: APXvYqwQY+eh6vRxRu91KONkqhUhNR5yHlwVboxZBoTWE998/Kn6s3Xjf/PWZQ1nzW2QKt/0DcLK X-Received: by 2002:a17:906:6dc2:: with SMTP id j2mr20077197ejt.140.1574142981105; Mon, 18 Nov 2019 21:56:21 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574142981; cv=none; d=google.com; s=arc-20160816; b=amBTt5U6Kl7ob5QH/U3BZU2yhOhsS1NqYeulHiMoNaHsiFY02kNnpQFhnFdu3sMuEu vfoVK6qXBGqY3cDIdNY6za6WCuIxa88Ou7+b2hqV9hdcAT4kklmDnu2Zwdqc2hFsMMP1 l55IoAuhC2LKqKaKjjHJ5LDsD9rvW4uxOJIPeL+gCO3ypzBqUeJlrLQ+bRsjy8oIeCbA yV0/HU9Car2XxnAsp2sd+MBqZS1BVEYMFYs7n8dfXRmlng9emw9UYqPWAYxA8o97l8r1 N2x3EllFKDEKajNIymqTsa3LzUtxnaDB/ijwG5q7zPLk0WDJTKMSLq+/DAlaFeeJ1O/K Ghow== 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=W//6+7Gbn460Ea5Qwy9bs8NJqt3mpzk/a31q+kmMy6A=; b=lslxQcQ3Xb25UveQ5YgFgeZbQ1mx4QDKaAJyQS0flXYkgc3HPTx+yLFKDc0gsisXyN +vGdj5074pVSqhh81MwPC0XLkGpRR3U9qm5brHqpohdY7XPQgSaCHwc9+DMGxtOv+QJb r9vYlS8TTT1kfIn2lDbgYWBZvDpmlmaKCNBwhNYofJRZWnyfu4oE2tJjJbHX3J0JenfY C15MGTpjhM9xurr91Gsz5c1tsztlMt53Im4jEn3iMfLZYRcP1ay7hhJTtg+0h75ooY9p FY65bLRSOI3WFxcO2PGo2OuoZ5MczEEKHAUS5j306KUBAmogMe/e7ToSkNFJWeP/l7mJ W/Hg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=twaL67y8; 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 w15si12663097ejb.226.2019.11.18.21.55.56; Mon, 18 Nov 2019 21:56:21 -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=twaL67y8; 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 S1731933AbfKSFwl (ORCPT + 99 others); Tue, 19 Nov 2019 00:52:41 -0500 Received: from mail.kernel.org ([198.145.29.99]:50442 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731596AbfKSFwj (ORCPT ); Tue, 19 Nov 2019 00:52:39 -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 37DAB20862; Tue, 19 Nov 2019 05:52:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1574142758; bh=OQxAjtgjoRmh71w/KKY3w4GztgCDEsVjgMRHOe26tms=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=twaL67y8LceUitYMheaLJQU4zJMtDfGQSaT/bIB2H/FwJddSzpQI6eAyGqYRgezhx J9+iFUlUMRHAF1m0tVOcz0xNTvaFUeDGnik3rcN7MxBC7OZWN4PN/b6HO6M2GuCIbN 0LvAxjOM8hTz/vfRYUszJbXVRhbfKt3q6jl7f+Ew= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Laurent Pinchart , Paul Elder , Kieran Bingham , Sasha Levin Subject: [PATCH 4.14 190/239] usb: gadget: uvc: Only halt video streaming endpoint in bulk mode Date: Tue, 19 Nov 2019 06:19:50 +0100 Message-Id: <20191119051335.493931245@linuxfoundation.org> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191119051255.850204959@linuxfoundation.org> References: <20191119051255.850204959@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: Laurent Pinchart [ Upstream commit 8dbf9c7abefd5c1434a956d5c6b25e11183061a3 ] When USB requests for video data fail to be submitted, the driver signals a problem to the host by halting the video streaming endpoint. This is only valid in bulk mode, as isochronous transfers have no handshake phase and can't thus report a stall. The usb_ep_set_halt() call returns an error when using isochronous endpoints, which we happily ignore, but some UDCs complain in the kernel log. Fix this by only trying to halt the endpoint in bulk mode. Signed-off-by: Laurent Pinchart Reviewed-by: Paul Elder Tested-by: Paul Elder Reviewed-by: Kieran Bingham Signed-off-by: Sasha Levin --- drivers/usb/gadget/function/uvc_video.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/usb/gadget/function/uvc_video.c b/drivers/usb/gadget/function/uvc_video.c index 540917f54506a..d6bab12b0b47d 100644 --- a/drivers/usb/gadget/function/uvc_video.c +++ b/drivers/usb/gadget/function/uvc_video.c @@ -136,7 +136,9 @@ static int uvcg_video_ep_queue(struct uvc_video *video, struct usb_request *req) ret = usb_ep_queue(video->ep, req, GFP_ATOMIC); if (ret < 0) { printk(KERN_INFO "Failed to queue request (%d).\n", ret); - usb_ep_set_halt(video->ep); + /* Isochronous endpoints can't be halted. */ + if (usb_endpoint_xfer_bulk(video->ep->desc)) + usb_ep_set_halt(video->ep); } return ret; -- 2.20.1