[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <c330c58f-bb73-d439-d6fa-63eb9cba4313@loongson.cn>
Date: Mon, 22 Nov 2021 20:25:57 +0800
From: zhuyinbo <zhuyinbo@...ngson.cn>
To: Mathias Nyman <mathias.nyman@...el.com>,
Greg Kroah-Hartman <gregkh@...uxfoundation.org>,
linux-usb@...r.kernel.org, linux-kernel@...r.kernel.org,
zhuyinbo@...ngson.cn, linux-kernel@...r.kernel.org
Subject: Re: [PATCH v3] usb: xhci: add LWP quirk for ensuring uPD720201 into
D3 state after S5
在 2021/11/11 下午2:28, Yinbo Zhu 写道:
> After S5, any pci device should into D3 state that if supported, but the
> uPD720201 was not and cause OSPM power consumption is more higher that
> S5 than S4. Due to that uPD720201 firmware behavior was unknown and the
> _PS3 method wasn't implemented in ACPI table which can make device into
> D3, I think xhci HCD can add a quirk ensure it into D3 state after S5
> that is appropriate and this patch was to add the XHCI_LWP_QURIK and set
> PCI_D3hot to uPD720201 pmsc register in xhci_pci_shutdown and
> xhci_pci_remove to fix xhci power consumption issue.
>
> Signed-off-by: Yinbo Zhu <zhuyinbo@...ngson.cn>
> ---
> Change in v3:
> Add D3 set in xhci_pci_remove function.
>
> drivers/usb/host/xhci-pci.c | 9 +++++++++
> drivers/usb/host/xhci.h | 1 +
> 2 files changed, 10 insertions(+)
>
> diff --git a/drivers/usb/host/xhci-pci.c b/drivers/usb/host/xhci-pci.c
> index 2c9f25c..6258a5a 100644
> --- a/drivers/usb/host/xhci-pci.c
> +++ b/drivers/usb/host/xhci-pci.c
> @@ -265,6 +265,7 @@ static void xhci_pci_quirks(struct device *dev, struct xhci_hcd *xhci)
> pdev->device == 0x0014) {
> xhci->quirks |= XHCI_TRUST_TX_LENGTH;
> xhci->quirks |= XHCI_ZERO_64B_REGS;
> + xhci->quirks |= XHCI_LWP_QUIRK;
> }
> if (pdev->vendor == PCI_VENDOR_ID_RENESAS &&
> pdev->device == 0x0015) {
> @@ -466,6 +467,10 @@ static void xhci_pci_remove(struct pci_dev *dev)
> pci_set_power_state(dev, PCI_D3hot);
>
> usb_hcd_pci_remove(dev);
> +
> + /* Workaround for decreasing power consumption after S5 */
> + if (xhci->quirks & XHCI_LWP_QUIRK)
> + pci_set_power_state(dev, PCI_D3hot);
> }
>
> #ifdef CONFIG_PM
> @@ -610,6 +615,10 @@ static void xhci_pci_shutdown(struct usb_hcd *hcd)
> /* Yet another workaround for spurious wakeups at shutdown with HSW */
> if (xhci->quirks & XHCI_SPURIOUS_WAKEUP)
> pci_set_power_state(pdev, PCI_D3hot);
> +
> + /* Workaround for decreasing power consumption after S5 */
> + if (xhci->quirks & XHCI_LWP_QUIRK)
> + pci_set_power_state(pdev, PCI_D3hot);
> }
> #endif /* CONFIG_PM */
>
> diff --git a/drivers/usb/host/xhci.h b/drivers/usb/host/xhci.h
> index dca6181..bcd70d1 100644
> --- a/drivers/usb/host/xhci.h
> +++ b/drivers/usb/host/xhci.h
> @@ -1899,6 +1899,7 @@ struct xhci_hcd {
> #define XHCI_SG_TRB_CACHE_SIZE_QUIRK BIT_ULL(39)
> #define XHCI_NO_SOFT_RETRY BIT_ULL(40)
> #define XHCI_BROKEN_D3COLD BIT_ULL(41)
> +#define XHCI_LWP_QUIRK BIT_ULL(42)
>
> unsigned int num_active_eps;
> unsigned int limit_active_eps;
Hi all,
Do you have any advice about my patch, if no any question, please you
help me merge this patch to upstream.
Thanks,
BRs,
Yinbo Zhu.
Powered by blists - more mailing lists