diff options
author | Thierry Reding <treding@nvidia.com> | 2013-10-29 19:03:03 +0400 |
---|---|---|
committer | Thierry Reding <treding@nvidia.com> | 2013-12-19 12:29:55 +0400 |
commit | b5190022f77a41465c2202f621a5fa07c9aabb7b (patch) | |
tree | bbdb18d1010430c0b01d25ad32b1ccd565d21f24 | |
parent | 365765fc293e68a1d2ce63811b80c5b3c33eebd1 (diff) | |
download | linux-b5190022f77a41465c2202f621a5fa07c9aabb7b.tar.xz |
drm/tegra: Disable outputs for power-saving
When an output is disabled, its DPMS mode is usually set to off. Instead
of only disabling the panel (if one is attached), turn the output off
entirely to save more power.
HDMI doesn't have any panels attached, so it previously didn't save any
power at all. With this commit, however, the complete HDMI interface
will be turned off, therefore allowing an attached monitor to go into a
standby mode.
Signed-off-by: Thierry Reding <treding@nvidia.com>
-rw-r--r-- | drivers/gpu/drm/tegra/output.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/drivers/gpu/drm/tegra/output.c b/drivers/gpu/drm/tegra/output.c index 5dc4d1a9cad8..581dc5d37bed 100644 --- a/drivers/gpu/drm/tegra/output.c +++ b/drivers/gpu/drm/tegra/output.c @@ -130,11 +130,12 @@ static void tegra_encoder_dpms(struct drm_encoder *encoder, int mode) struct tegra_output *output = encoder_to_output(encoder); struct drm_panel *panel = output->panel; - if (panel && panel->funcs) { - if (mode != DRM_MODE_DPMS_ON) - drm_panel_disable(panel); - else - drm_panel_enable(panel); + if (mode != DRM_MODE_DPMS_ON) { + drm_panel_disable(panel); + tegra_output_disable(output); + } else { + tegra_output_enable(output); + drm_panel_enable(panel); } } |