Skip to content

Commit 71f0a62

Browse files
committed
drm/i915: Only use sanitized values for ILK watermarks
The raw watermark values are needed when planes are not part of the state, but this introduced a regression and possibly an overflow when merging the watermarks because invalid values may end up used. Solve this by calculating raw watermarks for all levels, and only setting non-zero values when the level is valid. Fixes the SNB warning: WARNING: CPU: 1 PID: 25405 at drivers/gpu/drm/i915/intel_pm.c:2580 ilk_program_watermarks+0x7b2/0x9d0 [i915]() WARN_ON(wm_lp != 1) Modules linked in: i915 drm_kms_helper drm bluetooth fuse iTCO_wdt iTCO_vendor_support syscopyarea sysfillrect sysimgblt fb_sys_fops tpm_tis mei_me e1000e snd_hda_codec_hdmi pcspkr tpm mei i2c_i801 lpc_ich snd_hda_codec snd_hda_core CPU: 1 PID: 25405 Comm: kms_universal_p Tainted: G U W 4.5.0-rc6apollolake+ #462 Hardware name: /DH67GD, BIOS BLH6710H.86A.0160.2012.1204.1156 12/04/2012 0000000000000000 ffff88009d42b918 ffffffff8143cfab ffff88009d42b960 ffffffffa0363580 ffff88009d42b950 ffffffff81082746 ffff8800b9a24928 ffff88009d42ba00 ffff88009d4a0000 0000000000000000 ffff88009d42ba6c Call Trace: [<ffffffff8143cfab>] dump_stack+0x4d/0x72 [<ffffffff81082746>] warn_slowpath_common+0x86/0xc0 [<ffffffff810827cc>] warn_slowpath_fmt+0x4c/0x50 [<ffffffffa0292862>] ilk_program_watermarks+0x7b2/0x9d0 [i915] [<ffffffffa0292cb7>] ilk_initial_watermarks+0x107/0x120 [i915] [<ffffffffa02feffa>] intel_pre_plane_update+0x12a/0x190 [i915] [<ffffffffa02ffb36>] intel_atomic_commit+0x546/0xd50 [i915] [<ffffffffa012c9e7>] drm_atomic_commit+0x37/0x60 [drm] [<ffffffffa0217361>] drm_atomic_helper_disable_plane+0xb1/0xf0 [drm_kms_helper] [<ffffffffa011cdb4>] __setplane_internal+0x184/0x280 [drm] [<ffffffffa012b57a>] ? drm_modeset_lock_all_ctx+0x9a/0xb0 [drm] [<ffffffffa012010f>] drm_mode_setplane+0x13f/0x1c0 [drm] [<ffffffffa0111b52>] drm_ioctl+0x142/0x590 [drm] [<ffffffffa011ffd0>] ? drm_plane_check_pixel_format+0x50/0x50 [drm] [<ffffffff811f2744>] ? mntput+0x24/0x40 [<ffffffff811d28d4>] ? __fput+0x194/0x200 [<ffffffffa012dec3>] drm_compat_ioctl+0x33/0x40 [drm] [<ffffffffa029e1c2>] i915_compat_ioctl+0x32/0x40 [i915] [<ffffffff81228d72>] compat_SyS_ioctl+0xc2/0x330 [<ffffffff810021d5>] ? exit_to_usermode_loop+0x95/0xb0 [<ffffffff81002d2e>] do_fast_syscall_32+0x9e/0x210 [<ffffffff8197faf2>] entry_SYSENTER_compat+0x52/0x70 Cc: Matt Roper <[email protected]> Cc: Chris Wilson <[email protected]> Cc: Paulo Zanoni <[email protected]> Cc: Ville Syrjälä <[email protected]> Testcase: kms_universal_plane Fixes: d81f04c ("drm/i915: Allow preservation of watermarks, v2.") Signed-off-by: Maarten Lankhorst <[email protected]> Link: http://patchwork.freedesktop.org/patch/msgid/[email protected] Reviewed-by: Ville Syrjälä <[email protected]>
1 parent acad889 commit 71f0a62

File tree

2 files changed

+12
-8
lines changed

2 files changed

+12
-8
lines changed

drivers/gpu/drm/i915/intel_drv.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -390,6 +390,7 @@ struct intel_crtc_scaler_state {
390390

391391
struct intel_pipe_wm {
392392
struct intel_wm_level wm[5];
393+
struct intel_wm_level raw_wm[5];
393394
uint32_t linetime;
394395
bool fbc_wm_enabled;
395396
bool pipe_enabled;

drivers/gpu/drm/i915/intel_pm.c

Lines changed: 11 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -2335,7 +2335,6 @@ static int ilk_compute_pipe_wm(struct intel_crtc_state *cstate)
23352335
drm_rect_height(&sprstate->dst) != drm_rect_height(&sprstate->src) >> 16);
23362336
}
23372337

2338-
23392338
usable_level = max_level;
23402339

23412340
/* ILK/SNB: LP2+ watermarks only w/o sprites */
@@ -2347,7 +2346,10 @@ static int ilk_compute_pipe_wm(struct intel_crtc_state *cstate)
23472346
usable_level = 0;
23482347

23492348
ilk_compute_wm_level(dev_priv, intel_crtc, 0, cstate,
2350-
pristate, sprstate, curstate, &pipe_wm->wm[0]);
2349+
pristate, sprstate, curstate, &pipe_wm->raw_wm[0]);
2350+
2351+
memset(&pipe_wm->wm, 0, sizeof(pipe_wm->wm));
2352+
pipe_wm->wm[0] = pipe_wm->raw_wm[0];
23512353

23522354
if (IS_HASWELL(dev) || IS_BROADWELL(dev))
23532355
pipe_wm->linetime = hsw_compute_linetime_wm(dev, cstate);
@@ -2358,7 +2360,7 @@ static int ilk_compute_pipe_wm(struct intel_crtc_state *cstate)
23582360
ilk_compute_wm_reg_maximums(dev, 1, &max);
23592361

23602362
for (level = 1; level <= max_level; level++) {
2361-
struct intel_wm_level *wm = &pipe_wm->wm[level];
2363+
struct intel_wm_level *wm = &pipe_wm->raw_wm[level];
23622364

23632365
ilk_compute_wm_level(dev_priv, intel_crtc, level, cstate,
23642366
pristate, sprstate, curstate, wm);
@@ -2368,12 +2370,13 @@ static int ilk_compute_pipe_wm(struct intel_crtc_state *cstate)
23682370
* register maximums since such watermarks are
23692371
* always invalid.
23702372
*/
2371-
if (level > usable_level) {
2372-
wm->enable = false;
2373-
} else if (!ilk_validate_wm_level(level, &max, wm)) {
2374-
wm->enable = false;
2373+
if (level > usable_level)
2374+
continue;
2375+
2376+
if (ilk_validate_wm_level(level, &max, wm))
2377+
pipe_wm->wm[level] = *wm;
2378+
else
23752379
usable_level = level;
2376-
}
23772380
}
23782381

23792382
return 0;

0 commit comments

Comments
 (0)