blob: e53cfa96e91e2fe76787ef6db096fef6dd55d737 [file] [log] [blame]
Frederic Weisbecker78634062017-10-27 04:42:28 +02001#ifndef _LINUX_SCHED_ISOLATION_H
2#define _LINUX_SCHED_ISOLATION_H
3
4#include <linux/cpumask.h>
5#include <linux/init.h>
6#include <linux/tick.h>
7
Frederic Weisbeckerde201552017-10-27 04:42:35 +02008enum hk_flags {
9 HK_FLAG_TIMER = 1,
10 HK_FLAG_RCU = (1 << 1),
11 HK_FLAG_MISC = (1 << 2),
12 HK_FLAG_SCHED = (1 << 3),
Frederic Weisbecker6f1982f2017-10-27 04:42:36 +020013 HK_FLAG_TICK = (1 << 4),
Frederic Weisbeckerde201552017-10-27 04:42:35 +020014};
15
Frederic Weisbecker5c4991e2017-10-27 04:42:34 +020016#ifdef CONFIG_CPU_ISOLATION
Frederic Weisbeckere179f5a2017-10-27 04:42:32 +020017DECLARE_STATIC_KEY_FALSE(housekeeping_overriden);
Frederic Weisbeckerde201552017-10-27 04:42:35 +020018extern int housekeeping_any_cpu(enum hk_flags flags);
19extern const struct cpumask *housekeeping_cpumask(enum hk_flags flags);
20extern void housekeeping_affine(struct task_struct *t, enum hk_flags flags);
21extern bool housekeeping_test_cpu(int cpu, enum hk_flags flags);
Frederic Weisbecker78634062017-10-27 04:42:28 +020022extern void __init housekeeping_init(void);
Frederic Weisbecker7e56a1c2017-10-27 04:42:31 +020023
Frederic Weisbecker78634062017-10-27 04:42:28 +020024#else
Frederic Weisbecker78634062017-10-27 04:42:28 +020025
Frederic Weisbeckerde201552017-10-27 04:42:35 +020026static inline int housekeeping_any_cpu(enum hk_flags flags)
Frederic Weisbecker9f0ca2d2017-10-27 04:42:30 +020027{
Frederic Weisbecker9f0ca2d2017-10-27 04:42:30 +020028 return smp_processor_id();
29}
Frederic Weisbecker78634062017-10-27 04:42:28 +020030
Frederic Weisbeckerde201552017-10-27 04:42:35 +020031static inline const struct cpumask *housekeeping_cpumask(enum hk_flags flags)
Frederic Weisbecker78634062017-10-27 04:42:28 +020032{
Frederic Weisbecker78634062017-10-27 04:42:28 +020033 return cpu_possible_mask;
34}
35
Frederic Weisbeckerde201552017-10-27 04:42:35 +020036static inline void housekeeping_affine(struct task_struct *t,
37 enum hk_flags flags) { }
Frederic Weisbecker7e56a1c2017-10-27 04:42:31 +020038static inline void housekeeping_init(void) { }
Frederic Weisbecker5c4991e2017-10-27 04:42:34 +020039#endif /* CONFIG_CPU_ISOLATION */
Frederic Weisbecker7e56a1c2017-10-27 04:42:31 +020040
Frederic Weisbeckerde201552017-10-27 04:42:35 +020041static inline bool housekeeping_cpu(int cpu, enum hk_flags flags)
Frederic Weisbecker78634062017-10-27 04:42:28 +020042{
Frederic Weisbecker5c4991e2017-10-27 04:42:34 +020043#ifdef CONFIG_CPU_ISOLATION
Frederic Weisbeckere179f5a2017-10-27 04:42:32 +020044 if (static_branch_unlikely(&housekeeping_overriden))
Frederic Weisbeckerde201552017-10-27 04:42:35 +020045 return housekeeping_test_cpu(cpu, flags);
Frederic Weisbecker78634062017-10-27 04:42:28 +020046#endif
47 return true;
48}
49
Frederic Weisbecker78634062017-10-27 04:42:28 +020050#endif /* _LINUX_SCHED_ISOLATION_H */