Merge tag 'drm-intel-fixes-2021-10-07' of git://anongit.freedesktop.org/drm/drm-intel into drm-fixes
drm/i915 fixes for v5.15-rc5: - Fix RKL HDMI audio - Fix runtime pm imbalance on i915_gem_shrink() error path - Fix Type-C port access before hw/sw state sync - Fix VBT backlight struct version/size check - Fix VT-d async flip on SKL/BXT with plane stretch workaround Signed-off-by: Dave Airlie <airlied@redhat.com> From: Jani Nikula <jani.nikula@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/87k0ipywo4.fsf@intel.com
This commit is contained in:
commit
7d80cc702f
@ -1577,8 +1577,14 @@ static void gen11_dsi_sync_state(struct intel_encoder *encoder,
|
|||||||
const struct intel_crtc_state *crtc_state)
|
const struct intel_crtc_state *crtc_state)
|
||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
|
struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
|
||||||
struct intel_crtc *intel_crtc = to_intel_crtc(crtc_state->uapi.crtc);
|
struct intel_crtc *intel_crtc;
|
||||||
enum pipe pipe = intel_crtc->pipe;
|
enum pipe pipe;
|
||||||
|
|
||||||
|
if (!crtc_state)
|
||||||
|
return;
|
||||||
|
|
||||||
|
intel_crtc = to_intel_crtc(crtc_state->uapi.crtc);
|
||||||
|
pipe = intel_crtc->pipe;
|
||||||
|
|
||||||
/* wa verify 1409054076:icl,jsl,ehl */
|
/* wa verify 1409054076:icl,jsl,ehl */
|
||||||
if (DISPLAY_VER(dev_priv) == 11 && pipe == PIPE_B &&
|
if (DISPLAY_VER(dev_priv) == 11 && pipe == PIPE_B &&
|
||||||
|
@ -1308,8 +1308,9 @@ static void i915_audio_component_init(struct drm_i915_private *dev_priv)
|
|||||||
else
|
else
|
||||||
aud_freq = aud_freq_init;
|
aud_freq = aud_freq_init;
|
||||||
|
|
||||||
/* use BIOS provided value for TGL unless it is a known bad value */
|
/* use BIOS provided value for TGL and RKL unless it is a known bad value */
|
||||||
if (IS_TIGERLAKE(dev_priv) && aud_freq_init != AUD_FREQ_TGL_BROKEN)
|
if ((IS_TIGERLAKE(dev_priv) || IS_ROCKETLAKE(dev_priv)) &&
|
||||||
|
aud_freq_init != AUD_FREQ_TGL_BROKEN)
|
||||||
aud_freq = aud_freq_init;
|
aud_freq = aud_freq_init;
|
||||||
|
|
||||||
drm_dbg_kms(&dev_priv->drm, "use AUD_FREQ_CNTRL of 0x%x (init value 0x%x)\n",
|
drm_dbg_kms(&dev_priv->drm, "use AUD_FREQ_CNTRL of 0x%x (init value 0x%x)\n",
|
||||||
|
@ -451,14 +451,24 @@ parse_lfp_backlight(struct drm_i915_private *i915,
|
|||||||
}
|
}
|
||||||
|
|
||||||
i915->vbt.backlight.type = INTEL_BACKLIGHT_DISPLAY_DDI;
|
i915->vbt.backlight.type = INTEL_BACKLIGHT_DISPLAY_DDI;
|
||||||
if (bdb->version >= 191 &&
|
if (bdb->version >= 191) {
|
||||||
get_blocksize(backlight_data) >= sizeof(*backlight_data)) {
|
size_t exp_size;
|
||||||
|
|
||||||
|
if (bdb->version >= 236)
|
||||||
|
exp_size = sizeof(struct bdb_lfp_backlight_data);
|
||||||
|
else if (bdb->version >= 234)
|
||||||
|
exp_size = EXP_BDB_LFP_BL_DATA_SIZE_REV_234;
|
||||||
|
else
|
||||||
|
exp_size = EXP_BDB_LFP_BL_DATA_SIZE_REV_191;
|
||||||
|
|
||||||
|
if (get_blocksize(backlight_data) >= exp_size) {
|
||||||
const struct lfp_backlight_control_method *method;
|
const struct lfp_backlight_control_method *method;
|
||||||
|
|
||||||
method = &backlight_data->backlight_control[panel_type];
|
method = &backlight_data->backlight_control[panel_type];
|
||||||
i915->vbt.backlight.type = method->type;
|
i915->vbt.backlight.type = method->type;
|
||||||
i915->vbt.backlight.controller = method->controller;
|
i915->vbt.backlight.controller = method->controller;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
i915->vbt.backlight.pwm_freq_hz = entry->pwm_freq_hz;
|
i915->vbt.backlight.pwm_freq_hz = entry->pwm_freq_hz;
|
||||||
i915->vbt.backlight.active_low_pwm = entry->active_low_pwm;
|
i915->vbt.backlight.active_low_pwm = entry->active_low_pwm;
|
||||||
|
@ -3807,7 +3807,13 @@ void hsw_ddi_get_config(struct intel_encoder *encoder,
|
|||||||
static void intel_ddi_sync_state(struct intel_encoder *encoder,
|
static void intel_ddi_sync_state(struct intel_encoder *encoder,
|
||||||
const struct intel_crtc_state *crtc_state)
|
const struct intel_crtc_state *crtc_state)
|
||||||
{
|
{
|
||||||
if (intel_crtc_has_dp_encoder(crtc_state))
|
struct drm_i915_private *i915 = to_i915(encoder->base.dev);
|
||||||
|
enum phy phy = intel_port_to_phy(i915, encoder->port);
|
||||||
|
|
||||||
|
if (intel_phy_is_tc(i915, phy))
|
||||||
|
intel_tc_port_sanitize(enc_to_dig_port(encoder));
|
||||||
|
|
||||||
|
if (crtc_state && intel_crtc_has_dp_encoder(crtc_state))
|
||||||
intel_dp_sync_state(encoder, crtc_state);
|
intel_dp_sync_state(encoder, crtc_state);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -13082,18 +13082,16 @@ static void intel_modeset_readout_hw_state(struct drm_device *dev)
|
|||||||
readout_plane_state(dev_priv);
|
readout_plane_state(dev_priv);
|
||||||
|
|
||||||
for_each_intel_encoder(dev, encoder) {
|
for_each_intel_encoder(dev, encoder) {
|
||||||
|
struct intel_crtc_state *crtc_state = NULL;
|
||||||
|
|
||||||
pipe = 0;
|
pipe = 0;
|
||||||
|
|
||||||
if (encoder->get_hw_state(encoder, &pipe)) {
|
if (encoder->get_hw_state(encoder, &pipe)) {
|
||||||
struct intel_crtc_state *crtc_state;
|
|
||||||
|
|
||||||
crtc = intel_get_crtc_for_pipe(dev_priv, pipe);
|
crtc = intel_get_crtc_for_pipe(dev_priv, pipe);
|
||||||
crtc_state = to_intel_crtc_state(crtc->base.state);
|
crtc_state = to_intel_crtc_state(crtc->base.state);
|
||||||
|
|
||||||
encoder->base.crtc = &crtc->base;
|
encoder->base.crtc = &crtc->base;
|
||||||
intel_encoder_get_config(encoder, crtc_state);
|
intel_encoder_get_config(encoder, crtc_state);
|
||||||
if (encoder->sync_state)
|
|
||||||
encoder->sync_state(encoder, crtc_state);
|
|
||||||
|
|
||||||
/* read out to slave crtc as well for bigjoiner */
|
/* read out to slave crtc as well for bigjoiner */
|
||||||
if (crtc_state->bigjoiner) {
|
if (crtc_state->bigjoiner) {
|
||||||
@ -13108,6 +13106,9 @@ static void intel_modeset_readout_hw_state(struct drm_device *dev)
|
|||||||
encoder->base.crtc = NULL;
|
encoder->base.crtc = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (encoder->sync_state)
|
||||||
|
encoder->sync_state(encoder, crtc_state);
|
||||||
|
|
||||||
drm_dbg_kms(&dev_priv->drm,
|
drm_dbg_kms(&dev_priv->drm,
|
||||||
"[ENCODER:%d:%s] hw state readout: %s, pipe %c\n",
|
"[ENCODER:%d:%s] hw state readout: %s, pipe %c\n",
|
||||||
encoder->base.base.id, encoder->base.name,
|
encoder->base.base.id, encoder->base.name,
|
||||||
@ -13390,17 +13391,6 @@ intel_modeset_setup_hw_state(struct drm_device *dev,
|
|||||||
intel_modeset_readout_hw_state(dev);
|
intel_modeset_readout_hw_state(dev);
|
||||||
|
|
||||||
/* HW state is read out, now we need to sanitize this mess. */
|
/* HW state is read out, now we need to sanitize this mess. */
|
||||||
|
|
||||||
/* Sanitize the TypeC port mode upfront, encoders depend on this */
|
|
||||||
for_each_intel_encoder(dev, encoder) {
|
|
||||||
enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
|
|
||||||
|
|
||||||
/* We need to sanitize only the MST primary port. */
|
|
||||||
if (encoder->type != INTEL_OUTPUT_DP_MST &&
|
|
||||||
intel_phy_is_tc(dev_priv, phy))
|
|
||||||
intel_tc_port_sanitize(enc_to_dig_port(encoder));
|
|
||||||
}
|
|
||||||
|
|
||||||
get_encoder_power_domains(dev_priv);
|
get_encoder_power_domains(dev_priv);
|
||||||
|
|
||||||
if (HAS_PCH_IBX(dev_priv))
|
if (HAS_PCH_IBX(dev_priv))
|
||||||
|
@ -814,6 +814,11 @@ struct lfp_brightness_level {
|
|||||||
u16 reserved;
|
u16 reserved;
|
||||||
} __packed;
|
} __packed;
|
||||||
|
|
||||||
|
#define EXP_BDB_LFP_BL_DATA_SIZE_REV_191 \
|
||||||
|
offsetof(struct bdb_lfp_backlight_data, brightness_level)
|
||||||
|
#define EXP_BDB_LFP_BL_DATA_SIZE_REV_234 \
|
||||||
|
offsetof(struct bdb_lfp_backlight_data, brightness_precision_bits)
|
||||||
|
|
||||||
struct bdb_lfp_backlight_data {
|
struct bdb_lfp_backlight_data {
|
||||||
u8 entry_size;
|
u8 entry_size;
|
||||||
struct lfp_backlight_data_entry data[16];
|
struct lfp_backlight_data_entry data[16];
|
||||||
|
@ -118,7 +118,7 @@ i915_gem_shrink(struct i915_gem_ww_ctx *ww,
|
|||||||
intel_wakeref_t wakeref = 0;
|
intel_wakeref_t wakeref = 0;
|
||||||
unsigned long count = 0;
|
unsigned long count = 0;
|
||||||
unsigned long scanned = 0;
|
unsigned long scanned = 0;
|
||||||
int err;
|
int err = 0;
|
||||||
|
|
||||||
/* CHV + VTD workaround use stop_machine(); need to trylock vm->mutex */
|
/* CHV + VTD workaround use stop_machine(); need to trylock vm->mutex */
|
||||||
bool trylock_vm = !ww && intel_vm_no_concurrent_access_wa(i915);
|
bool trylock_vm = !ww && intel_vm_no_concurrent_access_wa(i915);
|
||||||
@ -242,12 +242,15 @@ skip:
|
|||||||
list_splice_tail(&still_in_list, phase->list);
|
list_splice_tail(&still_in_list, phase->list);
|
||||||
spin_unlock_irqrestore(&i915->mm.obj_lock, flags);
|
spin_unlock_irqrestore(&i915->mm.obj_lock, flags);
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (shrink & I915_SHRINK_BOUND)
|
if (shrink & I915_SHRINK_BOUND)
|
||||||
intel_runtime_pm_put(&i915->runtime_pm, wakeref);
|
intel_runtime_pm_put(&i915->runtime_pm, wakeref);
|
||||||
|
|
||||||
|
if (err)
|
||||||
|
return err;
|
||||||
|
|
||||||
if (nr_scanned)
|
if (nr_scanned)
|
||||||
*nr_scanned += scanned;
|
*nr_scanned += scanned;
|
||||||
return count;
|
return count;
|
||||||
|
@ -8193,6 +8193,11 @@ enum {
|
|||||||
#define HSW_SPR_STRETCH_MAX_X1 REG_FIELD_PREP(HSW_SPR_STRETCH_MAX_MASK, 3)
|
#define HSW_SPR_STRETCH_MAX_X1 REG_FIELD_PREP(HSW_SPR_STRETCH_MAX_MASK, 3)
|
||||||
#define HSW_FBCQ_DIS (1 << 22)
|
#define HSW_FBCQ_DIS (1 << 22)
|
||||||
#define BDW_DPRS_MASK_VBLANK_SRD (1 << 0)
|
#define BDW_DPRS_MASK_VBLANK_SRD (1 << 0)
|
||||||
|
#define SKL_PLANE1_STRETCH_MAX_MASK REG_GENMASK(1, 0)
|
||||||
|
#define SKL_PLANE1_STRETCH_MAX_X8 REG_FIELD_PREP(SKL_PLANE1_STRETCH_MAX_MASK, 0)
|
||||||
|
#define SKL_PLANE1_STRETCH_MAX_X4 REG_FIELD_PREP(SKL_PLANE1_STRETCH_MAX_MASK, 1)
|
||||||
|
#define SKL_PLANE1_STRETCH_MAX_X2 REG_FIELD_PREP(SKL_PLANE1_STRETCH_MAX_MASK, 2)
|
||||||
|
#define SKL_PLANE1_STRETCH_MAX_X1 REG_FIELD_PREP(SKL_PLANE1_STRETCH_MAX_MASK, 3)
|
||||||
#define CHICKEN_PIPESL_1(pipe) _MMIO_PIPE(pipe, _CHICKEN_PIPESL_1_A, _CHICKEN_PIPESL_1_B)
|
#define CHICKEN_PIPESL_1(pipe) _MMIO_PIPE(pipe, _CHICKEN_PIPESL_1_A, _CHICKEN_PIPESL_1_B)
|
||||||
|
|
||||||
#define _CHICKEN_TRANS_A 0x420c0
|
#define _CHICKEN_TRANS_A 0x420c0
|
||||||
|
@ -76,6 +76,8 @@ struct intel_wm_config {
|
|||||||
|
|
||||||
static void gen9_init_clock_gating(struct drm_i915_private *dev_priv)
|
static void gen9_init_clock_gating(struct drm_i915_private *dev_priv)
|
||||||
{
|
{
|
||||||
|
enum pipe pipe;
|
||||||
|
|
||||||
if (HAS_LLC(dev_priv)) {
|
if (HAS_LLC(dev_priv)) {
|
||||||
/*
|
/*
|
||||||
* WaCompressedResourceDisplayNewHashMode:skl,kbl
|
* WaCompressedResourceDisplayNewHashMode:skl,kbl
|
||||||
@ -89,6 +91,16 @@ static void gen9_init_clock_gating(struct drm_i915_private *dev_priv)
|
|||||||
SKL_DE_COMPRESSED_HASH_MODE);
|
SKL_DE_COMPRESSED_HASH_MODE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for_each_pipe(dev_priv, pipe) {
|
||||||
|
/*
|
||||||
|
* "Plane N strech max must be programmed to 11b (x1)
|
||||||
|
* when Async flips are enabled on that plane."
|
||||||
|
*/
|
||||||
|
if (!IS_GEMINILAKE(dev_priv) && intel_vtd_active())
|
||||||
|
intel_uncore_rmw(&dev_priv->uncore, CHICKEN_PIPESL_1(pipe),
|
||||||
|
SKL_PLANE1_STRETCH_MAX_MASK, SKL_PLANE1_STRETCH_MAX_X1);
|
||||||
|
}
|
||||||
|
|
||||||
/* See Bspec note for PSR2_CTL bit 31, Wa#828:skl,bxt,kbl,cfl */
|
/* See Bspec note for PSR2_CTL bit 31, Wa#828:skl,bxt,kbl,cfl */
|
||||||
intel_uncore_write(&dev_priv->uncore, CHICKEN_PAR1_1,
|
intel_uncore_write(&dev_priv->uncore, CHICKEN_PAR1_1,
|
||||||
intel_uncore_read(&dev_priv->uncore, CHICKEN_PAR1_1) | SKL_EDP_PSR_FIX_RDWRAP);
|
intel_uncore_read(&dev_priv->uncore, CHICKEN_PAR1_1) | SKL_EDP_PSR_FIX_RDWRAP);
|
||||||
|
Loading…
Reference in New Issue
Block a user