aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2013-12-17 09:34:50 -0500
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2014-01-09 15:24:22 -0500
commit6f02958728dec12eb99715893e057bfdad8bed90 (patch)
tree2823f9a54234b4e1698a72710b2b7246cb79d8dd
parent43515fde135fd981c9eaa4f7f76dc30a1aa2ed27 (diff)
drm/i915: Use the correct GMCH_CTRL register for Sandybridge+
commit a885b3ccc74d8e38074e1c43a47c354c5ea0b01e upstream. The GMCH_CTRL register (or MGCC in the spec) is at a different address on Sandybridge, and the address to which we currently write to is undefined. These stray writes appear to upset (hard hang) my Ivybridge machine whilst it is in UEFI mode. Note that the register is still marked as locked RO on Sandybridge, so vgaarb is still dysfunctional. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: Jani Nikula <jani.nikula@linux.intel.com> Cc: Ville Syrjälä <ville.syrjala@linux.intel.com> Reviewed-by: Jani Nikula <jani.nikula@intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r--drivers/gpu/drm/i915/intel_display.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c
index c37dfe2a6dc8..15358add4f70 100644
--- a/drivers/gpu/drm/i915/intel_display.c
+++ b/drivers/gpu/drm/i915/intel_display.c
@@ -9532,14 +9532,15 @@ void intel_connector_attach_encoder(struct intel_connector *connector,
9532int intel_modeset_vga_set_state(struct drm_device *dev, bool state) 9532int intel_modeset_vga_set_state(struct drm_device *dev, bool state)
9533{ 9533{
9534 struct drm_i915_private *dev_priv = dev->dev_private; 9534 struct drm_i915_private *dev_priv = dev->dev_private;
9535 unsigned reg = INTEL_INFO(dev)->gen >= 6 ? SNB_GMCH_CTRL : INTEL_GMCH_CTRL;
9535 u16 gmch_ctrl; 9536 u16 gmch_ctrl;
9536 9537
9537 pci_read_config_word(dev_priv->bridge_dev, INTEL_GMCH_CTRL, &gmch_ctrl); 9538 pci_read_config_word(dev_priv->bridge_dev, reg, &gmch_ctrl);
9538 if (state) 9539 if (state)
9539 gmch_ctrl &= ~INTEL_GMCH_VGA_DISABLE; 9540 gmch_ctrl &= ~INTEL_GMCH_VGA_DISABLE;
9540 else 9541 else
9541 gmch_ctrl |= INTEL_GMCH_VGA_DISABLE; 9542 gmch_ctrl |= INTEL_GMCH_VGA_DISABLE;
9542 pci_write_config_word(dev_priv->bridge_dev, INTEL_GMCH_CTRL, gmch_ctrl); 9543 pci_write_config_word(dev_priv->bridge_dev, reg, gmch_ctrl);
9543 return 0; 9544 return 0;
9544} 9545}
9545 9546