lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
Open Source and information security mailing list archives
| ||
|
Date: Fri, 9 Sep 2022 16:11:47 -0700 From: Ricardo Neri <ricardo.neri-calderon@...ux.intel.com> To: "Peter Zijlstra (Intel)" <peterz@...radead.org>, Juri Lelli <juri.lelli@...hat.com>, Vincent Guittot <vincent.guittot@...aro.org> Cc: Ricardo Neri <ricardo.neri@...el.com>, "Ravi V. Shankar" <ravi.v.shankar@...el.com>, Ben Segall <bsegall@...gle.com>, Daniel Bristot de Oliveira <bristot@...hat.com>, Dietmar Eggemann <dietmar.eggemann@....com>, Len Brown <len.brown@...el.com>, Mel Gorman <mgorman@...e.de>, "Rafael J. Wysocki" <rafael.j.wysocki@...el.com>, Srinivas Pandruvada <srinivas.pandruvada@...ux.intel.com>, Steven Rostedt <rostedt@...dmis.org>, Tim Chen <tim.c.chen@...ux.intel.com>, Valentin Schneider <vschneid@...hat.com>, x86@...nel.org, linux-kernel@...r.kernel.org, Ricardo Neri <ricardo.neri-calderon@...ux.intel.com>, "Tim C . Chen" <tim.c.chen@...el.com> Subject: [RFC PATCH 05/23] sched/core: Move is_core_idle() out of fair.c Information about the idle state of the SMT siblings of a core can be used to improve the accuracy of the classification of the current task. Move is_core_idle() to sched.h to make it available to scheduler_tick(). Cc: Ben Segall <bsegall@...gle.com> Cc: Daniel Bristot de Oliveira <bristot@...hat.com> Cc: Dietmar Eggemann <dietmar.eggemann@....com> Cc: Len Brown <len.brown@...el.com> Cc: Mel Gorman <mgorman@...e.de> Cc: Rafael J. Wysocki <rafael.j.wysocki@...el.com> Cc: Srinivas Pandruvada <srinivas.pandruvada@...ux.intel.com> Cc: Steven Rostedt <rostedt@...dmis.org> Cc: Tim C. Chen <tim.c.chen@...el.com> Cc: Valentin Schneider <vschneid@...hat.com> Cc: x86@...nel.org Cc: linux-kernel@...r.kernel.org Signed-off-by: Ricardo Neri <ricardo.neri-calderon@...ux.intel.com> --- kernel/sched/fair.c | 17 ----------------- kernel/sched/sched.h | 17 +++++++++++++++++ 2 files changed, 17 insertions(+), 17 deletions(-) diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c index 0089b33ea7b8..2f2a6bb5990d 100644 --- a/kernel/sched/fair.c +++ b/kernel/sched/fair.c @@ -1536,23 +1536,6 @@ struct numa_stats { int idle_cpu; }; -static inline bool is_core_idle(int cpu) -{ -#ifdef CONFIG_SCHED_SMT - int sibling; - - for_each_cpu(sibling, cpu_smt_mask(cpu)) { - if (cpu == sibling) - continue; - - if (!idle_cpu(sibling)) - return false; - } -#endif - - return true; -} - struct task_numa_env { struct task_struct *p; diff --git a/kernel/sched/sched.h b/kernel/sched/sched.h index 719bdba660e2..2bddedc55ee9 100644 --- a/kernel/sched/sched.h +++ b/kernel/sched/sched.h @@ -3212,6 +3212,23 @@ static inline bool is_per_cpu_kthread(struct task_struct *p) } #endif +static inline bool is_core_idle(int cpu) +{ +#ifdef CONFIG_SCHED_SMT + int sibling; + + for_each_cpu(sibling, cpu_smt_mask(cpu)) { + if (cpu == sibling) + continue; + + if (!idle_cpu(sibling)) + return false; + } +#endif + + return true; +} + extern void swake_up_all_locked(struct swait_queue_head *q); extern void __prepare_to_swait(struct swait_queue_head *q, struct swait_queue *wait); -- 2.25.1
Powered by blists - more mailing lists