mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-09 15:29:16 +00:00
Merge tag 'drm-intel-fixes-2021-05-14' of git://anongit.freedesktop.org/drm/drm-intel into drm-fixes
drm/i915 fixes for v5.13-rc2: - Fix active callback alignment annotations and subsequent crashes - Retract link training strategy to slow and wide, again - Avoid division by zero on gen2 - Use correct width reads for C0DRB3/C1DRB3 registers - Fix double free in pdp allocation failure path - Fix HDMI 2.1 PCON downstream caps check Signed-off-by: Dave Airlie <airlied@redhat.com> From: Jani Nikula <jani.nikula@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/87a6oxu9ao.fsf@intel.com
This commit is contained in:
commit
89cd34a14e
@ -1095,44 +1095,6 @@ intel_dp_compute_link_config_wide(struct intel_dp *intel_dp,
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Optimize link config in order: max bpp, min lanes, min clock */
|
|
||||||
static int
|
|
||||||
intel_dp_compute_link_config_fast(struct intel_dp *intel_dp,
|
|
||||||
struct intel_crtc_state *pipe_config,
|
|
||||||
const struct link_config_limits *limits)
|
|
||||||
{
|
|
||||||
const struct drm_display_mode *adjusted_mode = &pipe_config->hw.adjusted_mode;
|
|
||||||
int bpp, clock, lane_count;
|
|
||||||
int mode_rate, link_clock, link_avail;
|
|
||||||
|
|
||||||
for (bpp = limits->max_bpp; bpp >= limits->min_bpp; bpp -= 2 * 3) {
|
|
||||||
int output_bpp = intel_dp_output_bpp(pipe_config->output_format, bpp);
|
|
||||||
|
|
||||||
mode_rate = intel_dp_link_required(adjusted_mode->crtc_clock,
|
|
||||||
output_bpp);
|
|
||||||
|
|
||||||
for (lane_count = limits->min_lane_count;
|
|
||||||
lane_count <= limits->max_lane_count;
|
|
||||||
lane_count <<= 1) {
|
|
||||||
for (clock = limits->min_clock; clock <= limits->max_clock; clock++) {
|
|
||||||
link_clock = intel_dp->common_rates[clock];
|
|
||||||
link_avail = intel_dp_max_data_rate(link_clock,
|
|
||||||
lane_count);
|
|
||||||
|
|
||||||
if (mode_rate <= link_avail) {
|
|
||||||
pipe_config->lane_count = lane_count;
|
|
||||||
pipe_config->pipe_bpp = bpp;
|
|
||||||
pipe_config->port_clock = link_clock;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return -EINVAL;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int intel_dp_dsc_compute_bpp(struct intel_dp *intel_dp, u8 dsc_max_bpc)
|
static int intel_dp_dsc_compute_bpp(struct intel_dp *intel_dp, u8 dsc_max_bpc)
|
||||||
{
|
{
|
||||||
int i, num_bpc;
|
int i, num_bpc;
|
||||||
@ -1382,22 +1344,11 @@ intel_dp_compute_link_config(struct intel_encoder *encoder,
|
|||||||
intel_dp_can_bigjoiner(intel_dp))
|
intel_dp_can_bigjoiner(intel_dp))
|
||||||
pipe_config->bigjoiner = true;
|
pipe_config->bigjoiner = true;
|
||||||
|
|
||||||
if (intel_dp_is_edp(intel_dp))
|
/*
|
||||||
/*
|
* Optimize for slow and wide for everything, because there are some
|
||||||
* Optimize for fast and narrow. eDP 1.3 section 3.3 and eDP 1.4
|
* eDP 1.3 and 1.4 panels don't work well with fast and narrow.
|
||||||
* section A.1: "It is recommended that the minimum number of
|
*/
|
||||||
* lanes be used, using the minimum link rate allowed for that
|
ret = intel_dp_compute_link_config_wide(intel_dp, pipe_config, &limits);
|
||||||
* lane configuration."
|
|
||||||
*
|
|
||||||
* Note that we fall back to the max clock and lane count for eDP
|
|
||||||
* panels that fail with the fast optimal settings (see
|
|
||||||
* intel_dp->use_max_params), in which case the fast vs. wide
|
|
||||||
* choice doesn't matter.
|
|
||||||
*/
|
|
||||||
ret = intel_dp_compute_link_config_fast(intel_dp, pipe_config, &limits);
|
|
||||||
else
|
|
||||||
/* Optimize for slow and wide. */
|
|
||||||
ret = intel_dp_compute_link_config_wide(intel_dp, pipe_config, &limits);
|
|
||||||
|
|
||||||
/* enable compression if the mode doesn't fit available BW */
|
/* enable compression if the mode doesn't fit available BW */
|
||||||
drm_dbg_kms(&i915->drm, "Force DSC en = %d\n", intel_dp->force_dsc_en);
|
drm_dbg_kms(&i915->drm, "Force DSC en = %d\n", intel_dp->force_dsc_en);
|
||||||
@ -2160,7 +2111,7 @@ void intel_dp_check_frl_training(struct intel_dp *intel_dp)
|
|||||||
* -PCON supports SRC_CTL_MODE (VESA DP2.0-HDMI2.1 PCON Spec Draft-1 Sec-7)
|
* -PCON supports SRC_CTL_MODE (VESA DP2.0-HDMI2.1 PCON Spec Draft-1 Sec-7)
|
||||||
* -sink is HDMI2.1
|
* -sink is HDMI2.1
|
||||||
*/
|
*/
|
||||||
if (!(intel_dp->dpcd[2] & DP_PCON_SOURCE_CTL_MODE) ||
|
if (!(intel_dp->downstream_ports[2] & DP_PCON_SOURCE_CTL_MODE) ||
|
||||||
!intel_dp_is_hdmi_2_1_sink(intel_dp) ||
|
!intel_dp_is_hdmi_2_1_sink(intel_dp) ||
|
||||||
intel_dp->frl.is_trained)
|
intel_dp->frl.is_trained)
|
||||||
return;
|
return;
|
||||||
|
@ -383,7 +383,7 @@ static void intel_overlay_off_tail(struct intel_overlay *overlay)
|
|||||||
i830_overlay_clock_gating(dev_priv, true);
|
i830_overlay_clock_gating(dev_priv, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
__i915_active_call static void
|
||||||
intel_overlay_last_flip_retire(struct i915_active *active)
|
intel_overlay_last_flip_retire(struct i915_active *active)
|
||||||
{
|
{
|
||||||
struct intel_overlay *overlay =
|
struct intel_overlay *overlay =
|
||||||
|
@ -189,7 +189,7 @@ compute_partial_view(const struct drm_i915_gem_object *obj,
|
|||||||
struct i915_ggtt_view view;
|
struct i915_ggtt_view view;
|
||||||
|
|
||||||
if (i915_gem_object_is_tiled(obj))
|
if (i915_gem_object_is_tiled(obj))
|
||||||
chunk = roundup(chunk, tile_row_pages(obj));
|
chunk = roundup(chunk, tile_row_pages(obj) ?: 1);
|
||||||
|
|
||||||
view.type = I915_GGTT_VIEW_PARTIAL;
|
view.type = I915_GGTT_VIEW_PARTIAL;
|
||||||
view.partial.offset = rounddown(page_offset, chunk);
|
view.partial.offset = rounddown(page_offset, chunk);
|
||||||
|
@ -641,7 +641,6 @@ static int gen8_preallocate_top_level_pdp(struct i915_ppgtt *ppgtt)
|
|||||||
|
|
||||||
err = pin_pt_dma(vm, pde->pt.base);
|
err = pin_pt_dma(vm, pde->pt.base);
|
||||||
if (err) {
|
if (err) {
|
||||||
i915_gem_object_put(pde->pt.base);
|
|
||||||
free_pd(vm, pde);
|
free_pd(vm, pde);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
@ -653,8 +653,8 @@ static void detect_bit_6_swizzle(struct i915_ggtt *ggtt)
|
|||||||
* banks of memory are paired and unswizzled on the
|
* banks of memory are paired and unswizzled on the
|
||||||
* uneven portion, so leave that as unknown.
|
* uneven portion, so leave that as unknown.
|
||||||
*/
|
*/
|
||||||
if (intel_uncore_read(uncore, C0DRB3) ==
|
if (intel_uncore_read16(uncore, C0DRB3) ==
|
||||||
intel_uncore_read(uncore, C1DRB3)) {
|
intel_uncore_read16(uncore, C1DRB3)) {
|
||||||
swizzle_x = I915_BIT_6_SWIZZLE_9_10;
|
swizzle_x = I915_BIT_6_SWIZZLE_9_10;
|
||||||
swizzle_y = I915_BIT_6_SWIZZLE_9;
|
swizzle_y = I915_BIT_6_SWIZZLE_9;
|
||||||
}
|
}
|
||||||
|
@ -1156,7 +1156,8 @@ static int auto_active(struct i915_active *ref)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void auto_retire(struct i915_active *ref)
|
__i915_active_call static void
|
||||||
|
auto_retire(struct i915_active *ref)
|
||||||
{
|
{
|
||||||
i915_active_put(ref);
|
i915_active_put(ref);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user