mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2026-03-03 18:28:01 +01:00
It doesn't make sense to use nohz_full without also isolating the related CPUs from the domain topology, either through the use of isolcpus= or cpuset isolated partitions. And now HK_TYPE_DOMAIN includes all kinds of domain isolated CPUs. This means that HK_TYPE_DOMAIN should always be a subset of HK_TYPE_KERNEL_NOISE (of which HK_TYPE_TICK is only an alias). Therefore if a CPU is not HK_TYPE_DOMAIN, it shouldn't be HK_TYPE_KERNEL_NOISE either. Testing the former is then enough. Simplify cpu_is_isolated() accordingly. Signed-off-by: Frederic Weisbecker <frederic@kernel.org> Acked-by: Waiman Long <longman@redhat.com> Cc: Ingo Molnar <mingo@redhat.com> Cc: Marco Crivellari <marco.crivellari@suse.com> Cc: Michal Hocko <mhocko@suse.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Tejun Heo <tj@kernel.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Vlastimil Babka <vbabka@suse.cz> Cc: Waiman Long <longman@redhat.com>
89 lines
2.4 KiB
C
89 lines
2.4 KiB
C
#ifndef _LINUX_SCHED_ISOLATION_H
|
|
#define _LINUX_SCHED_ISOLATION_H
|
|
|
|
#include <linux/cpumask.h>
|
|
#include <linux/init.h>
|
|
#include <linux/tick.h>
|
|
|
|
enum hk_type {
|
|
/* Inverse of boot-time isolcpus= argument */
|
|
HK_TYPE_DOMAIN_BOOT,
|
|
/*
|
|
* Same as HK_TYPE_DOMAIN_BOOT but also includes the
|
|
* inverse of cpuset isolated partitions. As such it
|
|
* is always a subset of HK_TYPE_DOMAIN_BOOT.
|
|
*/
|
|
HK_TYPE_DOMAIN,
|
|
/* Inverse of boot-time isolcpus=managed_irq argument */
|
|
HK_TYPE_MANAGED_IRQ,
|
|
/* Inverse of boot-time nohz_full= or isolcpus=nohz arguments */
|
|
HK_TYPE_KERNEL_NOISE,
|
|
HK_TYPE_MAX,
|
|
|
|
/*
|
|
* The following housekeeping types are only set by the nohz_full
|
|
* boot commandline option. So they can share the same value.
|
|
*/
|
|
HK_TYPE_TICK = HK_TYPE_KERNEL_NOISE,
|
|
HK_TYPE_TIMER = HK_TYPE_KERNEL_NOISE,
|
|
HK_TYPE_RCU = HK_TYPE_KERNEL_NOISE,
|
|
HK_TYPE_MISC = HK_TYPE_KERNEL_NOISE,
|
|
HK_TYPE_WQ = HK_TYPE_KERNEL_NOISE,
|
|
HK_TYPE_KTHREAD = HK_TYPE_KERNEL_NOISE
|
|
};
|
|
|
|
#ifdef CONFIG_CPU_ISOLATION
|
|
DECLARE_STATIC_KEY_FALSE(housekeeping_overridden);
|
|
extern int housekeeping_any_cpu(enum hk_type type);
|
|
extern const struct cpumask *housekeeping_cpumask(enum hk_type type);
|
|
extern bool housekeeping_enabled(enum hk_type type);
|
|
extern void housekeeping_affine(struct task_struct *t, enum hk_type type);
|
|
extern bool housekeeping_test_cpu(int cpu, enum hk_type type);
|
|
extern int housekeeping_update(struct cpumask *isol_mask);
|
|
extern void __init housekeeping_init(void);
|
|
|
|
#else
|
|
|
|
static inline int housekeeping_any_cpu(enum hk_type type)
|
|
{
|
|
return smp_processor_id();
|
|
}
|
|
|
|
static inline const struct cpumask *housekeeping_cpumask(enum hk_type type)
|
|
{
|
|
return cpu_possible_mask;
|
|
}
|
|
|
|
static inline bool housekeeping_enabled(enum hk_type type)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
static inline void housekeeping_affine(struct task_struct *t,
|
|
enum hk_type type) { }
|
|
|
|
static inline bool housekeeping_test_cpu(int cpu, enum hk_type type)
|
|
{
|
|
return true;
|
|
}
|
|
|
|
static inline int housekeeping_update(struct cpumask *isol_mask) { return 0; }
|
|
static inline void housekeeping_init(void) { }
|
|
#endif /* CONFIG_CPU_ISOLATION */
|
|
|
|
static inline bool housekeeping_cpu(int cpu, enum hk_type type)
|
|
{
|
|
#ifdef CONFIG_CPU_ISOLATION
|
|
if (static_branch_unlikely(&housekeeping_overridden))
|
|
return housekeeping_test_cpu(cpu, type);
|
|
#endif
|
|
return true;
|
|
}
|
|
|
|
static inline bool cpu_is_isolated(int cpu)
|
|
{
|
|
return !housekeeping_test_cpu(cpu, HK_TYPE_DOMAIN);
|
|
}
|
|
|
|
#endif /* _LINUX_SCHED_ISOLATION_H */
|