DRM/I915: Add enum hpd_pin to intel_encoder.
authorEgbert Eich <eich@suse.de>
Mon, 25 Feb 2013 17:06:49 +0000 (12:06 -0500)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Tue, 26 Mar 2013 20:50:22 +0000 (21:50 +0100)
To clean up hotplug support we add a new enum to intel_encoder:
enum hpd_pin. It allows the encoder to request a hpd line but leave
the details which IRQ is responsible on which chipset generation
to i915_irq.c.
This way requesting hotplug support will become really simple on
the encoder/connector level.

Signed-off-by: Egbert Eich <eich@suse.de>
Acked-by: Chris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: Jesse Barnes <jbarnes@virtuousgeek.org>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
drivers/gpu/drm/i915/i915_drv.h
drivers/gpu/drm/i915/intel_crt.c
drivers/gpu/drm/i915/intel_dp.c
drivers/gpu/drm/i915/intel_drv.h
drivers/gpu/drm/i915/intel_hdmi.c
drivers/gpu/drm/i915/intel_sdvo.c

index 7f6452b592aaf748aca29971174b4ab8d1a0ea19..cda598d89f173dea459a17b14c52f3fb89e19abf 100644 (file)
@@ -86,6 +86,19 @@ enum port {
 };
 #define port_name(p) ((p) + 'A')
 
+enum hpd_pin {
+       HPD_NONE = 0,
+       HPD_PORT_A = HPD_NONE, /* PORT_A is internal */
+       HPD_TV = HPD_NONE,     /* TV is known to be unreliable */
+       HPD_CRT,
+       HPD_SDVO_B,
+       HPD_SDVO_C,
+       HPD_PORT_B,
+       HPD_PORT_C,
+       HPD_PORT_D,
+       HPD_NUM_PINS
+};
+
 #define I915_GEM_GPU_DOMAINS \
        (I915_GEM_DOMAIN_RENDER | \
         I915_GEM_DOMAIN_SAMPLER | \
index 32a3693905ecb14f697fd82b4f8a2419e2818552..a4b3e4e01e654d4f877789c3151381f7fa450356 100644 (file)
@@ -776,6 +776,8 @@ void intel_crt_init(struct drm_device *dev)
 
        crt->base.disable = intel_disable_crt;
        crt->base.enable = intel_enable_crt;
+       if (I915_HAS_HOTPLUG(dev))
+               crt->base.hpd_pin = HPD_CRT;
        if (HAS_DDI(dev))
                crt->base.get_hw_state = intel_ddi_get_hw_state;
        else
index 2f2ec42a417af282f750459df85e1463f3bc59ed..c7c5635f06e0ae6b53e1e93d0133000e39861a6c 100644 (file)
@@ -2821,18 +2821,22 @@ intel_dp_init_connector(struct intel_digital_port *intel_dig_port,
        /* Set up the DDC bus. */
        switch (port) {
        case PORT_A:
+               intel_encoder->hpd_pin = HPD_PORT_A;
                name = "DPDDC-A";
                break;
        case PORT_B:
                dev_priv->hotplug_supported_mask |= PORTB_HOTPLUG_INT_STATUS;
+               intel_encoder->hpd_pin = HPD_PORT_B;
                name = "DPDDC-B";
                break;
        case PORT_C:
                dev_priv->hotplug_supported_mask |= PORTC_HOTPLUG_INT_STATUS;
+               intel_encoder->hpd_pin = HPD_PORT_C;
                name = "DPDDC-C";
                break;
        case PORT_D:
                dev_priv->hotplug_supported_mask |= PORTD_HOTPLUG_INT_STATUS;
+               intel_encoder->hpd_pin = HPD_PORT_D;
                name = "DPDDC-D";
                break;
        default:
index 276f6651dcc30228906b4eddcd6d9cb387dfd58d..54bc2ea61fa991317aa7a9460e78d9e1ee5610a6 100644 (file)
@@ -168,6 +168,7 @@ struct intel_encoder {
         * it is connected to in the pipe parameter. */
        bool (*get_hw_state)(struct intel_encoder *, enum pipe *pipe);
        int crtc_mask;
+       enum hpd_pin hpd_pin;
 };
 
 struct intel_panel {
index 2474b1b6de619c3345bfe9f3d8036f62952767d2..6d92aebadfc3710ce209d8fac374ef4ce5262b61 100644 (file)
@@ -988,17 +988,21 @@ void intel_hdmi_init_connector(struct intel_digital_port *intel_dig_port,
        switch (port) {
        case PORT_B:
                intel_hdmi->ddc_bus = GMBUS_PORT_DPB;
+               intel_encoder->hpd_pin = HPD_PORT_B;
                dev_priv->hotplug_supported_mask |= PORTB_HOTPLUG_INT_STATUS;
                break;
        case PORT_C:
                intel_hdmi->ddc_bus = GMBUS_PORT_DPC;
+               intel_encoder->hpd_pin = HPD_PORT_C;
                dev_priv->hotplug_supported_mask |= PORTC_HOTPLUG_INT_STATUS;
                break;
        case PORT_D:
                intel_hdmi->ddc_bus = GMBUS_PORT_DPD;
+               intel_encoder->hpd_pin = HPD_PORT_D;
                dev_priv->hotplug_supported_mask |= PORTD_HOTPLUG_INT_STATUS;
                break;
        case PORT_A:
+               intel_encoder->hpd_pin = HPD_PORT_A;
                /* Internal port only for eDP. */
        default:
                BUG();
index 678c47cac72b3f160bddc5ac4d1e66460cb3c779..0ff557fe2f60974bf86e8d3a992913082a9c580d 100644 (file)
@@ -2779,6 +2779,9 @@ bool intel_sdvo_init(struct drm_device *dev, uint32_t sdvo_reg, bool is_sdvob)
                        SDVOB_HOTPLUG_INT_STATUS_I915 : SDVOC_HOTPLUG_INT_STATUS_I915;
        }
 
+       if (intel_sdvo->hotplug_active)
+               intel_encoder->hpd_pin = HPD_SDVO_B ? HPD_SDVO_B : HPD_SDVO_C;
+
        drm_encoder_helper_add(&intel_encoder->base, &intel_sdvo_helper_funcs);
 
        intel_encoder->disable = intel_disable_sdvo;