]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/i915/gt: add a macro for mock gt wakeref special value and use it
authorJani Nikula <jani.nikula@intel.com>
Wed, 18 Sep 2024 17:35:46 +0000 (20:35 +0300)
committerJani Nikula <jani.nikula@intel.com>
Mon, 30 Sep 2024 14:54:11 +0000 (17:54 +0300)
Add a dedicated macro for the special mock gt wakeref value, with a cast
to intel_wakeref_t, instead of assuming you can assign or compare the
wakeref to -ENODEV directly.

Arguably the whole thing is a hack that should not exist, but at least
make it slightly less hacky.

Side note: If this value were to ever end up in
intel_ref_tracker_free(), it would wreak havoc.

Reviewed-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/1da887a6b4fe1ec45355571ea7b56d91fadf0af2.1726680898.git.jani.nikula@intel.com
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
drivers/gpu/drm/i915/gt/intel_gt_pm.h
drivers/gpu/drm/i915/gt/intel_tlb.c
drivers/gpu/drm/i915/selftests/mock_gem_device.c

index 911fd0160221ba5c815d226537fbe5f9108525db..fef8d5d288f85464dd0078f5ecf68dec0cf352e6 100644 (file)
@@ -105,9 +105,13 @@ int intel_gt_runtime_resume(struct intel_gt *gt);
 
 ktime_t intel_gt_get_awake_time(const struct intel_gt *gt);
 
+#define INTEL_WAKEREF_MOCK_GT ((intel_wakeref_t)-ENODEV)
+
 static inline bool is_mock_gt(const struct intel_gt *gt)
 {
-       return I915_SELFTEST_ONLY(gt->awake == -ENODEV);
+       BUILD_BUG_ON(INTEL_WAKEREF_DEF == INTEL_WAKEREF_MOCK_GT);
+
+       return I915_SELFTEST_ONLY(gt->awake == INTEL_WAKEREF_MOCK_GT);
 }
 
 #endif /* INTEL_GT_PM_H */
index 756e9ebbc72541b2054f08f035ac7ac8d6246258..2487768bc23038df9e8897429427a3b6ff64e403 100644 (file)
@@ -122,7 +122,7 @@ void intel_gt_invalidate_tlb_full(struct intel_gt *gt, u32 seqno)
 {
        intel_wakeref_t wakeref;
 
-       if (I915_SELFTEST_ONLY(gt->awake == -ENODEV))
+       if (is_mock_gt(gt))
                return;
 
        if (intel_gt_is_wedged(gt))
index 70f3d7bf47d0dbc8d68a801226d115445dd73ddd..ae57eb03dfca98072454633a9f051e31918d2623 100644 (file)
@@ -203,7 +203,7 @@ struct drm_i915_private *mock_gem_device(void)
        intel_root_gt_init_early(i915);
        mock_uncore_init(&i915->uncore, i915);
        atomic_inc(&to_gt(i915)->wakeref.count); /* disable; no hw support */
-       to_gt(i915)->awake = -ENODEV;
+       to_gt(i915)->awake = INTEL_WAKEREF_MOCK_GT;
        mock_gt_probe(i915);
 
        ret = intel_region_ttm_device_init(i915);