diff options
author | Jesse Barnes <jbarnes@virtuousgeek.org> | 2009-09-10 18:28:04 -0400 |
---|---|---|
committer | Eric Anholt <eric@anholt.net> | 2009-09-10 19:10:21 -0400 |
commit | b42d4c5c6a872815d711e5d51a600f5122c38eee (patch) | |
tree | 3cf56dff583ec83110d6d20466892642e71a9699 | |
parent | c1c7af60892070e4b82ad63bbfb95ae745056de0 (diff) |
drm/i915: use ACPI LID status for LVDS ->detect hook
We can't load or hotplug detect LVDS like we can other outputs, but if
there's a lid device present we can use it as a proxy. This allows the
LFP state to be determined at ->detect time, making configurations
requiring manual intervention today "just work" assuming the lid device
status is correct.
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
Signed-off-by: Eric Anholt <eric@anholt.net>
-rw-r--r-- | drivers/gpu/drm/i915/intel_lvds.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/drivers/gpu/drm/i915/intel_lvds.c b/drivers/gpu/drm/i915/intel_lvds.c index e190ff792bf0..90f69d4717e9 100644 --- a/drivers/gpu/drm/i915/intel_lvds.c +++ b/drivers/gpu/drm/i915/intel_lvds.c | |||
@@ -589,12 +589,18 @@ static void intel_lvds_mode_set(struct drm_encoder *encoder, | |||
589 | /** | 589 | /** |
590 | * Detect the LVDS connection. | 590 | * Detect the LVDS connection. |
591 | * | 591 | * |
592 | * This always returns CONNECTOR_STATUS_CONNECTED. This connector should only have | 592 | * Since LVDS doesn't have hotlug, we use the lid as a proxy. Open means |
593 | * been set up if the LVDS was actually connected anyway. | 593 | * connected and closed means disconnected. We also send hotplug events as |
594 | * needed, using lid status notification from the input layer. | ||
594 | */ | 595 | */ |
595 | static enum drm_connector_status intel_lvds_detect(struct drm_connector *connector) | 596 | static enum drm_connector_status intel_lvds_detect(struct drm_connector *connector) |
596 | { | 597 | { |
597 | return connector_status_connected; | 598 | enum drm_connector_status status = connector_status_connected; |
599 | |||
600 | if (!acpi_lid_open()) | ||
601 | status = connector_status_disconnected; | ||
602 | |||
603 | return status; | ||
598 | } | 604 | } |
599 | 605 | ||
600 | /** | 606 | /** |