u64 last_update;
 
        /* The fields below are only needed when sharing a policy. */
-       unsigned long util;
+       unsigned long util_cfs;
+       unsigned long util_dl;
        unsigned long max;
        unsigned int flags;
 
        return cpufreq_driver_resolve_freq(policy, freq);
 }
 
-static void sugov_get_util(unsigned long *util, unsigned long *max, int cpu)
+static void sugov_get_util(struct sugov_cpu *sg_cpu)
 {
-       struct rq *rq = cpu_rq(cpu);
-       unsigned long util_cfs = cpu_util_cfs(rq);
-       unsigned long util_dl  = cpu_util_dl(rq);
+       struct rq *rq = cpu_rq(sg_cpu->cpu);
 
-       *max = arch_scale_cpu_capacity(NULL, cpu);
+       sg_cpu->max = arch_scale_cpu_capacity(NULL, sg_cpu->cpu);
+       sg_cpu->util_cfs = cpu_util_cfs(rq);
+       sg_cpu->util_dl  = cpu_util_dl(rq);
+}
 
+static unsigned long sugov_aggregate_util(struct sugov_cpu *sg_cpu)
+{
        /*
         * Ideally we would like to set util_dl as min/guaranteed freq and
         * util_cfs + util_dl as requested freq. However, cpufreq is not yet
         * ready for such an interface. So, we only do the latter for now.
         */
-       *util = min(util_cfs + util_dl, *max);
+       return min(sg_cpu->util_cfs + sg_cpu->util_dl, sg_cpu->max);
 }
 
 static void sugov_set_iowait_boost(struct sugov_cpu *sg_cpu, u64 time)
        if (flags & SCHED_CPUFREQ_RT) {
                next_f = policy->cpuinfo.max_freq;
        } else {
-               sugov_get_util(&util, &max, sg_cpu->cpu);
+               sugov_get_util(sg_cpu);
+               max = sg_cpu->max;
+               util = sugov_aggregate_util(sg_cpu);
                sugov_iowait_boost(sg_cpu, &util, &max);
                next_f = get_next_freq(sg_policy, util, max);
                /*
                if (j_sg_cpu->flags & SCHED_CPUFREQ_RT)
                        return policy->cpuinfo.max_freq;
 
-               j_util = j_sg_cpu->util;
                j_max = j_sg_cpu->max;
+               j_util = sugov_aggregate_util(j_sg_cpu);
                if (j_util * max > j_max * util) {
                        util = j_util;
                        max = j_max;
 {
        struct sugov_cpu *sg_cpu = container_of(hook, struct sugov_cpu, update_util);
        struct sugov_policy *sg_policy = sg_cpu->sg_policy;
-       unsigned long util, max;
        unsigned int next_f;
 
-       sugov_get_util(&util, &max, sg_cpu->cpu);
-
        raw_spin_lock(&sg_policy->update_lock);
 
-       sg_cpu->util = util;
-       sg_cpu->max = max;
+       sugov_get_util(sg_cpu);
        sg_cpu->flags = flags;
 
        sugov_set_iowait_boost(sg_cpu, time);