summaryrefslogtreecommitdiff
path: root/tests/kms_frontbuffer_tracking.c
diff options
context:
space:
mode:
authorMaarten Lankhorst <maarten.lankhorst@linux.intel.com>2018-02-26 10:57:47 +0100
committerMaarten Lankhorst <maarten.lankhorst@linux.intel.com>2018-08-30 11:10:36 +0200
commit6feed199d8564f775e26f3cc631b74d56ba1b5c1 (patch)
treee9d1d7b182a7f661a129b52a4dd6c8594e1756c9 /tests/kms_frontbuffer_tracking.c
parent809612336137296c8dbfab415a4083d5dce148ef (diff)
tests/kms_frontbuffer_tracking: Remove redundant modesets for toggling features, v5.
Disabling PSR and FBC used to require a commit, but now that changes to FBC take effect after the next commit, and PSR is toggled through debugfs we can skip those modesets. Changes since v1: - Try to avoid modesets for PSR if the kernel supports it, but otherwise force a modeset for the changes to take effect. Changes since v2: - Rebase on top of previous PSR changes. Changes since v3: - Rebase on move to lib/igt_psr. Changes since v4: - Split out related changes. (dhnkrn) Signed-off-by: Maarten Lankhorst <maarten.lankhorst@linux.intel.com> Reviewed-by: Dhinakaran Pandiyan <dhinakaran.pandiyan@intel.com>
Diffstat (limited to 'tests/kms_frontbuffer_tracking.c')
-rw-r--r--tests/kms_frontbuffer_tracking.c28
1 files changed, 19 insertions, 9 deletions
diff --git a/tests/kms_frontbuffer_tracking.c b/tests/kms_frontbuffer_tracking.c
index 07b70fbf..a570f93a 100644
--- a/tests/kms_frontbuffer_tracking.c
+++ b/tests/kms_frontbuffer_tracking.c
@@ -1129,14 +1129,14 @@ static void unset_all_crtcs(void)
igt_display_commit(&drm.display);
}
-static void disable_features(const struct test_mode *t)
+static bool disable_features(const struct test_mode *t)
{
if (t->feature == FEATURE_DEFAULT)
- return;
+ return false;
fbc_disable();
- psr_disable(drm.debugfs);
drrs_disable();
+ return psr_disable(drm.debugfs);
}
static void *busy_thread_func(void *data)
@@ -1717,17 +1717,21 @@ static void set_region_for_test(const struct test_mode *t,
do_assertions(ASSERT_NO_ACTION_CHANGE);
}
-static void enable_features_for_test(const struct test_mode *t)
+static bool enable_features_for_test(const struct test_mode *t)
{
+ bool ret = false;
+
if (t->feature == FEATURE_DEFAULT)
- return;
+ return false;
if (t->feature & FEATURE_FBC)
fbc_enable();
if (t->feature & FEATURE_PSR)
- psr_enable(drm.debugfs);
+ ret = psr_enable(drm.debugfs);
if (t->feature & FEATURE_DRRS)
drrs_enable();
+
+ return ret;
}
static void check_test_requirements(const struct test_mode *t)
@@ -1809,23 +1813,29 @@ static void set_crtc_fbs(const struct test_mode *t)
static void prepare_subtest_data(const struct test_mode *t,
struct draw_pattern_info *pattern)
{
+ bool need_modeset;
+
check_test_requirements(t);
stop_busy_thread();
- disable_features(t);
+ need_modeset = disable_features(t);
set_crtc_fbs(t);
if (t->screen == SCREEN_OFFSCREEN)
fill_fb_region(&offscreen_fb, COLOR_OFFSCREEN_BG);
- unset_all_crtcs();
+ igt_display_reset(&drm.display);
+ if (need_modeset)
+ igt_display_commit(&drm.display);
init_blue_crc(t->format);
if (pattern)
init_crcs(t->format, pattern);
- enable_features_for_test(t);
+ need_modeset = enable_features_for_test(t);
+ if (need_modeset)
+ igt_display_commit(&drm.display);
}
static void prepare_subtest_screens(const struct test_mode *t)