3 * SPDX-License-Identifier: MIT
5 * Copyright © 2019 Intel Corporation
8 #include "selftest_llc.h"
9 #include "selftest_rc6.h"
10 #include "selftest_rps.h"
12 static int live_gt_resume(void *arg)
14 struct intel_gt *gt = arg;
15 IGT_TIMEOUT(end_time);
18 /* Do several suspend/resume cycles to check we don't explode! */
20 intel_gt_suspend_prepare(gt);
21 intel_gt_suspend_late(gt);
23 if (gt->rc6.enabled) {
24 pr_err("rc6 still enabled after suspend!\n");
25 intel_gt_set_wedged_on_init(gt);
30 err = intel_gt_resume(gt);
34 if (gt->rc6.supported && !gt->rc6.enabled) {
35 pr_err("rc6 not enabled upon resume!\n");
36 intel_gt_set_wedged_on_init(gt);
41 err = st_llc_verify(>->llc);
43 pr_err("llc state not restored upon resume!\n");
44 intel_gt_set_wedged_on_init(gt);
47 } while (!__igt_timeout(end_time, NULL));
52 int intel_gt_pm_live_selftests(struct drm_i915_private *i915)
54 static const struct i915_subtest tests[] = {
55 SUBTEST(live_rc6_manual),
56 SUBTEST(live_rps_frequency),
57 SUBTEST(live_rps_power),
58 SUBTEST(live_rps_interrupt),
59 SUBTEST(live_gt_resume),
62 if (intel_gt_is_wedged(&i915->gt))
65 return intel_gt_live_subtests(tests, &i915->gt);
68 int intel_gt_pm_late_selftests(struct drm_i915_private *i915)
70 static const struct i915_subtest tests[] = {
72 * These tests may leave the system in an undesirable state.
73 * They are intended to be run last in CI and the system
74 * rebooted afterwards.
76 SUBTEST(live_rc6_ctx_wa),
79 if (intel_gt_is_wedged(&i915->gt))
82 return intel_gt_live_subtests(tests, &i915->gt);