/*
                 * Register with the energy model before
-                * sched_cpufreq_governor_change() is called, which will result
+                * sugov_eas_rebuild_sd() is called, which will result
                 * in rebuilding of the sched domains, which should only be done
                 * once the energy model is properly initialized for the policy
                 * first.
                ret = cpufreq_start_governor(policy);
                if (!ret) {
                        pr_debug("governor change\n");
-                       sched_cpufreq_governor_change(policy, old_gov);
                        return 0;
                }
                cpufreq_exit_governor(policy);
 
 }
 #endif
 
-#if defined(CONFIG_ENERGY_MODEL) && defined(CONFIG_CPU_FREQ_GOV_SCHEDUTIL)
-void sched_cpufreq_governor_change(struct cpufreq_policy *policy,
-                       struct cpufreq_governor *old_gov);
-#else
-static inline void sched_cpufreq_governor_change(struct cpufreq_policy *policy,
-                       struct cpufreq_governor *old_gov) { }
-#endif
-
 extern unsigned int arch_freq_get_on_cpu(int cpu);
 
 #ifndef arch_set_freq_scale
 
 
 /********************** cpufreq governor interface *********************/
 
+#ifdef CONFIG_ENERGY_MODEL
+static void rebuild_sd_workfn(struct work_struct *work)
+{
+       rebuild_sched_domains_energy();
+}
+
+static DECLARE_WORK(rebuild_sd_work, rebuild_sd_workfn);
+
+/*
+ * EAS shouldn't be attempted without sugov, so rebuild the sched_domains
+ * on governor changes to make sure the scheduler knows about it.
+ */
+static void sugov_eas_rebuild_sd(void)
+{
+       /*
+        * When called from the cpufreq_register_driver() path, the
+        * cpu_hotplug_lock is already held, so use a work item to
+        * avoid nested locking in rebuild_sched_domains().
+        */
+       schedule_work(&rebuild_sd_work);
+}
+#else
+static inline void sugov_eas_rebuild_sd(void) { };
+#endif
+
 struct cpufreq_governor schedutil_gov;
 
 static struct sugov_policy *sugov_policy_alloc(struct cpufreq_policy *policy)
        if (ret)
                goto fail;
 
+       sugov_eas_rebuild_sd();
+
 out:
        mutex_unlock(&global_tunables_lock);
        return 0;
        sugov_kthread_stop(sg_policy);
        sugov_policy_free(sg_policy);
        cpufreq_disable_fast_switch(policy);
+
+       sugov_eas_rebuild_sd();
 }
 
 static int sugov_start(struct cpufreq_policy *policy)
 #endif
 
 cpufreq_governor_init(schedutil_gov);
-
-#ifdef CONFIG_ENERGY_MODEL
-static void rebuild_sd_workfn(struct work_struct *work)
-{
-       rebuild_sched_domains_energy();
-}
-static DECLARE_WORK(rebuild_sd_work, rebuild_sd_workfn);
-
-/*
- * EAS shouldn't be attempted without sugov, so rebuild the sched_domains
- * on governor changes to make sure the scheduler knows about it.
- */
-void sched_cpufreq_governor_change(struct cpufreq_policy *policy,
-                                 struct cpufreq_governor *old_gov)
-{
-       if (old_gov == &schedutil_gov || policy->governor == &schedutil_gov) {
-               /*
-                * When called from the cpufreq_register_driver() path, the
-                * cpu_hotplug_lock is already held, so use a work item to
-                * avoid nested locking in rebuild_sched_domains().
-                */
-               schedule_work(&rebuild_sd_work);
-       }
-
-}
-#endif