wake_up_interruptible(&group->poll_wait);
 }
 
-static void record_times(struct psi_group_cpu *groupc, int cpu)
+static void record_times(struct psi_group_cpu *groupc, u64 now)
 {
        u32 delta;
-       u64 now;
 
-       now = cpu_clock(cpu);
        delta = now - groupc->state_start;
        groupc->state_start = now;
 
 }
 
 static void psi_group_change(struct psi_group *group, int cpu,
-                            unsigned int clear, unsigned int set,
+                            unsigned int clear, unsigned int set, u64 now,
                             bool wake_clock)
 {
        struct psi_group_cpu *groupc;
         */
        write_seqcount_begin(&groupc->seq);
 
-       record_times(groupc, cpu);
+       record_times(groupc, now);
 
        for (t = 0, m = clear; m; m &= ~(1 << t), t++) {
                if (!(m & (1 << t)))
        struct psi_group *group;
        bool wake_clock = true;
        void *iter = NULL;
+       u64 now;
 
        if (!task->pid)
                return;
 
        psi_flags_change(task, clear, set);
 
+       now = cpu_clock(cpu);
        /*
         * Periodic aggregation shuts off if there is a period of no
         * task changes, so we wake it back up if necessary. However,
                wake_clock = false;
 
        while ((group = iterate_groups(task, &iter)))
-               psi_group_change(group, cpu, clear, set, wake_clock);
+               psi_group_change(group, cpu, clear, set, now, wake_clock);
 }
 
 void psi_task_switch(struct task_struct *prev, struct task_struct *next,
        struct psi_group *group, *common = NULL;
        int cpu = task_cpu(prev);
        void *iter;
+       u64 now = cpu_clock(cpu);
 
        if (next->pid) {
                bool identical_state;
                                break;
                        }
 
-                       psi_group_change(group, cpu, 0, TSK_ONCPU, true);
+                       psi_group_change(group, cpu, 0, TSK_ONCPU, now, true);
                }
        }
 
 
                iter = NULL;
                while ((group = iterate_groups(prev, &iter)) && group != common)
-                       psi_group_change(group, cpu, clear, set, true);
+                       psi_group_change(group, cpu, clear, set, now, true);
 
                /*
                 * TSK_ONCPU is handled up to the common ancestor. If we're tasked
                if (sleep) {
                        clear &= ~TSK_ONCPU;
                        for (; group; group = iterate_groups(prev, &iter))
-                               psi_group_change(group, cpu, clear, set, true);
+                               psi_group_change(group, cpu, clear, set, now, true);
                }
        }
 }