Received: by 2002:a17:90a:88:0:0:0:0 with SMTP id a8csp14509pja; Fri, 22 Nov 2019 02:49:42 -0800 (PST) X-Google-Smtp-Source: APXvYqxXsbY3uGlHKmn+j0Nat+tW9Et/8ReRZQPMx78YDUXcu8E92cmX9xuFhJXUhJOH2btGIznP X-Received: by 2002:aa7:cdc6:: with SMTP id h6mr243775edw.15.1574419782207; Fri, 22 Nov 2019 02:49:42 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574419782; cv=none; d=google.com; s=arc-20160816; b=jIPF8IrSTCq+kFCTnq543y7lahotS35rE8bQDOUxHVAxjh/0uCPCfJbRVbQVKb+TjK Nw9vKXflGh0vr0ehbdKeHBQ7yNFaHFjKm4M3Pq3MWZ8KDuCjjENT1EnPKZGPP+gg+gM1 Jk9LaBKgDF8l2rD7O9GlF7SEkq795NDqC39kOu99xFhpkHzhvervPz52Ejt/SmaUCD1U 6AkOVmYKd/sgaIHuzyDJvZCXnOAMCcFpquQdWDSKIicuKzbPU06s4K4NLz8BH0gRoBHV cNGgc6XNu2uoB9ZkThHAlt3ARnOS/BEGUnR8puWIyVLPaO4lGa1oZIbs5Ff8W3s3M1FU hUxg== 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=tjSi4KtoizowMmUzcN3reAU+jspfk4ZNC7IaCpdKoNd/uyQCkUrLDkO7Tyl1LYOz8u 6BRn//IQyDTs1AleptLRio0dTyUS7Ie/QEGph9ZBGhSBIQbBQ152zMJyVqIK0mt6iPpp /oiJLfRvXdoio5A3U8vpco2By6p6grfNxJLF9/C6d7ZnsSgMHV/5IMZOHPZmdkKB0zov TgIWViTTLr307rmKr0sZoug/FVnAZMtVgxAqLiFaB5jxIGyLz+PPIjzcwFZlgA9tGRks yXKv5KLAqqsKm+l8kkoKNAmshfmEe59N+uLR4JqfvecSwqIqsl7x2ektfXUt4noimUop tUuA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=n9R6QCPk; 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 p38si1184379edc.163.2019.11.22.02.49.17; Fri, 22 Nov 2019 02:49:42 -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=n9R6QCPk; 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 S1729684AbfKVKqt (ORCPT + 99 others); Fri, 22 Nov 2019 05:46:49 -0500 Received: from mail.kernel.org ([198.145.29.99]:54154 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729681AbfKVKqq (ORCPT ); Fri, 22 Nov 2019 05:46:46 -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 D605D2071C; Fri, 22 Nov 2019 10:46:45 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1574419606; bh=OQxAjtgjoRmh71w/KKY3w4GztgCDEsVjgMRHOe26tms=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=n9R6QCPktLIEbyCYBtXRfNS9ZNSlsTy5/QldgIxCMpofzeN0kffpdg2PQW19t5O/t i5v/8U0802xTqQ8xAd/0i47orLTNWi94LbzUpSSwBqHHhwu/WTPDQ0rxrcXE8LJ+FC 4Kgsoy6zNC5OiqrMzR6djeEO7LFdaVXfG/9ned9Q= 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.9 116/222] usb: gadget: uvc: Only halt video streaming endpoint in bulk mode Date: Fri, 22 Nov 2019 11:27:36 +0100 Message-Id: <20191122100911.549322410@linuxfoundation.org> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191122100830.874290814@linuxfoundation.org> References: <20191122100830.874290814@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