* @cdev: thermal_cooling_device pointer to keep track of the
  *     registered cooling device.
  * @policy: cpufreq policy.
+ * @cooling_ops: cpufreq callbacks to thermal cooling device ops
  * @idle_time: idle time stats
  * @qos_req: PM QoS contraint to apply
  *
        unsigned int max_level;
        struct em_perf_domain *em;
        struct cpufreq_policy *policy;
+       struct thermal_cooling_device_ops cooling_ops;
 #ifndef CONFIG_SMP
        struct time_in_idle *idle_time;
 #endif
        return ret;
 }
 
-/* Bind cpufreq callbacks to thermal cooling device ops */
-
-static struct thermal_cooling_device_ops cpufreq_cooling_ops = {
-       .get_max_state          = cpufreq_get_max_state,
-       .get_cur_state          = cpufreq_get_cur_state,
-       .set_cur_state          = cpufreq_set_cur_state,
-};
-
 /**
  * __cpufreq_cooling_register - helper function to create cpufreq cooling device
  * @np: a valid struct device_node to the cooling device device tree node
        /* max_level is an index, not a counter */
        cpufreq_cdev->max_level = i - 1;
 
-       cooling_ops = &cpufreq_cooling_ops;
+       cooling_ops = &cpufreq_cdev->cooling_ops;
+       cooling_ops->get_max_state = cpufreq_get_max_state;
+       cooling_ops->get_cur_state = cpufreq_get_cur_state;
+       cooling_ops->set_cur_state = cpufreq_set_cur_state;
 
 #ifdef CONFIG_THERMAL_GOV_POWER_ALLOCATOR
        if (em_is_sane(cpufreq_cdev, em)) {