aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/gpu/drm/i915/intel_dp.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/intel_dp.c b/drivers/gpu/drm/i915/intel_dp.c
index f9c5f17af9d8..464d8ad9bb71 100644
--- a/drivers/gpu/drm/i915/intel_dp.c
+++ b/drivers/gpu/drm/i915/intel_dp.c
@@ -4498,6 +4498,18 @@ intel_dp_hpd_pulse(struct intel_digital_port *intel_dig_port, bool long_hpd)
4498 if (intel_dig_port->base.type != INTEL_OUTPUT_EDP) 4498 if (intel_dig_port->base.type != INTEL_OUTPUT_EDP)
4499 intel_dig_port->base.type = INTEL_OUTPUT_DISPLAYPORT; 4499 intel_dig_port->base.type = INTEL_OUTPUT_DISPLAYPORT;
4500 4500
4501 if (long_hpd && intel_dig_port->base.type == INTEL_OUTPUT_EDP) {
4502 /*
4503 * vdd off can generate a long pulse on eDP which
4504 * would require vdd on to handle it, and thus we
4505 * would end up in an endless cycle of
4506 * "vdd off -> long hpd -> vdd on -> detect -> vdd off -> ..."
4507 */
4508 DRM_DEBUG_KMS("ignoring long hpd on eDP port %c\n",
4509 port_name(intel_dig_port->port));
4510 return false;
4511 }
4512
4501 DRM_DEBUG_KMS("got hpd irq on port %c - %s\n", 4513 DRM_DEBUG_KMS("got hpd irq on port %c - %s\n",
4502 port_name(intel_dig_port->port), 4514 port_name(intel_dig_port->port),
4503 long_hpd ? "long" : "short"); 4515 long_hpd ? "long" : "short");