summaryrefslogtreecommitdiff
path: root/kernel/sched
diff options
context:
space:
mode:
authorLinux Build Service Account <lnxbuild@quicinc.com>2017-08-25 15:30:51 -0700
committerGerrit - the friendly Code Review server <code-review@localhost>2017-08-25 15:30:51 -0700
commitccfef7e7014e9d3b62ff718030f54f6886f2f39e (patch)
tree5b8ddabb4132f460cdb12d9ea29778f1b6cf8028 /kernel/sched
parentcac55e7f09a17f7c6344b587302ffddf0d586c7e (diff)
parenta66b3eb5aff1536bc32e5e5eb60393610a21dd06 (diff)
Merge "softirq: defer softirq processing to ksoftirqd if CPU is busy with RT"
Diffstat (limited to 'kernel/sched')
-rw-r--r--kernel/sched/cpupri.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/kernel/sched/cpupri.c b/kernel/sched/cpupri.c
index 1d00cf8c00fa..14225d5d8617 100644
--- a/kernel/sched/cpupri.c
+++ b/kernel/sched/cpupri.c
@@ -279,3 +279,14 @@ void cpupri_cleanup(struct cpupri *cp)
for (i = 0; i < CPUPRI_NR_PRIORITIES; i++)
free_cpumask_var(cp->pri_to_cpu[i].mask);
}
+
+/*
+ * cpupri_check_rt - check if CPU has a RT task
+ * should be called from rcu-sched read section.
+ */
+bool cpupri_check_rt(void)
+{
+ int cpu = raw_smp_processor_id();
+
+ return cpu_rq(cpu)->rd->cpupri.cpu_to_pri[cpu] > CPUPRI_NORMAL;
+}