Received: by 2002:ab2:1149:0:b0:1f3:1f8c:d0c6 with SMTP id z9csp3054165lqz; Wed, 3 Apr 2024 17:33:07 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCV5URm5EdcYEcmTbledxTLuFp6qRP51IbO1vMShP11N7lgQIEeq69R4I2bru7wx9pjOkYIKCiEY1F2B1WSkEdMVOL6zQilkbmxLblHMwA== X-Google-Smtp-Source: AGHT+IHQDqcH9Rc6o1arOSP2a6RyAVYCdTGAQqhyv7/Of30y2UIuNy6iHW448tYVulCn0WiRJunj X-Received: by 2002:a05:6a00:8cf:b0:6ea:c2c7:5d6a with SMTP id s15-20020a056a0008cf00b006eac2c75d6amr1281364pfu.2.1712190787220; Wed, 03 Apr 2024 17:33:07 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1712190787; cv=pass; d=google.com; s=arc-20160816; b=PDlGyFKhZICN6TgI/nYeRGHDn5u2PBoJ/ipRdmYqhDGkbCFPpF6PpYQMDeduA4qqWK OBk0Of1EYVGjRc6M71iaRpUMeIFmuQ3iGFGpSLh5MbamYSy3MZL7uJBL7IIEO0l6XOQB lr6N1+rGlQQpwlCOJmfzbp+REMWJdj9lzu1pNUcGFyh5P3xza2gKvdsbIx1WeUExjHRC ZtdgMr/9XY8xX7rcF1UBh9Kad6ZMVTsS/z583PKtMrBj21+7iUEK0UwNFc9PZszeSyh3 +X71GldpySbrMhWgL7qyhFQQeHKExHeIc1OsoiNs7PVFh9z7g+L6WnyDUTNNQVcCiqm2 kGcw== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=in-reply-to:content-disposition:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:message-id:subject:cc :to:from:date:dkim-signature; bh=CPGX7LSq4qRJADNqQ6VAZySp2IL5EXnxJTUk1MoFlT0=; fh=5W3Ast8xixuAvUfeeseuCkNp3YI2AiDmGM/3PCTP9aw=; b=lYc12PTKfPuEjqQbvHcWD0Dv568bqRDRA+CDFiV7dWfVV5yCtJI245WluLu97dfQkU TcVA6IoDgsVhdnlB8Y0CoawoZrJo6LbmNBL2tMyrOEs1qwFhqreBju0CaRufwBr5TMbt /mG3GaJ5bjOzOq/r0BTwRniNm7i2ypHTWFvwB1TctY90uOezlEEdvw1NqxYthvX5YSZ8 +VufJYDlcGro1MzWMMxnEeUuCEIHIWJDTXO5C0YNTrhjtNRstxSq+ajfxNruWC0Exef0 URifaS8hKuVmZiatJ6eIGBH5/UOjzJtlqsgnp//VLwk8jl0tMHX/URmW1NbIoslecn7m 00ww==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=lKtE8no3; arc=pass (i=1 spf=pass spfdomain=ideasonboard.com dkim=pass dkdomain=ideasonboard.com); spf=pass (google.com: domain of linux-kernel+bounces-130788-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-130788-linux.lists.archive=gmail.com@vger.kernel.org" Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id h11-20020a056a00000b00b006e6cc8f90f5si13634396pfk.274.2024.04.03.17.33.06 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 03 Apr 2024 17:33:07 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-130788-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=lKtE8no3; arc=pass (i=1 spf=pass spfdomain=ideasonboard.com dkim=pass dkdomain=ideasonboard.com); spf=pass (google.com: domain of linux-kernel+bounces-130788-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-130788-linux.lists.archive=gmail.com@vger.kernel.org" Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id DB0EE287603 for ; Thu, 4 Apr 2024 00:33:06 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id B64C8BE5E; Thu, 4 Apr 2024 00:32:52 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=ideasonboard.com header.i=@ideasonboard.com header.b="lKtE8no3" Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [213.167.242.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id F409423CE; Thu, 4 Apr 2024 00:32:49 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=213.167.242.64 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712190771; cv=none; b=iltiJ2cETMJ6NrOfVA7TRWm8PxuCV/cs0m9qubT25EmLVlPSlFpsW6ZtSSbxgw+bewKKsgrunoSbfIXP/6jbpGMtYirqs4GQs1sDYR9nq24Lwkhkp68VtFDz2WaA9FV9WgUTYrDN+bCzgBApH4Rjz9vrE9Sg1Gov0XcgNTyp8Po= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712190771; c=relaxed/simple; bh=v6ELGC0wWuhzAcp7TF7tSfRbebnHs2P8lRKexVxuir4=; h=Date:From:To:Cc:Subject:Message-ID:References:MIME-Version: Content-Type:Content-Disposition:In-Reply-To; b=nZjLr3Q68DVqlkv9G+uBargNpmM0tyJCzj+G1t8Qw8FlTWGyqsaX+TdQTtt8BedDE9gOtVvM/78y3+bklqi8AvVXMXw002hksupYejFkPntxwEhUB48OdCHsLF9Wwi3sDwYmOHWTPdMQyRwM/nKn9CnWYmVmpDevwBDnBH5+bFE= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=ideasonboard.com; spf=pass smtp.mailfrom=ideasonboard.com; dkim=pass (1024-bit key) header.d=ideasonboard.com header.i=@ideasonboard.com header.b=lKtE8no3; arc=none smtp.client-ip=213.167.242.64 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=ideasonboard.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=ideasonboard.com Received: from pendragon.ideasonboard.com (81-175-209-231.bb.dnainternet.fi [81.175.209.231]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 83ED5CCC; Thu, 4 Apr 2024 02:32:10 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1712190730; bh=v6ELGC0wWuhzAcp7TF7tSfRbebnHs2P8lRKexVxuir4=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=lKtE8no3H6w862RIl8SSijlaCBm4Rhdr+FVHmYpPNYT9yV4AXVedYzvjniRQsujMP 0eg+kpZavOg5jYrBp7mOBkXG23aXFyDkg1jY3jReEQtPPqoonFtPCHP2t0CMZkOjXO mCFby0GhUHfZO0x8va4VjW3PpdZPnj/3i7wbCoDw= Date: Thu, 4 Apr 2024 03:32:37 +0300 From: Laurent Pinchart To: Ricardo Ribalda Cc: Greg Kroah-Hartman , Alan Stern , Mauro Carvalho Chehab , linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, linux-media@vger.kernel.org, stable@vger.kernel.org, Oliver Neukum , Devinder Khroad , Sergey Senozhatsky Subject: Re: [PATCH v5] media: ucvideo: Add quirk for Logitech Rally Bar Message-ID: <20240404003237.GE23803@pendragon.ideasonboard.com> References: <20240402-rallybar-v5-1-7bdd0fbc51f7@chromium.org> <20240404003055.GD23803@pendragon.ideasonboard.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20240404003055.GD23803@pendragon.ideasonboard.com> One more thing, s/ucvideo/uvcvideo/ in the subject line. On Thu, Apr 04, 2024 at 03:30:57AM +0300, Laurent Pinchart wrote: > Hi Ricardo, > > Thank you for the patch. > > On Tue, Apr 02, 2024 at 12:09:29PM +0000, Ricardo Ribalda wrote: > > Logitech Rally Bar devices, despite behaving as UVC cameras, have a > > different power management system that the other cameras from Logitech. > > > > USB_QUIRK_RESET_RESUME is applied to all the UVC cameras from Logitech > > at the usb core. Unfortunately, USB_QUIRK_RESET_RESUME causes undesired > > USB disconnects in the Rally Bar that make them completely unusable. > > > > There is an open discussion about if we should fix this in the core or > > add a quirk in the UVC driver. In order to enable this hardware, let's > > land this patch first, and we can revert it later if there is a > > different conclusion. > > > > Fixes: e387ef5c47dd ("usb: Add USB_QUIRK_RESET_RESUME for all Logitech UVC webcams") > > Cc: > > Cc: Greg Kroah-Hartman > > Cc: Alan Stern > > Cc: Oliver Neukum > > Acked-by: Greg Kroah-Hartman > > Reviewed-by: Devinder Khroad > > Reviewed-by: Sergey Senozhatsky > > Reviewed-by: Laurent Pinchart > > Signed-off-by: Ricardo Ribalda > > --- > > Tested with a Rallybar Mini with an Acer Chromebook Spin 513 > > --- > > Changes in v5: > > - Update commit message to describe that this is a temp solution. > > - Link to v4: https://lore.kernel.org/r/20240108-rallybar-v4-1-a7450641e41b@chromium.org > > > > Changes in v4: > > - Include Logi Rally Bar Huddle (Thanks Kyle!) > > - Link to v3: https://lore.kernel.org/r/20240102-rallybar-v3-1-0ab197ce4aa2@chromium.org > > > > Changes in v3: > > - Move quirk to uvc driver > > - Link to v2: https://lore.kernel.org/r/20231222-rallybar-v2-1-5849d62a9514@chromium.org > > > > Changes in v2: > > - Add Fixes tag > > - Add UVC maintainer as Cc > > - Link to v1: https://lore.kernel.org/r/20231222-rallybar-v1-1-82b2a4d3106f@chromium.org > > --- > > drivers/media/usb/uvc/uvc_driver.c | 30 ++++++++++++++++++++++++++++++ > > drivers/media/usb/uvc/uvcvideo.h | 1 + > > 2 files changed, 31 insertions(+) > > > > diff --git a/drivers/media/usb/uvc/uvc_driver.c b/drivers/media/usb/uvc/uvc_driver.c > > index 08fcd2ffa727b..9663bcac68438 100644 > > --- a/drivers/media/usb/uvc/uvc_driver.c > > +++ b/drivers/media/usb/uvc/uvc_driver.c > > @@ -14,6 +14,7 @@ > > #include > > #include > > #include > > +#include > > #include > > #include > > #include > > @@ -2233,6 +2234,8 @@ static int uvc_probe(struct usb_interface *intf, > > } > > > > uvc_dbg(dev, PROBE, "UVC device initialized\n"); > > + if (dev->quirks & UVC_QUIRK_FORCE_RESUME) > > The quirk isn't really about forcing resume, but about not resetting on > resume. Can we name it UVC_QUIRK_NO_RESET_RESUME ? > > > + udev->quirks &= ~USB_QUIRK_RESET_RESUME; > > Let's move this before the uvc_dbg(). > > With that, the patch looks good to me. I can apply those changes > locally if you don't want to submit a v6. > > > usb_enable_autosuspend(udev); > > return 0; > > > > @@ -2574,6 +2577,33 @@ static const struct usb_device_id uvc_ids[] = { > > .bInterfaceSubClass = 1, > > .bInterfaceProtocol = 0, > > .driver_info = UVC_INFO_QUIRK(UVC_QUIRK_RESTORE_CTRLS_ON_INIT) }, > > + /* Logitech Rally Bar Huddle */ > > + { .match_flags = USB_DEVICE_ID_MATCH_DEVICE > > + | USB_DEVICE_ID_MATCH_INT_INFO, > > + .idVendor = 0x046d, > > + .idProduct = 0x087c, > > + .bInterfaceClass = USB_CLASS_VIDEO, > > + .bInterfaceSubClass = 1, > > + .bInterfaceProtocol = 0, > > + .driver_info = UVC_INFO_QUIRK(UVC_QUIRK_FORCE_RESUME) }, > > + /* Logitech Rally Bar */ > > + { .match_flags = USB_DEVICE_ID_MATCH_DEVICE > > + | USB_DEVICE_ID_MATCH_INT_INFO, > > + .idVendor = 0x046d, > > + .idProduct = 0x089b, > > + .bInterfaceClass = USB_CLASS_VIDEO, > > + .bInterfaceSubClass = 1, > > + .bInterfaceProtocol = 0, > > + .driver_info = UVC_INFO_QUIRK(UVC_QUIRK_FORCE_RESUME) }, > > + /* Logitech Rally Bar Mini */ > > + { .match_flags = USB_DEVICE_ID_MATCH_DEVICE > > + | USB_DEVICE_ID_MATCH_INT_INFO, > > + .idVendor = 0x046d, > > + .idProduct = 0x08d3, > > + .bInterfaceClass = USB_CLASS_VIDEO, > > + .bInterfaceSubClass = 1, > > + .bInterfaceProtocol = 0, > > + .driver_info = UVC_INFO_QUIRK(UVC_QUIRK_FORCE_RESUME) }, > > /* Chicony CNF7129 (Asus EEE 100HE) */ > > { .match_flags = USB_DEVICE_ID_MATCH_DEVICE > > | USB_DEVICE_ID_MATCH_INT_INFO, > > diff --git a/drivers/media/usb/uvc/uvcvideo.h b/drivers/media/usb/uvc/uvcvideo.h > > index 6fb0a78b1b009..fa59a21d2a289 100644 > > --- a/drivers/media/usb/uvc/uvcvideo.h > > +++ b/drivers/media/usb/uvc/uvcvideo.h > > @@ -73,6 +73,7 @@ > > #define UVC_QUIRK_FORCE_Y8 0x00000800 > > #define UVC_QUIRK_FORCE_BPP 0x00001000 > > #define UVC_QUIRK_WAKE_AUTOSUSPEND 0x00002000 > > +#define UVC_QUIRK_FORCE_RESUME 0x00004000 > > > > /* Format flags */ > > #define UVC_FMT_FLAG_COMPRESSED 0x00000001 > > > > --- > > base-commit: c0f65a7c112b3cfa691cead54bcf24d6cc2182b5 > > change-id: 20231222-rallybar-19ce0c64d5e6 > > -- > Regards, > > Laurent Pinchart -- Regards, Laurent Pinchart