diff options
Diffstat (limited to 'drivers/gpu/drm/i915/intel_sdvo.c')
| -rw-r--r-- | drivers/gpu/drm/i915/intel_sdvo.c | 9 | 
1 files changed, 3 insertions, 6 deletions
diff --git a/drivers/gpu/drm/i915/intel_sdvo.c b/drivers/gpu/drm/i915/intel_sdvo.c index 298dc85ec32..f6a9f4a0d7f 100644 --- a/drivers/gpu/drm/i915/intel_sdvo.c +++ b/drivers/gpu/drm/i915/intel_sdvo.c @@ -1231,12 +1231,8 @@ static bool intel_sdvo_connector_get_hw_state(struct intel_connector *connector)  	struct intel_sdvo_connector *intel_sdvo_connector =  		to_intel_sdvo_connector(&connector->base);  	struct intel_sdvo *intel_sdvo = intel_attached_sdvo(&connector->base); -	struct drm_i915_private *dev_priv = intel_sdvo->base.base.dev->dev_private;  	u16 active_outputs; -	if (!(I915_READ(intel_sdvo->sdvo_reg) & SDVO_ENABLE)) -		return false; -  	intel_sdvo_get_active_outputs(intel_sdvo, &active_outputs);  	if (active_outputs & intel_sdvo_connector->output_flag) @@ -1251,11 +1247,13 @@ static bool intel_sdvo_get_hw_state(struct intel_encoder *encoder,  	struct drm_device *dev = encoder->base.dev;  	struct drm_i915_private *dev_priv = dev->dev_private;  	struct intel_sdvo *intel_sdvo = to_intel_sdvo(&encoder->base); +	u16 active_outputs;  	u32 tmp;  	tmp = I915_READ(intel_sdvo->sdvo_reg); +	intel_sdvo_get_active_outputs(intel_sdvo, &active_outputs); -	if (!(tmp & SDVO_ENABLE)) +	if (!(tmp & SDVO_ENABLE) && (active_outputs == 0))  		return false;  	if (HAS_PCH_CPT(dev)) @@ -2746,7 +2744,6 @@ bool intel_sdvo_init(struct drm_device *dev, uint32_t sdvo_reg, bool is_sdvob)  	struct intel_sdvo *intel_sdvo;  	u32 hotplug_mask;  	int i; -  	intel_sdvo = kzalloc(sizeof(struct intel_sdvo), GFP_KERNEL);  	if (!intel_sdvo)  		return false;  |