• Home
  • Raw
  • Download

Lines Matching refs:sg_policy

44 	struct sugov_policy	*sg_policy;  member
65 static bool sugov_should_update_freq(struct sugov_policy *sg_policy, u64 time) in sugov_should_update_freq() argument
84 if (!cpufreq_this_cpu_can_update(sg_policy->policy)) in sugov_should_update_freq()
87 if (unlikely(sg_policy->limits_changed)) { in sugov_should_update_freq()
88 sg_policy->limits_changed = false; in sugov_should_update_freq()
89 sg_policy->need_freq_update = true; in sugov_should_update_freq()
93 delta_ns = time - sg_policy->last_freq_update_time; in sugov_should_update_freq()
95 return delta_ns >= sg_policy->freq_update_delay_ns; in sugov_should_update_freq()
98 static bool sugov_update_next_freq(struct sugov_policy *sg_policy, u64 time, in sugov_update_next_freq() argument
101 if (sg_policy->need_freq_update) in sugov_update_next_freq()
102 sg_policy->need_freq_update = cpufreq_driver_test_flags(CPUFREQ_NEED_UPDATE_LIMITS); in sugov_update_next_freq()
103 else if (sg_policy->next_freq == next_freq) in sugov_update_next_freq()
106 sg_policy->next_freq = next_freq; in sugov_update_next_freq()
107 sg_policy->last_freq_update_time = time; in sugov_update_next_freq()
112 static void sugov_deferred_update(struct sugov_policy *sg_policy) in sugov_deferred_update() argument
114 if (!sg_policy->work_in_progress) { in sugov_deferred_update()
115 sg_policy->work_in_progress = true; in sugov_deferred_update()
116 irq_work_queue(&sg_policy->irq_work); in sugov_deferred_update()
142 static unsigned int get_next_freq(struct sugov_policy *sg_policy, in get_next_freq() argument
145 struct cpufreq_policy *policy = sg_policy->policy; in get_next_freq()
152 &sg_policy->need_freq_update); in get_next_freq()
158 if (freq == sg_policy->cached_raw_freq && !sg_policy->need_freq_update) in get_next_freq()
159 return sg_policy->next_freq; in get_next_freq()
161 sg_policy->cached_raw_freq = freq; in get_next_freq()
317 sg_cpu->sg_policy->limits_changed = true; in ignore_dl_rate_limit()
328 if (!sugov_should_update_freq(sg_cpu->sg_policy, time)) in sugov_update_single_common()
341 struct sugov_policy *sg_policy = sg_cpu->sg_policy; in sugov_update_single_freq() local
342 unsigned int cached_freq = sg_policy->cached_raw_freq; in sugov_update_single_freq()
348 next_f = get_next_freq(sg_policy, sg_cpu->util, sg_cpu->max); in sugov_update_single_freq()
356 sugov_cpu_is_busy(sg_cpu) && next_f < sg_policy->next_freq && in sugov_update_single_freq()
357 !sg_policy->need_freq_update) { in sugov_update_single_freq()
358 next_f = sg_policy->next_freq; in sugov_update_single_freq()
361 sg_policy->cached_raw_freq = cached_freq; in sugov_update_single_freq()
364 if (!sugov_update_next_freq(sg_policy, time, next_f)) in sugov_update_single_freq()
372 if (sg_policy->policy->fast_switch_enabled) { in sugov_update_single_freq()
373 cpufreq_driver_fast_switch(sg_policy->policy, next_f); in sugov_update_single_freq()
375 raw_spin_lock(&sg_policy->update_lock); in sugov_update_single_freq()
376 sugov_deferred_update(sg_policy); in sugov_update_single_freq()
377 raw_spin_unlock(&sg_policy->update_lock); in sugov_update_single_freq()
413 sg_cpu->sg_policy->last_freq_update_time = time; in sugov_update_single_perf()
418 struct sugov_policy *sg_policy = sg_cpu->sg_policy; in sugov_next_freq_shared() local
419 struct cpufreq_policy *policy = sg_policy->policy; in sugov_next_freq_shared()
438 return get_next_freq(sg_policy, util, max); in sugov_next_freq_shared()
445 struct sugov_policy *sg_policy = sg_cpu->sg_policy; in sugov_update_shared() local
448 raw_spin_lock(&sg_policy->update_lock); in sugov_update_shared()
455 if (sugov_should_update_freq(sg_policy, time)) { in sugov_update_shared()
458 if (!sugov_update_next_freq(sg_policy, time, next_f)) in sugov_update_shared()
461 if (sg_policy->policy->fast_switch_enabled) in sugov_update_shared()
462 cpufreq_driver_fast_switch(sg_policy->policy, next_f); in sugov_update_shared()
464 sugov_deferred_update(sg_policy); in sugov_update_shared()
467 raw_spin_unlock(&sg_policy->update_lock); in sugov_update_shared()
472 struct sugov_policy *sg_policy = container_of(work, struct sugov_policy, work); in sugov_work() local
486 raw_spin_lock_irqsave(&sg_policy->update_lock, flags); in sugov_work()
487 freq = sg_policy->next_freq; in sugov_work()
488 sg_policy->work_in_progress = false; in sugov_work()
489 raw_spin_unlock_irqrestore(&sg_policy->update_lock, flags); in sugov_work()
491 mutex_lock(&sg_policy->work_lock); in sugov_work()
492 __cpufreq_driver_target(sg_policy->policy, freq, CPUFREQ_RELATION_L); in sugov_work()
493 mutex_unlock(&sg_policy->work_lock); in sugov_work()
498 struct sugov_policy *sg_policy; in sugov_irq_work() local
500 sg_policy = container_of(irq_work, struct sugov_policy, irq_work); in sugov_irq_work()
502 kthread_queue_work(&sg_policy->worker, &sg_policy->work); in sugov_irq_work()
526 struct sugov_policy *sg_policy; in rate_limit_us_store() local
534 list_for_each_entry(sg_policy, &attr_set->policy_list, tunables_hook) in rate_limit_us_store()
535 sg_policy->freq_update_delay_ns = rate_limit_us * NSEC_PER_USEC; in rate_limit_us_store()
567 struct sugov_policy *sg_policy; in sugov_policy_alloc() local
569 sg_policy = kzalloc(sizeof(*sg_policy), GFP_KERNEL); in sugov_policy_alloc()
570 if (!sg_policy) in sugov_policy_alloc()
573 sg_policy->policy = policy; in sugov_policy_alloc()
574 raw_spin_lock_init(&sg_policy->update_lock); in sugov_policy_alloc()
575 return sg_policy; in sugov_policy_alloc()
578 static void sugov_policy_free(struct sugov_policy *sg_policy) in sugov_policy_free() argument
580 kfree(sg_policy); in sugov_policy_free()
583 static int sugov_kthread_create(struct sugov_policy *sg_policy) in sugov_kthread_create() argument
600 struct cpufreq_policy *policy = sg_policy->policy; in sugov_kthread_create()
608 kthread_init_work(&sg_policy->work, sugov_work); in sugov_kthread_create()
609 kthread_init_worker(&sg_policy->worker); in sugov_kthread_create()
610 thread = kthread_create(kthread_worker_fn, &sg_policy->worker, in sugov_kthread_create()
625 sg_policy->thread = thread; in sugov_kthread_create()
627 init_irq_work(&sg_policy->irq_work, sugov_irq_work); in sugov_kthread_create()
628 mutex_init(&sg_policy->work_lock); in sugov_kthread_create()
635 static void sugov_kthread_stop(struct sugov_policy *sg_policy) in sugov_kthread_stop() argument
638 if (sg_policy->policy->fast_switch_enabled) in sugov_kthread_stop()
641 kthread_flush_worker(&sg_policy->worker); in sugov_kthread_stop()
642 kthread_stop(sg_policy->thread); in sugov_kthread_stop()
643 mutex_destroy(&sg_policy->work_lock); in sugov_kthread_stop()
646 static struct sugov_tunables *sugov_tunables_alloc(struct sugov_policy *sg_policy) in sugov_tunables_alloc() argument
652 gov_attr_set_init(&tunables->attr_set, &sg_policy->tunables_hook); in sugov_tunables_alloc()
667 struct sugov_policy *sg_policy; in sugov_init() local
677 sg_policy = sugov_policy_alloc(policy); in sugov_init()
678 if (!sg_policy) { in sugov_init()
683 ret = sugov_kthread_create(sg_policy); in sugov_init()
694 policy->governor_data = sg_policy; in sugov_init()
695 sg_policy->tunables = global_tunables; in sugov_init()
697 gov_attr_set_get(&global_tunables->attr_set, &sg_policy->tunables_hook); in sugov_init()
701 tunables = sugov_tunables_alloc(sg_policy); in sugov_init()
709 policy->governor_data = sg_policy; in sugov_init()
710 sg_policy->tunables = tunables; in sugov_init()
728 sugov_kthread_stop(sg_policy); in sugov_init()
732 sugov_policy_free(sg_policy); in sugov_init()
743 struct sugov_policy *sg_policy = policy->governor_data; in sugov_exit() local
744 struct sugov_tunables *tunables = sg_policy->tunables; in sugov_exit()
749 count = gov_attr_set_put(&tunables->attr_set, &sg_policy->tunables_hook); in sugov_exit()
756 sugov_kthread_stop(sg_policy); in sugov_exit()
757 sugov_policy_free(sg_policy); in sugov_exit()
763 struct sugov_policy *sg_policy = policy->governor_data; in sugov_start() local
767 sg_policy->freq_update_delay_ns = sg_policy->tunables->rate_limit_us * NSEC_PER_USEC; in sugov_start()
768 sg_policy->last_freq_update_time = 0; in sugov_start()
769 sg_policy->next_freq = 0; in sugov_start()
770 sg_policy->work_in_progress = false; in sugov_start()
771 sg_policy->limits_changed = false; in sugov_start()
772 sg_policy->cached_raw_freq = 0; in sugov_start()
774 sg_policy->need_freq_update = cpufreq_driver_test_flags(CPUFREQ_NEED_UPDATE_LIMITS); in sugov_start()
781 sg_cpu->sg_policy = sg_policy; in sugov_start()
801 struct sugov_policy *sg_policy = policy->governor_data; in sugov_stop() local
810 irq_work_sync(&sg_policy->irq_work); in sugov_stop()
811 kthread_cancel_work_sync(&sg_policy->work); in sugov_stop()
817 struct sugov_policy *sg_policy = policy->governor_data; in sugov_limits() local
820 mutex_lock(&sg_policy->work_lock); in sugov_limits()
822 mutex_unlock(&sg_policy->work_lock); in sugov_limits()
825 sg_policy->limits_changed = true; in sugov_limits()