drm/i915: Pass hpd_pin to long_pulse_detect()
authorVille Syrjälä <ville.syrjala@linux.intel.com>
Thu, 5 Jul 2018 16:43:55 +0000 (19:43 +0300)
committerVille Syrjälä <ville.syrjala@linux.intel.com>
Fri, 13 Jul 2018 15:22:22 +0000 (18:22 +0300)
We're doing a pointless translation from hpd_pin to port simply for
passing the thing to long_pulse_detect(). Let's pass the hpd_pin
directly instead.

This removes the assumption that the hpd_pin and port always
match. The only other place where we make that assumption anymore
is intel_hpd_pin_default() and that's fine as it's what determines
the relationship between the two. If we ever get hardware where
the hpd pins are wired in more interesting ways it should be
trivial to handle from now on.

This should also fix the IS_CNL_WITH_PORT_F() case as that mapped
pin E back to port F and passed that to
spt_port_hotplug2_long_detect() which would always return false
for port F. Now that we pass in pin E directly it'll actually
do the right thing.

Cc: Rodrigo Vivi <rodrigo.vivi@intel.com>
Fixes: cf53902f48c3 ("drm/i915/cnl: Add HPD support for Port F.")
Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20180705164357.28512-7-ville.syrjala@linux.intel.com
Reviewed-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
drivers/gpu/drm/i915/i915_drv.h
drivers/gpu/drm/i915/i915_irq.c
drivers/gpu/drm/i915/intel_hotplug.c

index 059cef73eb288a67828c6e9fb3fd14181c9d6a7f..08d4303abb1468639cc9b19e09874aa18f74f973 100644 (file)
@@ -2745,8 +2745,6 @@ void intel_hpd_irq_handler(struct drm_i915_private *dev_priv,
 void intel_hpd_init(struct drm_i915_private *dev_priv);
 void intel_hpd_init_work(struct drm_i915_private *dev_priv);
 void intel_hpd_cancel_work(struct drm_i915_private *dev_priv);
-enum port intel_hpd_pin_to_port(struct drm_i915_private *dev_priv,
-                               enum hpd_pin pin);
 enum hpd_pin intel_hpd_pin_default(struct drm_i915_private *dev_priv,
                                   enum port port);
 bool intel_hpd_disable(struct drm_i915_private *dev_priv, enum hpd_pin pin);
index bd9c77c804ab7828bea0102524d5fe6f2c73c88d..6d80eb6b89985ecacfa0f2a270f3473e7dff2fc4 100644 (file)
@@ -1576,122 +1576,122 @@ static void gen8_gt_irq_handler(struct drm_i915_private *i915,
        }
 }
 
-static bool gen11_port_hotplug_long_detect(enum port port, u32 val)
+static bool gen11_port_hotplug_long_detect(enum hpd_pin pin, u32 val)
 {
-       switch (port) {
-       case PORT_C:
+       switch (pin) {
+       case HPD_PORT_C:
                return val & GEN11_HOTPLUG_CTL_LONG_DETECT(PORT_TC1);
-       case PORT_D:
+       case HPD_PORT_D:
                return val & GEN11_HOTPLUG_CTL_LONG_DETECT(PORT_TC2);
-       case PORT_E:
+       case HPD_PORT_E:
                return val & GEN11_HOTPLUG_CTL_LONG_DETECT(PORT_TC3);
-       case PORT_F:
+       case HPD_PORT_F:
                return val & GEN11_HOTPLUG_CTL_LONG_DETECT(PORT_TC4);
        default:
                return false;
        }
 }
 
-static bool bxt_port_hotplug_long_detect(enum port port, u32 val)
+static bool bxt_port_hotplug_long_detect(enum hpd_pin pin, u32 val)
 {
-       switch (port) {
-       case PORT_A:
+       switch (pin) {
+       case HPD_PORT_A:
                return val & PORTA_HOTPLUG_LONG_DETECT;
-       case PORT_B:
+       case HPD_PORT_B:
                return val & PORTB_HOTPLUG_LONG_DETECT;
-       case PORT_C:
+       case HPD_PORT_C:
                return val & PORTC_HOTPLUG_LONG_DETECT;
        default:
                return false;
        }
 }
 
-static bool icp_ddi_port_hotplug_long_detect(enum port port, u32 val)
+static bool icp_ddi_port_hotplug_long_detect(enum hpd_pin pin, u32 val)
 {
-       switch (port) {
-       case PORT_A:
+       switch (pin) {
+       case HPD_PORT_A:
                return val & ICP_DDIA_HPD_LONG_DETECT;
-       case PORT_B:
+       case HPD_PORT_B:
                return val & ICP_DDIB_HPD_LONG_DETECT;
        default:
                return false;
        }
 }
 
-static bool icp_tc_port_hotplug_long_detect(enum port port, u32 val)
+static bool icp_tc_port_hotplug_long_detect(enum hpd_pin pin, u32 val)
 {
-       switch (port) {
-       case PORT_C:
+       switch (pin) {
+       case HPD_PORT_C:
                return val & ICP_TC_HPD_LONG_DETECT(PORT_TC1);
-       case PORT_D:
+       case HPD_PORT_D:
                return val & ICP_TC_HPD_LONG_DETECT(PORT_TC2);
-       case PORT_E:
+       case HPD_PORT_E:
                return val & ICP_TC_HPD_LONG_DETECT(PORT_TC3);
-       case PORT_F:
+       case HPD_PORT_F:
                return val & ICP_TC_HPD_LONG_DETECT(PORT_TC4);
        default:
                return false;
        }
 }
 
-static bool spt_port_hotplug2_long_detect(enum port port, u32 val)
+static bool spt_port_hotplug2_long_detect(enum hpd_pin pin, u32 val)
 {
-       switch (port) {
-       case PORT_E:
+       switch (pin) {
+       case HPD_PORT_E:
                return val & PORTE_HOTPLUG_LONG_DETECT;
        default:
                return false;
        }
 }
 
-static bool spt_port_hotplug_long_detect(enum port port, u32 val)
+static bool spt_port_hotplug_long_detect(enum hpd_pin pin, u32 val)
 {
-       switch (port) {
-       case PORT_A:
+       switch (pin) {
+       case HPD_PORT_A:
                return val & PORTA_HOTPLUG_LONG_DETECT;
-       case PORT_B:
+       case HPD_PORT_B:
                return val & PORTB_HOTPLUG_LONG_DETECT;
-       case PORT_C:
+       case HPD_PORT_C:
                return val & PORTC_HOTPLUG_LONG_DETECT;
-       case PORT_D:
+       case HPD_PORT_D:
                return val & PORTD_HOTPLUG_LONG_DETECT;
        default:
                return false;
        }
 }
 
-static bool ilk_port_hotplug_long_detect(enum port port, u32 val)
+static bool ilk_port_hotplug_long_detect(enum hpd_pin pin, u32 val)
 {
-       switch (port) {
-       case PORT_A:
+       switch (pin) {
+       case HPD_PORT_A:
                return val & DIGITAL_PORTA_HOTPLUG_LONG_DETECT;
        default:
                return false;
        }
 }
 
-static bool pch_port_hotplug_long_detect(enum port port, u32 val)
+static bool pch_port_hotplug_long_detect(enum hpd_pin pin, u32 val)
 {
-       switch (port) {
-       case PORT_B:
+       switch (pin) {
+       case HPD_PORT_B:
                return val & PORTB_HOTPLUG_LONG_DETECT;
-       case PORT_C:
+       case HPD_PORT_C:
                return val & PORTC_HOTPLUG_LONG_DETECT;
-       case PORT_D:
+       case HPD_PORT_D:
                return val & PORTD_HOTPLUG_LONG_DETECT;
        default:
                return false;
        }
 }
 
-static bool i9xx_port_hotplug_long_detect(enum port port, u32 val)
+static bool i9xx_port_hotplug_long_detect(enum hpd_pin pin, u32 val)
 {
-       switch (port) {
-       case PORT_B:
+       switch (pin) {
+       case HPD_PORT_B:
                return val & PORTB_HOTPLUG_INT_LONG_PULSE;
-       case PORT_C:
+       case HPD_PORT_C:
                return val & PORTC_HOTPLUG_INT_LONG_PULSE;
-       case PORT_D:
+       case HPD_PORT_D:
                return val & PORTD_HOTPLUG_INT_LONG_PULSE;
        default:
                return false;
@@ -1709,9 +1709,8 @@ static void intel_get_hpd_pins(struct drm_i915_private *dev_priv,
                               u32 *pin_mask, u32 *long_mask,
                               u32 hotplug_trigger, u32 dig_hotplug_reg,
                               const u32 hpd[HPD_NUM_PINS],
-                              bool long_pulse_detect(enum port port, u32 val))
+                              bool long_pulse_detect(enum hpd_pin pin, u32 val))
 {
-       enum port port;
        enum hpd_pin pin;
 
        for_each_hpd_pin(pin) {
@@ -1720,11 +1719,7 @@ static void intel_get_hpd_pins(struct drm_i915_private *dev_priv,
 
                *pin_mask |= BIT(pin);
 
-               port = intel_hpd_pin_to_port(dev_priv, pin);
-               if (port == PORT_NONE)
-                       continue;
-
-               if (long_pulse_detect(port, dig_hotplug_reg))
+               if (long_pulse_detect(pin, dig_hotplug_reg))
                        *long_mask |= BIT(pin);
        }
 
index d9d61d11dd2bf3011114d6f0139a4de0ddfd925a..648a13c6043c0071ddd495424691d795b39b96a1 100644 (file)
  * it will use i915_hotplug_work_func where this logic is handled.
  */
 
-/**
- * intel_hpd_port - return port hard associated with certain pin.
- * @dev_priv: private driver data pointer
- * @pin: the hpd pin to get associated port
- *
- * Return port that is associatade with @pin and PORT_NONE if no port is
- * hard associated with that @pin.
- */
-enum port intel_hpd_pin_to_port(struct drm_i915_private *dev_priv,
-                               enum hpd_pin pin)
-{
-       switch (pin) {
-       case HPD_PORT_A:
-               return PORT_A;
-       case HPD_PORT_B:
-               return PORT_B;
-       case HPD_PORT_C:
-               return PORT_C;
-       case HPD_PORT_D:
-               return PORT_D;
-       case HPD_PORT_E:
-               if (IS_CNL_WITH_PORT_F(dev_priv))
-                       return PORT_F;
-               return PORT_E;
-       case HPD_PORT_F:
-               return PORT_F;
-       default:
-               return PORT_NONE; /* no port for this pin */
-       }
-}
-
 /**
  * intel_hpd_pin_default - return default pin associated with certain port.
  * @dev_priv: private driver data pointer