drm/i915/pmu: Use existing uncore helper to read gpm_timestamp
authorUmesh Nerlige Ramappa <umesh.nerlige.ramappa@intel.com>
Wed, 27 Apr 2022 00:35:15 +0000 (17:35 -0700)
committerJohn Harrison <John.C.Harrison@Intel.com>
Thu, 28 Apr 2022 19:30:32 +0000 (12:30 -0700)
Use intel_uncore_read64_2x32 to read upper and lower fields of the GPM
timestamp.

v2: Fix compile error

Signed-off-by: Umesh Nerlige Ramappa <umesh.nerlige.ramappa@intel.com>
Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Signed-off-by: John Harrison <John.C.Harrison@Intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220427003515.3944267-1-umesh.nerlige.ramappa@intel.com
drivers/gpu/drm/i915/gt/uc/intel_guc_submission.c

index 61a6f24..33e695a 100644 (file)
@@ -1200,20 +1200,6 @@ static u32 gpm_timestamp_shift(struct intel_gt *gt)
        return 3 - shift;
 }
 
-static u64 gpm_timestamp(struct intel_gt *gt)
-{
-       u32 lo, hi, old_hi, loop = 0;
-
-       hi = intel_uncore_read(gt->uncore, MISC_STATUS1);
-       do {
-               lo = intel_uncore_read(gt->uncore, MISC_STATUS0);
-               old_hi = hi;
-               hi = intel_uncore_read(gt->uncore, MISC_STATUS1);
-       } while (old_hi != hi && loop++ < 2);
-
-       return ((u64)hi << 32) | lo;
-}
-
 static void guc_update_pm_timestamp(struct intel_guc *guc, ktime_t *now)
 {
        struct intel_gt *gt = guc_to_gt(guc);
@@ -1223,7 +1209,8 @@ static void guc_update_pm_timestamp(struct intel_guc *guc, ktime_t *now)
        lockdep_assert_held(&guc->timestamp.lock);
 
        gt_stamp_hi = upper_32_bits(guc->timestamp.gt_stamp);
-       gpm_ts = gpm_timestamp(gt) >> guc->timestamp.shift;
+       gpm_ts = intel_uncore_read64_2x32(gt->uncore, MISC_STATUS0,
+                                         MISC_STATUS1) >> guc->timestamp.shift;
        gt_stamp_lo = lower_32_bits(gpm_ts);
        *now = ktime_get();