Received: by 2002:a05:7412:b10a:b0:f3:1519:9f41 with SMTP id az10csp1150768rdb; Fri, 1 Dec 2023 08:14:09 -0800 (PST) X-Google-Smtp-Source: AGHT+IG0suG7HheL/bmLyOW76tqIGVfeESWDbuBbN6P4zBAaa4r0irsxV+hoTfgcXc1C7q1tLDQ1 X-Received: by 2002:a17:903:2444:b0:1cf:da41:7292 with SMTP id l4-20020a170903244400b001cfda417292mr18089204pls.45.1701447249160; Fri, 01 Dec 2023 08:14:09 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701447249; cv=none; d=google.com; s=arc-20160816; b=r4VW+5rwz+1RDsBInV4I/f4QPCiEoWvEkGr/16XiqqFRU8PzOogUlHan3W1XdmLaLq WCBLoYMxmcmE7bQe9QCNtffr0cVTfKZk9oxO6MgmhITwJWK8mJXER29H3llpVjoMOs0j qP/1j5DwbNp3/85neNbanYGqsp9HJgRrEsLj416Euo9AJJVj7R2ss3ID9XFhgXBdWxyu Q4cAVoWOFVut/PkgLmsUkFuOA83Pb09zJIzH3GWvq1N40k9tt9K2YfDvRckIwcqJPsYV UYqlr8e68gJUL7j3uDbnyJt6eurago5YxsB0qT9Blwr/7u60jb/kuLD0eZC1p7iKw1U6 YseA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=3C+/11yMhxpDahiZti37WSd5GbAwwGVg54wK3/yEgQg=; fh=PRNp//tzEkV2SHUN491UjbD63h48NsGOvebFpKwiYDc=; b=Jv/ittDb5e0uXUMuInaj+/JB3xC9063MyQU4XzFVmhNIKfqT42mOIRFVS65g4Iq0uO HogLXquBusW3XUuLtEgURVbufF4P7xGi1pbrTrUv/ziERJjSkmqBIg72Wk+6JfuHZ7uS //8RwngVE3l7BrGDEL0S2ga5EgrRaMxQ/cjgQ1NK1WimHMBu71omDc/CyB+Haca63aCb 9y1Vdf8eTqQy0riK8fjbdZB/M53JicrwGi83FmvR/6zdhangAsKyJoG4Zw/4GVwZk6TL rsy0f0kFdcZNr9Tko7XhPFljVoURw+zj0Q0hLxMMJN/7dnB3752UOB3Csb6waC9zvATf FGIA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=harvard.edu Return-Path: Received: from pete.vger.email (pete.vger.email. [23.128.96.36]) by mx.google.com with ESMTPS id w3-20020a170902a70300b001cc0cd0772dsi3387062plq.86.2023.12.01.08.14.08 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 01 Dec 2023 08:14:09 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) client-ip=23.128.96.36; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=harvard.edu Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by pete.vger.email (Postfix) with ESMTP id 2EDEA83D9B45; Fri, 1 Dec 2023 08:14:06 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at pete.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1378294AbjLAQNv (ORCPT + 99 others); Fri, 1 Dec 2023 11:13:51 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36602 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1378234AbjLAQNu (ORCPT ); Fri, 1 Dec 2023 11:13:50 -0500 Received: from netrider.rowland.org (netrider.rowland.org [192.131.102.5]) by lindbergh.monkeyblade.net (Postfix) with SMTP id 1B57010F3 for ; Fri, 1 Dec 2023 08:13:54 -0800 (PST) Received: (qmail 291319 invoked by uid 1000); 1 Dec 2023 11:13:53 -0500 Date: Fri, 1 Dec 2023 11:13:53 -0500 From: Alan Stern To: Hardik Gajjar Cc: gregkh@linuxfoundation.org, corbet@lwn.net, linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, erosca@de.adit-jv.com, tj@kernel.org, paulmck@kernel.org, Martin.Mueller5@de.bosch.com Subject: Re: [PATCH v3] usb: hub: Add quirk to decrease IN-ep poll interval for Microchip USB491x hub Message-ID: <39f334d2-abe6-4b4d-a48c-b22a907c6ea6@rowland.harvard.edu> References: <20231201144705.97385-1-hgajjar@de.adit-jv.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20231201144705.97385-1-hgajjar@de.adit-jv.com> X-Spam-Status: No, score=-0.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on pete.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (pete.vger.email [0.0.0.0]); Fri, 01 Dec 2023 08:14:06 -0800 (PST) On Fri, Dec 01, 2023 at 03:47:05PM +0100, Hardik Gajjar wrote: > There is a potential delay in notifying Linux USB drivers of downstream > USB bus activity when connecting a high-speed or superSpeed device via the > Microchip USB491x hub. This delay is due to the fixed bInterval value of > 12 in the silicon of the Microchip USB491x hub. > > Microchip requested to ignore the device descriptor and decrease that > value to 9 as it was too late to modify that in silicon. > > This patch speeds up the USB enummeration process that helps to pass > Apple Carplay certifications and improve the User experience when utilizing > the USB device via Microchip Multihost USB491x Hub. > > A new hub quirk HUB_QUIRK_REDUCE_FRAME_INTR_BINTERVAL speeds up > the notification process for Microchip USB491x hub by limiting > the maximum bInterval value to 9. > > Signed-off-by: Hardik Gajjar > --- > changes since version 1: > - Move implementation from config.c and quirk.c to hub.c as this is hub > specific changes. > - Improve commit message. > - Link to v1 - https://lore.kernel.org/all/20231123081948.58776-1-hgajjar@de.adit-jv.com/ > > changes since version 2: > - Call usb_set_interface after updating the bInterval to Tell the HCD about modification > - Link to v2 - https://lore.kernel.org/all/20231130084855.119937-1-hgajjar@de.adit-jv.com/ > --- > drivers/usb/core/hub.c | 27 +++++++++++++++++++++++++++ > 1 file changed, 27 insertions(+) > > diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c > index b4584a0cd484..b5ac29c5f016 100644 > --- a/drivers/usb/core/hub.c > +++ b/drivers/usb/core/hub.c > @@ -47,12 +47,18 @@ > #define USB_VENDOR_TEXAS_INSTRUMENTS 0x0451 > #define USB_PRODUCT_TUSB8041_USB3 0x8140 > #define USB_PRODUCT_TUSB8041_USB2 0x8142 > +#define USB_VENDOR_MICROCHIP 0x0424 > +#define USB_PRODUCT_USB4913 0x4913 > +#define USB_PRODUCT_USB4914 0x4914 > +#define USB_PRODUCT_USB4915 0x4915 > #define HUB_QUIRK_CHECK_PORT_AUTOSUSPEND 0x01 > #define HUB_QUIRK_DISABLE_AUTOSUSPEND 0x02 > +#define HUB_QUIRK_REDUCE_FRAME_INTR_BINTERVAL 0x08 Why use 0x08 instead of 0x04? Alan Stern