Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp869551rwr; Thu, 20 Apr 2023 07:18:26 -0700 (PDT) X-Google-Smtp-Source: AKy350YR1RyNN7BgPM/vq1s5m2KHk8jKO9aorgT6Cbb7zzRyD/tIbA5gRiOzwFJhn4EtFVBLMD7b X-Received: by 2002:a05:6a00:2387:b0:63d:2333:84e6 with SMTP id f7-20020a056a00238700b0063d233384e6mr1924248pfc.33.1682000306194; Thu, 20 Apr 2023 07:18:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1682000306; cv=none; d=google.com; s=arc-20160816; b=Aj5PF7fFk5COdjyny2sBcM2jqfeibtCXCDWHH2RN/6IerI4qVWQg9Jpjs0zLD6whqK NAgpoqR7NFIMvlAwASmk0FwdoDRcnWwxEBZ5Q5jissFltRNkfsVarDDi5UzjRNYnYGWR YWMA1WIG4o4wqBiSc88btXdzhSYWExAZ2esrzZ77+mfr7KoOcdmxXyOa/A5wf35Wi3/x vN9qx5EDp947cS9apjdf1/jlFgdND4G5J+ivP4RnZMpog7/mzBb9ha+7bWuseXVI2ix3 6fMSLSa5ZT8h2S4bMsoQu2cBQA5XkaEx6fudpAIdnYiGP/pwssEaJ489iHSB/kmPqVEe LlpA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=VDYzlRbPEB1JloCsTiYRft8VQtLwVNTMhe4GT8JAk5I=; b=IM/b4lY/kzfc/Ugdi+bLbmDQrf0GIAUcnOgqKUOWMQgMXp40yfbA7TL081LQqCbvHD YmY4yFluq1d227v1bnAZeMyL8k1wEqWQjl3sqDNl5jc9OQZ18dUj4i/cPP4c4DhP3RV2 V+iHGKNUreOqZWLJgRDWqd3g+apWJ3fAubuPEzkxSTMWtLMZ19kLJZIGllKyOESi/Nl+ ds3w2nUs4Uw39vRJVcy8PwuZYSQAO2Ld/7XaC9lwnv4D851nkz1JX2Mnh5svTkwxx3Zp 7ve1CwHhpuDwB/pAIzsacotl0VHL3IRmCmnlHXXY6NZQMu4sbOP6CxikqAKzzGjPR+MR 4Hug== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=dVXiq602; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id q8-20020aa79608000000b0063a6dbeaa56si1819232pfg.60.2023.04.20.07.18.13; Thu, 20 Apr 2023 07:18:26 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=dVXiq602; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231316AbjDTOFw (ORCPT + 99 others); Thu, 20 Apr 2023 10:05:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35134 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229960AbjDTOFv (ORCPT ); Thu, 20 Apr 2023 10:05:51 -0400 Received: from mga14.intel.com (mga14.intel.com [192.55.52.115]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E6E591BE3; Thu, 20 Apr 2023 07:05:49 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1681999549; x=1713535549; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=ORVWQB3PIs3oj9CLXBuce/f03MnSy/PHilD5oKnmU+I=; b=dVXiq6024CiFsT12WUVfJb/r/k5phtoKdt7W9EUTxNFGRrFjxRS+i9Xo r9D5CHFvaoADLMRjlf2ubNhuOp6p3Ha2cxgUMdzsUWs7lMO/AcbdeFBwA wvfQWN0L8rvz1UiUJgsQ3ikTBhNEI3bBXLQGpux2U4uStu+IE7o4e7Ghl gu+sNkzsYOPQ2HLghPZZMhjEdFH9I1jSPgYB1V+dZvY0HOFRlRoLQw6qi Pa2fn00k+6pP4L9AL5ceO/xxawo4jvnIgnid+1xM5UghfJTxFNJCZsKUD dmU+BZsYJfHFqaMvjIIduk+3V8SHTBl18uQli3oDhZ8MvJMw8LrOUjCDl g==; X-IronPort-AV: E=McAfee;i="6600,9927,10686"; a="345750044" X-IronPort-AV: E=Sophos;i="5.99,212,1677571200"; d="scan'208";a="345750044" Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 20 Apr 2023 07:05:49 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10686"; a="781247683" X-IronPort-AV: E=Sophos;i="5.99,212,1677571200"; d="scan'208";a="781247683" Received: from mattu-haswell.fi.intel.com (HELO [10.237.72.199]) ([10.237.72.199]) by FMSMGA003.fm.intel.com with ESMTP; 20 Apr 2023 07:05:47 -0700 Message-ID: <92cf6ed0-be37-d8a6-14c7-c5043f076916@intel.com> Date: Thu, 20 Apr 2023 17:07:16 +0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Firefox/102.0 Thunderbird/102.7.1 Subject: Re: [PATCH 2/3] xhci: Add zhaoxin xHCI U1/U2 feature support Content-Language: en-US To: Weitao Wang , gregkh@linuxfoundation.org, linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org Cc: tonywwang@zhaoxin.com, weitaowang@zhaoxin.com References: <20230420172130.375819-1-WeitaoWang-oc@zhaoxin.com> <20230420172130.375819-3-WeitaoWang-oc@zhaoxin.com> From: Mathias Nyman In-Reply-To: <20230420172130.375819-3-WeitaoWang-oc@zhaoxin.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-6.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 20.4.2023 20.21, Weitao Wang wrote: > Add U1/U2 feature support of xHCI for zhaoxin. > > Signed-off-by: Weitao Wang > --- > drivers/usb/host/xhci-pci.c | 5 +++++ > drivers/usb/host/xhci.c | 27 +++++++++++++++++++++++++-- > 2 files changed, 30 insertions(+), 2 deletions(-) > > diff --git a/drivers/usb/host/xhci-pci.c b/drivers/usb/host/xhci-pci.c > index 6db07ca419c3..a235effe8e5c 100644 > --- a/drivers/usb/host/xhci-pci.c > +++ b/drivers/usb/host/xhci-pci.c > @@ -334,6 +334,11 @@ static void xhci_pci_quirks(struct device *dev, struct xhci_hcd *xhci) > pdev->device == PCI_DEVICE_ID_AMD_PROMONTORYA_4)) > xhci->quirks |= XHCI_NO_SOFT_RETRY; > > + if (pdev->vendor == PCI_VENDOR_ID_ZHAOXIN) { > + xhci->quirks |= XHCI_LPM_SUPPORT; > + xhci->quirks |= XHCI_ZHAOXIN_HOST; > + } > + > /* xHC spec requires PCI devices to support D3hot and D3cold */ > if (xhci->hci_version >= 0x120) > xhci->quirks |= XHCI_DEFAULT_PM_RUNTIME_ALLOW; > diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c > index 6307bae9cddf..730c0f68518d 100644 > --- a/drivers/usb/host/xhci.c > +++ b/drivers/usb/host/xhci.c > @@ -4802,7 +4802,7 @@ static u16 xhci_calculate_u1_timeout(struct xhci_hcd *xhci, > } > } > > - if (xhci->quirks & XHCI_INTEL_HOST) > + if (xhci->quirks & (XHCI_INTEL_HOST | XHCI_ZHAOXIN_HOST)) > timeout_ns = xhci_calculate_intel_u1_timeout(udev, desc); Looks odd to tie Zhaoxin vendor to Intel specific values but ok, if they diverge in the future we anyway need to modify this. > else > timeout_ns = udev->u1_params.sel; > @@ -4866,7 +4866,7 @@ static u16 xhci_calculate_u2_timeout(struct xhci_hcd *xhci, > } > } > > - if (xhci->quirks & XHCI_INTEL_HOST) > + if (xhci->quirks & (XHCI_INTEL_HOST | XHCI_ZHAOXIN_HOST)) > timeout_ns = xhci_calculate_intel_u2_timeout(udev, desc); same. > else > timeout_ns = udev->u2_params.sel; > @@ -4938,6 +4938,27 @@ static int xhci_update_timeout_for_interface(struct xhci_hcd *xhci, > return 0; > } > > +static int xhci_check_zhaoxin_tier_policy(struct usb_device *udev, > + enum usb3_link_state state) > +{ > + struct usb_device *parent; > + unsigned int num_hubs; > + > + /* Don't enable U1/U2 if the device is on an external hub. */ > + for (parent = udev->parent, num_hubs = 0; parent->parent; > + parent = parent->parent) > + num_hubs++; > + > + if (num_hubs < 1) > + return 0; > + > + dev_dbg(&udev->dev, "Disabling U1/U2 link state for device" > + " below external hub.\n"); > + dev_dbg(&udev->dev, "Plug device into root hub " > + "to decrease power consumption.\n"); > + return -E2BIG; > +} > + I don't think we should add more vendor specific functions, this is almost an exact copy of xhci_check_intel_tier_policy(). How about getting rid of both of those and use something like this instead (untested): diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c index 2b280beb0011..e9a25e4d99cf 100644 --- a/drivers/usb/host/xhci.c +++ b/drivers/usb/host/xhci.c @@ -4926,10 +4926,24 @@ static int xhci_check_tier_policy(struct xhci_hcd *xhci, struct usb_device *udev, enum usb3_link_state state) { - if (xhci->quirks & XHCI_INTEL_HOST) - return xhci_check_intel_tier_policy(udev, state); - else - return 0; + struct usb_device *parent = udev->parent; + int tier = 1; /* roothub is tier1 */ + + while (parent) { + parent = parent->parent; + tier++; + } + + if (xhci->quirks & XHCI_INTEL_HOST && tier > 3) + goto fail; + if (xhci->quirks & XHCI_ZHAOXIN_HOST && tier > 2) + goto fail; + + return 0; +fail: + dev_dbg(&udev->dev, "Tier policy prevents U1/U2 LPM states for devices at tier %d\n", + tier); + return -E2BIG; } Or possibly even add a xhci->max_tier_for_lpm that can be set during probe based on vendor or from device property. Thanks -Mathias