3 * SPDX-License-Identifier: MIT
5 * Copyright © 2019 Intel Corporation
8 #include "selftest_llc.h"
10 static int live_gt_resume(void *arg)
12 struct intel_gt *gt = arg;
13 IGT_TIMEOUT(end_time);
16 /* Do several suspend/resume cycles to check we don't explode! */
18 intel_gt_suspend_prepare(gt);
19 intel_gt_suspend_late(gt);
21 if (gt->rc6.enabled) {
22 pr_err("rc6 still enabled after suspend!\n");
23 intel_gt_set_wedged_on_init(gt);
28 err = intel_gt_resume(gt);
32 if (gt->rc6.supported && !gt->rc6.enabled) {
33 pr_err("rc6 not enabled upon resume!\n");
34 intel_gt_set_wedged_on_init(gt);
39 err = st_llc_verify(>->llc);
41 pr_err("llc state not restored upon resume!\n");
42 intel_gt_set_wedged_on_init(gt);
45 } while (!__igt_timeout(end_time, NULL));
50 int intel_gt_pm_live_selftests(struct drm_i915_private *i915)
52 static const struct i915_subtest tests[] = {
53 SUBTEST(live_gt_resume),
56 if (intel_gt_is_wedged(&i915->gt))
59 return intel_gt_live_subtests(tests, &i915->gt);