Commit 7537b90c authored by Peter Zijlstra's avatar Peter Zijlstra

sched: Simplify get_nohz_timer_target()

Use guards to reduce gotos and simplify control flow.
Signed-off-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
Reviewed-by: default avatarJoel Fernandes (Google) <joel@joelfernandes.org>
Reviewed-by: default avatarValentin Schneider <vschneid@redhat.com>
Link: https://lore.kernel.org/r/20230801211811.828443100@infradead.org
parent c1fc6484
...@@ -1097,25 +1097,22 @@ int get_nohz_timer_target(void) ...@@ -1097,25 +1097,22 @@ int get_nohz_timer_target(void)
hk_mask = housekeeping_cpumask(HK_TYPE_TIMER); hk_mask = housekeeping_cpumask(HK_TYPE_TIMER);
rcu_read_lock(); guard(rcu)();
for_each_domain(cpu, sd) { for_each_domain(cpu, sd) {
for_each_cpu_and(i, sched_domain_span(sd), hk_mask) { for_each_cpu_and(i, sched_domain_span(sd), hk_mask) {
if (cpu == i) if (cpu == i)
continue; continue;
if (!idle_cpu(i)) { if (!idle_cpu(i))
cpu = i; return i;
goto unlock;
}
} }
} }
if (default_cpu == -1) if (default_cpu == -1)
default_cpu = housekeeping_any_cpu(HK_TYPE_TIMER); default_cpu = housekeeping_any_cpu(HK_TYPE_TIMER);
cpu = default_cpu;
unlock: return default_cpu;
rcu_read_unlock();
return cpu;
} }
/* /*
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment