Skip to content

Commit 914a4fd

Browse files
committed
drm/i915/gen9+: Fix initial readout for Y tiled framebuffers
If BIOS configured a Y tiled FB we failed to set up the backing object tiling accordingly, leading to a lack of GT fence installed and a garbled console. The problem was bisected to commit 011f22e ("drm/i915: Do NOT skip the first 4k of stolen memory for pre-allocated buffers v2") but it just revealed a pre-existing issue. Kudos to Ville who suspected a missing fence looking at the corruption on the screen. Cc: Ville Syrjälä <ville.syrjala@linux.intel.com> Cc: Mika Westerberg <mika.westerberg@linux.intel.com> Cc: Hans de Goede <hdegoede@redhat.com> Cc: <ronald@innovation.ch> Cc: <stable@vger.kernel.org> Reported-by: Mika Westerberg <mika.westerberg@linux.intel.com> Reported-by: <ronald@innovation.ch> Tested-by: <ronald@innovation.ch> Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=108264 Fixes: bc8d7df ("drm/i915/skl: Provide a Skylake version of get_plane_config()") Signed-off-by: Imre Deak <imre.deak@intel.com> Reviewed-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20181016160011.28347-1-imre.deak@intel.com
1 parent ad52fcc commit 914a4fd

File tree

1 file changed

+23
-2
lines changed

1 file changed

+23
-2
lines changed

drivers/gpu/drm/i915/intel_display.c

Lines changed: 23 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2673,6 +2673,17 @@ intel_alloc_initial_plane_obj(struct intel_crtc *crtc,
26732673
if (size_aligned * 2 > dev_priv->stolen_usable_size)
26742674
return false;
26752675

2676+
switch (fb->modifier) {
2677+
case DRM_FORMAT_MOD_LINEAR:
2678+
case I915_FORMAT_MOD_X_TILED:
2679+
case I915_FORMAT_MOD_Y_TILED:
2680+
break;
2681+
default:
2682+
DRM_DEBUG_DRIVER("Unsupported modifier for initial FB: 0x%llx\n",
2683+
fb->modifier);
2684+
return false;
2685+
}
2686+
26762687
mutex_lock(&dev->struct_mutex);
26772688
obj = i915_gem_object_create_stolen_for_preallocated(dev_priv,
26782689
base_aligned,
@@ -2682,8 +2693,17 @@ intel_alloc_initial_plane_obj(struct intel_crtc *crtc,
26822693
if (!obj)
26832694
return false;
26842695

2685-
if (plane_config->tiling == I915_TILING_X)
2686-
obj->tiling_and_stride = fb->pitches[0] | I915_TILING_X;
2696+
switch (plane_config->tiling) {
2697+
case I915_TILING_NONE:
2698+
break;
2699+
case I915_TILING_X:
2700+
case I915_TILING_Y:
2701+
obj->tiling_and_stride = fb->pitches[0] | plane_config->tiling;
2702+
break;
2703+
default:
2704+
MISSING_CASE(plane_config->tiling);
2705+
return false;
2706+
}
26872707

26882708
mode_cmd.pixel_format = fb->format->format;
26892709
mode_cmd.width = fb->width;
@@ -8837,6 +8857,7 @@ skylake_get_initial_plane_config(struct intel_crtc *crtc,
88378857
fb->modifier = I915_FORMAT_MOD_X_TILED;
88388858
break;
88398859
case PLANE_CTL_TILED_Y:
8860+
plane_config->tiling = I915_TILING_Y;
88408861
if (val & PLANE_CTL_RENDER_DECOMPRESSION_ENABLE)
88418862
fb->modifier = I915_FORMAT_MOD_Y_TILED_CCS;
88428863
else

0 commit comments

Comments
 (0)