aboutsummaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/tegra/output.c
diff options
context:
space:
mode:
authorThierry Reding <treding@nvidia.com>2013-10-29 16:03:03 +0100
committerThierry Reding <treding@nvidia.com>2013-12-19 09:29:55 +0100
commitb5190022f77a41465c2202f621a5fa07c9aabb7b (patch)
treebbdb18d1010430c0b01d25ad32b1ccd565d21f24 /drivers/gpu/drm/tegra/output.c
parent365765fc293e68a1d2ce63811b80c5b3c33eebd1 (diff)
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>
Diffstat (limited to 'drivers/gpu/drm/tegra/output.c')
-rw-r--r--drivers/gpu/drm/tegra/output.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/drivers/gpu/drm/tegra/output.c b/drivers/gpu/drm/tegra/output.c
index 5dc4d1a9cad..581dc5d37be 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);
}
}