mirror of
https://github.com/torvalds/linux.git
synced 2024-11-11 22:51:42 +00:00
Merge tag 'drm-intel-fixes-2013-11-20' of git://people.freedesktop.org/~danvet/drm-intel into drm-fixes
Just a small pile of fixes for bugs and a few regressions. I'm still trying to track down a driver load hang on my g33 (which infuriatingly doesn't happen when loading the module manually after boot), somehow bisecting loves to go astray on this one :( And there's a (harmless) locking WARN in the suspend code due to one of Jesse's vlv backlight rework patches. Otherwise nothing outstanding afaik. * tag 'drm-intel-fixes-2013-11-20' of git://people.freedesktop.org/~danvet/drm-intel: drm/i915: Fix gen3 self-refresh watermarks drm/i915: Replicate BIOS eDP bpp clamping hack for hsw drm/i915: Do not enable package C8 on unsupported hardware drm/i915: Hold pc8 lock around toggling pc8.gpu_idle drm/i915: encoder->get_config is no longer optional drm/i915/tv: add ->get_config callback drm/i915: restore the early forcewake cleanup Partially revert "drm/i915: tune the RC6 threshold for stability" drm/i915: flush cursors harder i915: Use 120MHz LVDS SSC clock for gen5/gen6/gen7 x86/early quirk: use gen6 stolen detection for VLV drm/i915/dp: set sink to power down mode on dp disable
This commit is contained in:
commit
cf96967794
@ -330,8 +330,8 @@ static struct pci_device_id intel_stolen_ids[] __initdata = {
|
|||||||
INTEL_I915GM_IDS(gen3_stolen_size),
|
INTEL_I915GM_IDS(gen3_stolen_size),
|
||||||
INTEL_I945G_IDS(gen3_stolen_size),
|
INTEL_I945G_IDS(gen3_stolen_size),
|
||||||
INTEL_I945GM_IDS(gen3_stolen_size),
|
INTEL_I945GM_IDS(gen3_stolen_size),
|
||||||
INTEL_VLV_M_IDS(gen3_stolen_size),
|
INTEL_VLV_M_IDS(gen6_stolen_size),
|
||||||
INTEL_VLV_D_IDS(gen3_stolen_size),
|
INTEL_VLV_D_IDS(gen6_stolen_size),
|
||||||
INTEL_PINEVIEW_IDS(gen3_stolen_size),
|
INTEL_PINEVIEW_IDS(gen3_stolen_size),
|
||||||
INTEL_I965G_IDS(gen3_stolen_size),
|
INTEL_I965G_IDS(gen3_stolen_size),
|
||||||
INTEL_G33_IDS(gen3_stolen_size),
|
INTEL_G33_IDS(gen3_stolen_size),
|
||||||
|
@ -1816,6 +1816,7 @@ struct drm_i915_file_private {
|
|||||||
#define HAS_POWER_WELL(dev) (IS_HASWELL(dev) || IS_BROADWELL(dev))
|
#define HAS_POWER_WELL(dev) (IS_HASWELL(dev) || IS_BROADWELL(dev))
|
||||||
#define HAS_FPGA_DBG_UNCLAIMED(dev) (INTEL_INFO(dev)->has_fpga_dbg)
|
#define HAS_FPGA_DBG_UNCLAIMED(dev) (INTEL_INFO(dev)->has_fpga_dbg)
|
||||||
#define HAS_PSR(dev) (IS_HASWELL(dev) || IS_BROADWELL(dev))
|
#define HAS_PSR(dev) (IS_HASWELL(dev) || IS_BROADWELL(dev))
|
||||||
|
#define HAS_PC8(dev) (IS_HASWELL(dev)) /* XXX HSW:ULX */
|
||||||
|
|
||||||
#define INTEL_PCH_DEVICE_ID_MASK 0xff00
|
#define INTEL_PCH_DEVICE_ID_MASK 0xff00
|
||||||
#define INTEL_PCH_IBX_DEVICE_ID_TYPE 0x3b00
|
#define INTEL_PCH_IBX_DEVICE_ID_TYPE 0x3b00
|
||||||
|
@ -790,7 +790,12 @@ init_vbt_defaults(struct drm_i915_private *dev_priv)
|
|||||||
|
|
||||||
/* Default to using SSC */
|
/* Default to using SSC */
|
||||||
dev_priv->vbt.lvds_use_ssc = 1;
|
dev_priv->vbt.lvds_use_ssc = 1;
|
||||||
dev_priv->vbt.lvds_ssc_freq = intel_bios_ssc_frequency(dev, 1);
|
/*
|
||||||
|
* Core/SandyBridge/IvyBridge use alternative (120MHz) reference
|
||||||
|
* clock for LVDS.
|
||||||
|
*/
|
||||||
|
dev_priv->vbt.lvds_ssc_freq = intel_bios_ssc_frequency(dev,
|
||||||
|
!HAS_PCH_SPLIT(dev));
|
||||||
DRM_DEBUG_KMS("Set default to SSC at %dMHz\n", dev_priv->vbt.lvds_ssc_freq);
|
DRM_DEBUG_KMS("Set default to SSC at %dMHz\n", dev_priv->vbt.lvds_ssc_freq);
|
||||||
|
|
||||||
for (port = PORT_A; port < I915_MAX_PORTS; port++) {
|
for (port = PORT_A; port < I915_MAX_PORTS; port++) {
|
||||||
|
@ -1406,6 +1406,26 @@ void intel_ddi_get_config(struct intel_encoder *encoder,
|
|||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (encoder->type == INTEL_OUTPUT_EDP && dev_priv->vbt.edp_bpp &&
|
||||||
|
pipe_config->pipe_bpp > dev_priv->vbt.edp_bpp) {
|
||||||
|
/*
|
||||||
|
* This is a big fat ugly hack.
|
||||||
|
*
|
||||||
|
* Some machines in UEFI boot mode provide us a VBT that has 18
|
||||||
|
* bpp and 1.62 GHz link bandwidth for eDP, which for reasons
|
||||||
|
* unknown we fail to light up. Yet the same BIOS boots up with
|
||||||
|
* 24 bpp and 2.7 GHz link. Use the same bpp as the BIOS uses as
|
||||||
|
* max, not what it tells us to use.
|
||||||
|
*
|
||||||
|
* Note: This will still be broken if the eDP panel is not lit
|
||||||
|
* up by the BIOS, and thus we can't get the mode at module
|
||||||
|
* load.
|
||||||
|
*/
|
||||||
|
DRM_DEBUG_KMS("pipe has %d bpp for eDP panel, overriding BIOS-provided max %d bpp\n",
|
||||||
|
pipe_config->pipe_bpp, dev_priv->vbt.edp_bpp);
|
||||||
|
dev_priv->vbt.edp_bpp = pipe_config->pipe_bpp;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void intel_ddi_destroy(struct drm_encoder *encoder)
|
static void intel_ddi_destroy(struct drm_encoder *encoder)
|
||||||
|
@ -6518,6 +6518,9 @@ static void __hsw_disable_package_c8(struct drm_i915_private *dev_priv)
|
|||||||
|
|
||||||
void hsw_enable_package_c8(struct drm_i915_private *dev_priv)
|
void hsw_enable_package_c8(struct drm_i915_private *dev_priv)
|
||||||
{
|
{
|
||||||
|
if (!HAS_PC8(dev_priv->dev))
|
||||||
|
return;
|
||||||
|
|
||||||
mutex_lock(&dev_priv->pc8.lock);
|
mutex_lock(&dev_priv->pc8.lock);
|
||||||
__hsw_enable_package_c8(dev_priv);
|
__hsw_enable_package_c8(dev_priv);
|
||||||
mutex_unlock(&dev_priv->pc8.lock);
|
mutex_unlock(&dev_priv->pc8.lock);
|
||||||
@ -6525,6 +6528,9 @@ void hsw_enable_package_c8(struct drm_i915_private *dev_priv)
|
|||||||
|
|
||||||
void hsw_disable_package_c8(struct drm_i915_private *dev_priv)
|
void hsw_disable_package_c8(struct drm_i915_private *dev_priv)
|
||||||
{
|
{
|
||||||
|
if (!HAS_PC8(dev_priv->dev))
|
||||||
|
return;
|
||||||
|
|
||||||
mutex_lock(&dev_priv->pc8.lock);
|
mutex_lock(&dev_priv->pc8.lock);
|
||||||
__hsw_disable_package_c8(dev_priv);
|
__hsw_disable_package_c8(dev_priv);
|
||||||
mutex_unlock(&dev_priv->pc8.lock);
|
mutex_unlock(&dev_priv->pc8.lock);
|
||||||
@ -6562,6 +6568,9 @@ static void hsw_update_package_c8(struct drm_device *dev)
|
|||||||
struct drm_i915_private *dev_priv = dev->dev_private;
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
||||||
bool allow;
|
bool allow;
|
||||||
|
|
||||||
|
if (!HAS_PC8(dev_priv->dev))
|
||||||
|
return;
|
||||||
|
|
||||||
if (!i915_enable_pc8)
|
if (!i915_enable_pc8)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -6585,18 +6594,28 @@ done:
|
|||||||
|
|
||||||
static void hsw_package_c8_gpu_idle(struct drm_i915_private *dev_priv)
|
static void hsw_package_c8_gpu_idle(struct drm_i915_private *dev_priv)
|
||||||
{
|
{
|
||||||
|
if (!HAS_PC8(dev_priv->dev))
|
||||||
|
return;
|
||||||
|
|
||||||
|
mutex_lock(&dev_priv->pc8.lock);
|
||||||
if (!dev_priv->pc8.gpu_idle) {
|
if (!dev_priv->pc8.gpu_idle) {
|
||||||
dev_priv->pc8.gpu_idle = true;
|
dev_priv->pc8.gpu_idle = true;
|
||||||
hsw_enable_package_c8(dev_priv);
|
__hsw_enable_package_c8(dev_priv);
|
||||||
}
|
}
|
||||||
|
mutex_unlock(&dev_priv->pc8.lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void hsw_package_c8_gpu_busy(struct drm_i915_private *dev_priv)
|
static void hsw_package_c8_gpu_busy(struct drm_i915_private *dev_priv)
|
||||||
{
|
{
|
||||||
|
if (!HAS_PC8(dev_priv->dev))
|
||||||
|
return;
|
||||||
|
|
||||||
|
mutex_lock(&dev_priv->pc8.lock);
|
||||||
if (dev_priv->pc8.gpu_idle) {
|
if (dev_priv->pc8.gpu_idle) {
|
||||||
dev_priv->pc8.gpu_idle = false;
|
dev_priv->pc8.gpu_idle = false;
|
||||||
hsw_disable_package_c8(dev_priv);
|
__hsw_disable_package_c8(dev_priv);
|
||||||
}
|
}
|
||||||
|
mutex_unlock(&dev_priv->pc8.lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define for_each_power_domain(domain, mask) \
|
#define for_each_power_domain(domain, mask) \
|
||||||
@ -7184,7 +7203,9 @@ static void i9xx_update_cursor(struct drm_crtc *crtc, u32 base)
|
|||||||
intel_crtc->cursor_visible = visible;
|
intel_crtc->cursor_visible = visible;
|
||||||
}
|
}
|
||||||
/* and commit changes on next vblank */
|
/* and commit changes on next vblank */
|
||||||
|
POSTING_READ(CURCNTR(pipe));
|
||||||
I915_WRITE(CURBASE(pipe), base);
|
I915_WRITE(CURBASE(pipe), base);
|
||||||
|
POSTING_READ(CURBASE(pipe));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ivb_update_cursor(struct drm_crtc *crtc, u32 base)
|
static void ivb_update_cursor(struct drm_crtc *crtc, u32 base)
|
||||||
@ -7213,7 +7234,9 @@ static void ivb_update_cursor(struct drm_crtc *crtc, u32 base)
|
|||||||
intel_crtc->cursor_visible = visible;
|
intel_crtc->cursor_visible = visible;
|
||||||
}
|
}
|
||||||
/* and commit changes on next vblank */
|
/* and commit changes on next vblank */
|
||||||
|
POSTING_READ(CURCNTR_IVB(pipe));
|
||||||
I915_WRITE(CURBASE_IVB(pipe), base);
|
I915_WRITE(CURBASE_IVB(pipe), base);
|
||||||
|
POSTING_READ(CURBASE_IVB(pipe));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If no-part of the cursor is visible on the framebuffer, then the GPU may hang... */
|
/* If no-part of the cursor is visible on the framebuffer, then the GPU may hang... */
|
||||||
@ -9248,8 +9271,7 @@ check_crtc_state(struct drm_device *dev)
|
|||||||
enum pipe pipe;
|
enum pipe pipe;
|
||||||
if (encoder->base.crtc != &crtc->base)
|
if (encoder->base.crtc != &crtc->base)
|
||||||
continue;
|
continue;
|
||||||
if (encoder->get_config &&
|
if (encoder->get_hw_state(encoder, &pipe))
|
||||||
encoder->get_hw_state(encoder, &pipe))
|
|
||||||
encoder->get_config(encoder, &pipe_config);
|
encoder->get_config(encoder, &pipe_config);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -10909,8 +10931,7 @@ static void intel_modeset_readout_hw_state(struct drm_device *dev)
|
|||||||
if (encoder->get_hw_state(encoder, &pipe)) {
|
if (encoder->get_hw_state(encoder, &pipe)) {
|
||||||
crtc = to_intel_crtc(dev_priv->pipe_to_crtc_mapping[pipe]);
|
crtc = to_intel_crtc(dev_priv->pipe_to_crtc_mapping[pipe]);
|
||||||
encoder->base.crtc = &crtc->base;
|
encoder->base.crtc = &crtc->base;
|
||||||
if (encoder->get_config)
|
encoder->get_config(encoder, &crtc->config);
|
||||||
encoder->get_config(encoder, &crtc->config);
|
|
||||||
} else {
|
} else {
|
||||||
encoder->base.crtc = NULL;
|
encoder->base.crtc = NULL;
|
||||||
}
|
}
|
||||||
|
@ -1774,7 +1774,7 @@ static void intel_disable_dp(struct intel_encoder *encoder)
|
|||||||
* ensure that we have vdd while we switch off the panel. */
|
* ensure that we have vdd while we switch off the panel. */
|
||||||
ironlake_edp_panel_vdd_on(intel_dp);
|
ironlake_edp_panel_vdd_on(intel_dp);
|
||||||
ironlake_edp_backlight_off(intel_dp);
|
ironlake_edp_backlight_off(intel_dp);
|
||||||
intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_ON);
|
intel_dp_sink_dpms(intel_dp, DRM_MODE_DPMS_OFF);
|
||||||
ironlake_edp_panel_off(intel_dp);
|
ironlake_edp_panel_off(intel_dp);
|
||||||
|
|
||||||
/* cpu edp my only be disable _after_ the cpu pipe/plane is disabled. */
|
/* cpu edp my only be disable _after_ the cpu pipe/plane is disabled. */
|
||||||
|
@ -1625,7 +1625,7 @@ static void i9xx_update_wm(struct drm_crtc *unused_crtc)
|
|||||||
&to_intel_crtc(enabled)->config.adjusted_mode;
|
&to_intel_crtc(enabled)->config.adjusted_mode;
|
||||||
int clock = adjusted_mode->crtc_clock;
|
int clock = adjusted_mode->crtc_clock;
|
||||||
int htotal = adjusted_mode->htotal;
|
int htotal = adjusted_mode->htotal;
|
||||||
int hdisplay = to_intel_crtc(crtc)->config.pipe_src_w;
|
int hdisplay = to_intel_crtc(enabled)->config.pipe_src_w;
|
||||||
int pixel_size = enabled->fb->bits_per_pixel / 8;
|
int pixel_size = enabled->fb->bits_per_pixel / 8;
|
||||||
unsigned long line_time_us;
|
unsigned long line_time_us;
|
||||||
int entries;
|
int entries;
|
||||||
@ -3888,7 +3888,7 @@ static void gen6_enable_rps(struct drm_device *dev)
|
|||||||
|
|
||||||
I915_WRITE(GEN6_RC_SLEEP, 0);
|
I915_WRITE(GEN6_RC_SLEEP, 0);
|
||||||
I915_WRITE(GEN6_RC1e_THRESHOLD, 1000);
|
I915_WRITE(GEN6_RC1e_THRESHOLD, 1000);
|
||||||
if (INTEL_INFO(dev)->gen <= 6 || IS_IVYBRIDGE(dev))
|
if (IS_IVYBRIDGE(dev))
|
||||||
I915_WRITE(GEN6_RC6_THRESHOLD, 125000);
|
I915_WRITE(GEN6_RC6_THRESHOLD, 125000);
|
||||||
else
|
else
|
||||||
I915_WRITE(GEN6_RC6_THRESHOLD, 50000);
|
I915_WRITE(GEN6_RC6_THRESHOLD, 50000);
|
||||||
|
@ -902,6 +902,13 @@ intel_tv_mode_valid(struct drm_connector *connector,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
intel_tv_get_config(struct intel_encoder *encoder,
|
||||||
|
struct intel_crtc_config *pipe_config)
|
||||||
|
{
|
||||||
|
pipe_config->adjusted_mode.crtc_clock = pipe_config->port_clock;
|
||||||
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
intel_tv_compute_config(struct intel_encoder *encoder,
|
intel_tv_compute_config(struct intel_encoder *encoder,
|
||||||
struct intel_crtc_config *pipe_config)
|
struct intel_crtc_config *pipe_config)
|
||||||
@ -1621,6 +1628,7 @@ intel_tv_init(struct drm_device *dev)
|
|||||||
DRM_MODE_ENCODER_TVDAC);
|
DRM_MODE_ENCODER_TVDAC);
|
||||||
|
|
||||||
intel_encoder->compute_config = intel_tv_compute_config;
|
intel_encoder->compute_config = intel_tv_compute_config;
|
||||||
|
intel_encoder->get_config = intel_tv_get_config;
|
||||||
intel_encoder->mode_set = intel_tv_mode_set;
|
intel_encoder->mode_set = intel_tv_mode_set;
|
||||||
intel_encoder->enable = intel_enable_tv;
|
intel_encoder->enable = intel_enable_tv;
|
||||||
intel_encoder->disable = intel_disable_tv;
|
intel_encoder->disable = intel_disable_tv;
|
||||||
|
@ -217,6 +217,19 @@ static void gen6_force_wake_work(struct work_struct *work)
|
|||||||
spin_unlock_irqrestore(&dev_priv->uncore.lock, irqflags);
|
spin_unlock_irqrestore(&dev_priv->uncore.lock, irqflags);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void intel_uncore_forcewake_reset(struct drm_device *dev)
|
||||||
|
{
|
||||||
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
||||||
|
|
||||||
|
if (IS_VALLEYVIEW(dev)) {
|
||||||
|
vlv_force_wake_reset(dev_priv);
|
||||||
|
} else if (INTEL_INFO(dev)->gen >= 6) {
|
||||||
|
__gen6_gt_force_wake_reset(dev_priv);
|
||||||
|
if (IS_IVYBRIDGE(dev) || IS_HASWELL(dev))
|
||||||
|
__gen6_gt_force_wake_mt_reset(dev_priv);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void intel_uncore_early_sanitize(struct drm_device *dev)
|
void intel_uncore_early_sanitize(struct drm_device *dev)
|
||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = dev->dev_private;
|
struct drm_i915_private *dev_priv = dev->dev_private;
|
||||||
@ -234,19 +247,8 @@ void intel_uncore_early_sanitize(struct drm_device *dev)
|
|||||||
dev_priv->ellc_size = 128;
|
dev_priv->ellc_size = 128;
|
||||||
DRM_INFO("Found %zuMB of eLLC\n", dev_priv->ellc_size);
|
DRM_INFO("Found %zuMB of eLLC\n", dev_priv->ellc_size);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
static void intel_uncore_forcewake_reset(struct drm_device *dev)
|
intel_uncore_forcewake_reset(dev);
|
||||||
{
|
|
||||||
struct drm_i915_private *dev_priv = dev->dev_private;
|
|
||||||
|
|
||||||
if (IS_VALLEYVIEW(dev)) {
|
|
||||||
vlv_force_wake_reset(dev_priv);
|
|
||||||
} else if (INTEL_INFO(dev)->gen >= 6) {
|
|
||||||
__gen6_gt_force_wake_reset(dev_priv);
|
|
||||||
if (IS_IVYBRIDGE(dev) || IS_HASWELL(dev))
|
|
||||||
__gen6_gt_force_wake_mt_reset(dev_priv);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void intel_uncore_sanitize(struct drm_device *dev)
|
void intel_uncore_sanitize(struct drm_device *dev)
|
||||||
|
Loading…
Reference in New Issue
Block a user