drm/i915/ddi: Rely on VBT DDI port info for eDP detection
authorImre Deak <imre.deak@intel.com>
Wed, 21 Dec 2016 10:17:24 +0000 (12:17 +0200)
committerImre Deak <imre.deak@intel.com>
Thu, 22 Dec 2016 12:22:50 +0000 (14:22 +0200)
There is at least one APL based system using port A in DP mode
(connecting to an on-board DP->VGA adaptor). Atm we'll configure port A
unconditionally as eDP which is incorrect in this case. Fix this by
relying on the VBT DDI port 'internal port' flag instead on all ports on
DDI platforms. For now chicken out from using VBT for port A before
GEN9.

v2:
- Move the DDI port info lookup to intel_bios_is_port_edp() (David, Jani)
- Use the DDI port info on all DDI platforms starting from port B.

Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
Cc: Jani Nikula <jani.nikula@intel.com>
Cc: David Weinehall <david.weinehall@linux.intel.com>
Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com> (v1)
Reviewed-by: David Weinehall <david.weinehall@linux.intel.com>
Signed-off-by: Imre Deak <imre.deak@intel.com>
Link: http://patchwork.freedesktop.org/patch/msgid/1482315444-24750-1-git-send-email-imre.deak@intel.com
drivers/gpu/drm/i915/i915_drv.h
drivers/gpu/drm/i915/intel_bios.c
drivers/gpu/drm/i915/intel_dp.c

index 87e4349bde927d06ff6fe693031c8cf22c46a104..bd3915ac01334d7b6e94b8374ce7f1604b5a3da7 100644 (file)
@@ -1669,6 +1669,7 @@ struct ddi_vbt_port_info {
        uint8_t supports_dvi:1;
        uint8_t supports_hdmi:1;
        uint8_t supports_dp:1;
+       uint8_t supports_edp:1;
 
        uint8_t alternate_aux_channel;
        uint8_t alternate_ddc_pin;
index 1cf2fa6ec28f80407b2e31f4010c8863b60b9587..a359defd5c5943b81162c28aaac6d2e478d04c4f 100644 (file)
@@ -1161,6 +1161,7 @@ static void parse_ddi_port(struct drm_i915_private *dev_priv, enum port port,
        info->supports_dvi = is_dvi;
        info->supports_hdmi = is_hdmi;
        info->supports_dp = is_dp;
+       info->supports_edp = is_edp;
 
        DRM_DEBUG_KMS("Port %c VBT info: DP:%d HDMI:%d DVI:%d EDP:%d CRT:%d\n",
                      port_name(port), is_dp, is_hdmi, is_dvi, is_edp, is_crt);
@@ -1664,6 +1665,9 @@ bool intel_bios_is_port_edp(struct drm_i915_private *dev_priv, enum port port)
        };
        int i;
 
+       if (HAS_DDI(dev_priv))
+               return dev_priv->vbt.ddi_port_info[port].supports_edp;
+
        if (!dev_priv->vbt.child_dev_num)
                return false;
 
index 66b5bc80b78149f8773f5bf82db54b6fde9e4080..746c2370032da091c6510521632827edd29e35a0 100644 (file)
@@ -4975,7 +4975,7 @@ bool intel_dp_is_edp(struct drm_i915_private *dev_priv, enum port port)
        if (INTEL_GEN(dev_priv) < 5)
                return false;
 
-       if (port == PORT_A)
+       if (INTEL_GEN(dev_priv) < 9 && port == PORT_A)
                return true;
 
        return intel_bios_is_port_edp(dev_priv, port);