Received: by 2002:ab2:1149:0:b0:1f3:1f8c:d0c6 with SMTP id z9csp2025744lqz; Tue, 2 Apr 2024 05:21:39 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWSyZYVZBWD4fbNogkaq4+hm3ziJ8lN/sZTXM1SrPsluTpz518NR49fH5+/wZS3Rm5S9KMceSJT3Kw7fNXu1xb15ilvPYLF3aN9QgR0hg== X-Google-Smtp-Source: AGHT+IG+H16el2q8GSoEuMVE+jSGVFniWbBm20nfv03SJDSxgQdKRLZd42JT3w8wKe5hHiGXfnvy X-Received: by 2002:a05:6a20:4a89:b0:1a6:b689:8c29 with SMTP id fn9-20020a056a204a8900b001a6b6898c29mr8547773pzb.61.1712060499324; Tue, 02 Apr 2024 05:21:39 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1712060499; cv=pass; d=google.com; s=arc-20160816; b=Bz3EOI+lGGjcoaJi3/bw4Y55ghshZrsMq2q9sLVmfY9JxPA4WGZWNdKuDQdpODq2G0 +hzK/TmWCNcdBpKbzXWGQg8pyn92mhiHXeclXsgQFs0qoaxSYI/5ghjwC8Z56IeW64Ez /0Bt5MZFfX2bfyj627i8yGsDLzpi2IFDwv98EOmk03uI9mrfsZ+C1usFOk1DlFi1dVLQ RqC8nEobYuuX55J/iUAKknb/UvDEdAN8EWGYScB0cUt1e/IZaQ55jAQsedWcp9PQOmTk VS/sgeux3fOdUtdgTS2Ob8TTu+S1s0Tpuk2OZhC5rBM0fuSMLJ+30l+/VXT0Ls/OmIFf BaCA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=cc:to:message-id:content-transfer-encoding:mime-version :list-unsubscribe:list-subscribe:list-id:precedence:subject:date :from:dkim-signature; bh=j5rFxrXL2P+kdAdamW3tYXEeRPfGn55Rv8VJMgZBhXg=; fh=m8l2PmOOmt3HfrAE0qdmUkTH+rzvbe1iq4f3p9phO1g=; b=Zhv0cZDs7Agm0xWjGfzIkwKxCQTXXH5WIy/FpWZNLNzCUcK2Ei9YjSELWor39EgaU1 DtKFrDYcPimPcGRlqeUO9pc3WzMT92tyiFLf5W93wG+lAbo3Pw1dL0SKnhgxnn8fKtWv N1zI+MFeZxo472BgmIrSmzXmfXDRB2FEU0Y0hmM4EKH+zvAqNMJfE4dMgVKaEW8bQj9F 0PpCgTMeqVSGchVyRl1FB74SXtkq+0u/3qVdqfiu7eYBzmQuN692ZCR8ZmJRdNf9kqlb Rd+PSdOqgq2cghHlznDs+Oc/iE5x5iBKdQL4vwSPY4pKyp35bUc/IG+GVemuOLYF3fWR W1Sg==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=hy8FKegc; arc=pass (i=1 spf=pass spfdomain=chromium.org dkim=pass dkdomain=chromium.org dmarc=pass fromdomain=chromium.org); spf=pass (google.com: domain of linux-kernel+bounces-127905-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-127905-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [147.75.48.161]) by mx.google.com with ESMTPS id fa11-20020a056a002d0b00b006eabaf68ae3si11863161pfb.170.2024.04.02.05.21.38 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 02 Apr 2024 05:21:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-127905-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) client-ip=147.75.48.161; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=hy8FKegc; arc=pass (i=1 spf=pass spfdomain=chromium.org dkim=pass dkdomain=chromium.org dmarc=pass fromdomain=chromium.org); spf=pass (google.com: domain of linux-kernel+bounces-127905-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-127905-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.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 sy.mirrors.kernel.org (Postfix) with ESMTPS id 9AF68B26441 for ; Tue, 2 Apr 2024 12:10:32 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 4828E7E796; Tue, 2 Apr 2024 12:09:34 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=chromium.org header.i=@chromium.org header.b="hy8FKegc" Received: from mail-ot1-f53.google.com (mail-ot1-f53.google.com [209.85.210.53]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 5B3E874262 for ; Tue, 2 Apr 2024 12:09:31 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.210.53 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712059773; cv=none; b=ihYL6PQJi+yi26RGnkdyO6OaVL9RQI13AqkVAygPv4tZJB6nglcg5X+Me7M01Oq9Odr7jFfaquyA7oPce6+TUG+y5D59Ym5ppTPeiMeBJMkp9p/zoX1x4KBMfg2Pzjx+yGzVzCZo9pOTNO03SGVGpprAjFbYyAUp8o+pyuGFAOo= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712059773; c=relaxed/simple; bh=ahRMcLkjFExP99f5A5yoUFbXddpWpyopk22CXBLQ9xI=; h=From:Date:Subject:MIME-Version:Content-Type:Message-Id:To:Cc; b=B7ZvqMDCzkfps5Vm/UyHQv2V7wxrzBgwkhxtvYjQQzdvOH7XJJCMUH6dcBRDrIDYI2rCtgNOMz/hE1jr6X1f/vR6LfbhTssWboImUAmWJwEnRonpV2awxrfzwb7mf8LvtueVPWRxquQG1FI32jvlA79KJ1zIQx1mQ9g/BCEd5Gc= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=chromium.org; spf=pass smtp.mailfrom=chromium.org; dkim=pass (1024-bit key) header.d=chromium.org header.i=@chromium.org header.b=hy8FKegc; arc=none smtp.client-ip=209.85.210.53 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=chromium.org Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=chromium.org Received: by mail-ot1-f53.google.com with SMTP id 46e09a7af769-6e8a1b8cf28so973316a34.1 for ; Tue, 02 Apr 2024 05:09:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; t=1712059770; x=1712664570; darn=vger.kernel.org; h=cc:to:message-id:content-transfer-encoding:mime-version:subject :date:from:from:to:cc:subject:date:message-id:reply-to; bh=j5rFxrXL2P+kdAdamW3tYXEeRPfGn55Rv8VJMgZBhXg=; b=hy8FKegcCoCS4rcGDmq2D7ojkfRcfgHQs+ZMiLSxXUzOfx2U8Lububh1Mg/tCE01Sf CLtrM+4VK7EA0dRtpJs9S2Gvdz/pSNI2rJqkI8EbZTL2ZMkTaFraKB+Kevu9wJEXDv+8 A5bNSViI1jesLx4cieOVHefUL4fakz0zauMxQ= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1712059770; x=1712664570; h=cc:to:message-id:content-transfer-encoding:mime-version:subject :date:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=j5rFxrXL2P+kdAdamW3tYXEeRPfGn55Rv8VJMgZBhXg=; b=EhbFWxNszKKSkur4ZHoaSn4p/3CMN+XKoJJiiNZA7prNDAoXXSROnJOb54K8pDR6ZS 2QT6j/JBd/8zg8q6R1R9NWMoNwYbAx/e+LQrsbgAMsFI16a94b2pJBtOaxXx7IT1AZDf NhJgsB3U2M+1HlAZMWcahQjUv26iNTZ0GT0n4DHCwr/Ob3B/dDjQ/Lc0/n2C0GFQJThJ y/AsNEw/AirgdquWBsMHGGzgjnNQYJATMUkUxD31kfXAgC9IJ1OoLkfYVYhtjcwe3r/T bxv5a/OIRBkJtneT8HpuC/0HaJjF0sVR5ovyCdeBS2K8ScngDTTU/O+zVr8SOHJyvj1G bnfA== X-Forwarded-Encrypted: i=1; AJvYcCUBawbeLPLga8+4QIf65I3if6mYUpnf2k8wnC3Fd+E3pQWbS/OhFyaemj7Sk5vKYApld/jyJzuPsRLad65mKJ6nDebMLN2FFjQTbJ9P X-Gm-Message-State: AOJu0YyEv0K2fJoN/eVlCBLem+ZFd7bSxZ7zNRwDMRpdDrqZA59XJPns Qz2iM7jIuPOwZW9dJ1lmqy5mVz5UQ+FJ7Vmi8qYE6+opNlAtWfgffy9MPaexWg== X-Received: by 2002:a9d:6c8f:0:b0:6e6:c811:4891 with SMTP id c15-20020a9d6c8f000000b006e6c8114891mr13403540otr.29.1712059770483; Tue, 02 Apr 2024 05:09:30 -0700 (PDT) Received: from denia.c.googlers.com (188.173.86.34.bc.googleusercontent.com. [34.86.173.188]) by smtp.gmail.com with ESMTPSA id r9-20020a056214124900b00698f0a22f5csm4396702qvv.130.2024.04.02.05.09.29 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 02 Apr 2024 05:09:30 -0700 (PDT) From: Ricardo Ribalda Date: Tue, 02 Apr 2024 12:09:29 +0000 Subject: [PATCH v5] media: ucvideo: Add quirk for Logitech Rally Bar 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-Transfer-Encoding: 7bit Message-Id: <20240402-rallybar-v5-1-7bdd0fbc51f7@chromium.org> X-B4-Tracking: v=1; b=H4sIAHj1C2YC/3XMwQrCMAzG8VeRnq00WVo3T76HeMi66ArqpNPhG Ht3O0EYMo9fyO8/qFZikFbtVoOK0oU2NLc07HqlfM23s+hQpa3QYAaIqCNfLn3JUUPhxXhHlRW n0vs9yim8PqnDMe06tI8m9p9yB9N1IdKBBp1jiUxVBsad9r6OzTU8r5smntXU6fCfxWRtTkXlk AsLtGCzryUDZm6zZA2XUGy9EDMuWJrbfGYpWd6SNY5ACMofO47jG+LFC/dXAQAA To: Greg Kroah-Hartman , Laurent Pinchart , Alan Stern , Mauro Carvalho Chehab Cc: 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 , Ricardo Ribalda X-Mailer: b4 0.12.4 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) + udev->quirks &= ~USB_QUIRK_RESET_RESUME; 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 Best regards, -- Ricardo Ribalda