diff options
author | JC Kuo <jckuo@nvidia.com> | 2021-01-20 15:34:14 +0800 |
---|---|---|
committer | Thierry Reding <treding@nvidia.com> | 2021-06-11 18:15:46 +0200 |
commit | 971ee247060d88dceb72428b5d203687312884f4 (patch) | |
tree | 823b9794d944559e06cb05fc85cfbeba12ff0598 /drivers/phy | |
parent | 41a7426d25fa3f43380560928edb6f815397da20 (diff) | |
download | linux-971ee247060d88dceb72428b5d203687312884f4.tar.gz linux-971ee247060d88dceb72428b5d203687312884f4.tar.bz2 linux-971ee247060d88dceb72428b5d203687312884f4.zip |
usb: xhci: tegra: Enable ELPG for runtime/system PM
This commit implements the complete programming sequence for ELPG
entry and exit.
1. At ELPG entry, invokes tegra_xusb_padctl_enable_phy_sleepwalk()
and tegra_xusb_padctl_enable_phy_wake() to configure XUSB PADCTL
sleepwalk and wake detection circuits to maintain USB lines level
and respond to wake events (wake-on-connect, wake-on-disconnect,
device-initiated-wake).
2. At ELPG exit, invokes tegra_xusb_padctl_disable_phy_sleepwalk()
and tegra_xusb_padctl_disable_phy_wake() to disarm sleepwalk and
wake detection circuits.
At runtime suspend, XUSB host controller can enter ELPG to reduce
power consumption. When XUSB PADCTL wake detection circuit detects
a wake event, an interrupt will be raised. xhci-tegra driver then
will invoke pm_runtime_resume() for xhci-tegra.
Runtime resume could also be triggered by protocol drivers, this is
the host-initiated-wake event. At runtime resume, xhci-tegra driver
brings XUSB host controller out of ELPG to handle the wake events.
The same ELPG enter/exit procedure will be performed for system
suspend/resume path so USB devices can remain connected across SC7.
Signed-off-by: JC Kuo <jckuo@nvidia.com>
Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Thierry Reding <treding@nvidia.com>
Diffstat (limited to 'drivers/phy')
0 files changed, 0 insertions, 0 deletions