diff options
author | Paulo Zanoni <paulo.r.zanoni@intel.com> | 2016-09-22 17:00:32 -0400 |
---|---|---|
committer | Jani Nikula <jani.nikula@intel.com> | 2016-10-10 09:06:39 -0400 |
commit | cf6c525a31fac11b0775b8c06c00a508c6356d9b (patch) | |
tree | 5bdb09fb2f2d27e9b653c43dbb412c0227582b81 | |
parent | ccc1057477bc99678896b51adce6b6ee4019dc37 (diff) |
drm/i915/gen9: fix plane_blocks_per_line on watermarks calculations
The confusing thing is that plane_blocks_per_line is listed as part of
the method 2 calculation but is also used for other things. We
calculated it in two different places and different ways: one inside
skl_wm_method2() and the other inside skl_compute_plane_wm(). The
skl_wm_method2() implementation is the one that matches the
specification.
With this patch we fix the skl_compute_plane_wm() calculation and just
pass it as a parameter to skl_wm_method2(). We also take care to not
modify the value of plane_bytes_per_line since we're going to rely on
it having a correct value in later patches.
This should affect the watermarks for Linear and Y-tiled.
From my analysis, it looks like the two plane_blocks_per_line
variables got out of sync on 0fda65680e92, but we can't really say
that commit was a regression, it looks like just an incomplete fix.
There's always the possibility that 0fda65680e92 matched our
specification at that time, and then later the specification changed.
v2: Try to add a "Fixes" tag (Maarten).
Fixes: 0fda65680e92 ("drm/i915/skl: Update watermarks for Y tiling")
Cc: stable@vger.kernel.org
Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Reviewed-by: Lyude <cpaul@redhat.com>
Reviewed-by: Maarten Lankhorst <maarten.lankhorst@linux.intel.com>
Signed-off-by: Paulo Zanoni <paulo.r.zanoni@intel.com>
Link: http://patchwork.freedesktop.org/patch/msgid/1474578035-424-7-git-send-email-paulo.r.zanoni@intel.com
(cherry picked from commit 7a1a8aed67e0a60772defe3f6499eb340da48634)
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
-rw-r--r-- | drivers/gpu/drm/i915/intel_pm.c | 39 |
1 files changed, 15 insertions, 24 deletions
diff --git a/drivers/gpu/drm/i915/intel_pm.c b/drivers/gpu/drm/i915/intel_pm.c index 32ce9365d763..2f2ced7c6921 100644 --- a/drivers/gpu/drm/i915/intel_pm.c +++ b/drivers/gpu/drm/i915/intel_pm.c | |||
@@ -3494,30 +3494,14 @@ static uint32_t skl_wm_method1(uint32_t pixel_rate, uint8_t cpp, uint32_t latenc | |||
3494 | } | 3494 | } |
3495 | 3495 | ||
3496 | static uint32_t skl_wm_method2(uint32_t pixel_rate, uint32_t pipe_htotal, | 3496 | static uint32_t skl_wm_method2(uint32_t pixel_rate, uint32_t pipe_htotal, |
3497 | uint32_t horiz_pixels, uint8_t cpp, | 3497 | uint32_t latency, uint32_t plane_blocks_per_line) |
3498 | uint64_t tiling, uint32_t latency, | ||
3499 | uint32_t y_min_scanlines) | ||
3500 | { | 3498 | { |
3501 | uint32_t ret; | 3499 | uint32_t ret; |
3502 | uint32_t plane_bytes_per_line, plane_blocks_per_line; | ||
3503 | uint32_t wm_intermediate_val; | 3500 | uint32_t wm_intermediate_val; |
3504 | 3501 | ||
3505 | if (latency == 0) | 3502 | if (latency == 0) |
3506 | return UINT_MAX; | 3503 | return UINT_MAX; |
3507 | 3504 | ||
3508 | plane_bytes_per_line = horiz_pixels * cpp; | ||
3509 | |||
3510 | if (tiling == I915_FORMAT_MOD_Y_TILED || | ||
3511 | tiling == I915_FORMAT_MOD_Yf_TILED) { | ||
3512 | plane_bytes_per_line *= y_min_scanlines; | ||
3513 | plane_blocks_per_line = DIV_ROUND_UP(plane_bytes_per_line, 512); | ||
3514 | plane_blocks_per_line /= y_min_scanlines; | ||
3515 | } else if (tiling == DRM_FORMAT_MOD_NONE) { | ||
3516 | plane_blocks_per_line = DIV_ROUND_UP(plane_bytes_per_line, 512) + 1; | ||
3517 | } else { | ||
3518 | plane_blocks_per_line = DIV_ROUND_UP(plane_bytes_per_line, 512); | ||
3519 | } | ||
3520 | |||
3521 | wm_intermediate_val = latency * pixel_rate; | 3505 | wm_intermediate_val = latency * pixel_rate; |
3522 | ret = DIV_ROUND_UP(wm_intermediate_val, pipe_htotal * 1000) * | 3506 | ret = DIV_ROUND_UP(wm_intermediate_val, pipe_htotal * 1000) * |
3523 | plane_blocks_per_line; | 3507 | plane_blocks_per_line; |
@@ -3606,17 +3590,24 @@ static int skl_compute_plane_wm(const struct drm_i915_private *dev_priv, | |||
3606 | y_min_scanlines = 4; | 3590 | y_min_scanlines = 4; |
3607 | } | 3591 | } |
3608 | 3592 | ||
3593 | plane_bytes_per_line = width * cpp; | ||
3594 | if (fb->modifier[0] == I915_FORMAT_MOD_Y_TILED || | ||
3595 | fb->modifier[0] == I915_FORMAT_MOD_Yf_TILED) { | ||
3596 | plane_blocks_per_line = | ||
3597 | DIV_ROUND_UP(plane_bytes_per_line * y_min_scanlines, 512); | ||
3598 | plane_blocks_per_line /= y_min_scanlines; | ||
3599 | } else if (fb->modifier[0] == DRM_FORMAT_MOD_NONE) { | ||
3600 | plane_blocks_per_line = DIV_ROUND_UP(plane_bytes_per_line, 512) | ||
3601 | + 1; | ||
3602 | } else { | ||
3603 | plane_blocks_per_line = DIV_ROUND_UP(plane_bytes_per_line, 512); | ||
3604 | } | ||
3605 | |||
3609 | method1 = skl_wm_method1(plane_pixel_rate, cpp, latency); | 3606 | method1 = skl_wm_method1(plane_pixel_rate, cpp, latency); |
3610 | method2 = skl_wm_method2(plane_pixel_rate, | 3607 | method2 = skl_wm_method2(plane_pixel_rate, |
3611 | cstate->base.adjusted_mode.crtc_htotal, | 3608 | cstate->base.adjusted_mode.crtc_htotal, |
3612 | width, | ||
3613 | cpp, | ||
3614 | fb->modifier[0], | ||
3615 | latency, | 3609 | latency, |
3616 | y_min_scanlines); | 3610 | plane_blocks_per_line); |
3617 | |||
3618 | plane_bytes_per_line = width * cpp; | ||
3619 | plane_blocks_per_line = DIV_ROUND_UP(plane_bytes_per_line, 512); | ||
3620 | 3611 | ||
3621 | if (fb->modifier[0] == I915_FORMAT_MOD_Y_TILED || | 3612 | if (fb->modifier[0] == I915_FORMAT_MOD_Y_TILED || |
3622 | fb->modifier[0] == I915_FORMAT_MOD_Yf_TILED) { | 3613 | fb->modifier[0] == I915_FORMAT_MOD_Yf_TILED) { |