~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/kernel/sched/features.h

Version: ~ [ linux-6.11-rc3 ] ~ [ linux-6.10.4 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.45 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.104 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.164 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.223 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.281 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.319 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /* SPDX-License-Identifier: GPL-2.0 */
  2 
  3 /*
  4  * Using the avg_vruntime, do the right thing and preserve lag across
  5  * sleep+wake cycles. EEVDF placement strategy #1, #2 if disabled.
  6  */
  7 SCHED_FEAT(PLACE_LAG, true)
  8 SCHED_FEAT(PLACE_DEADLINE_INITIAL, true)
  9 SCHED_FEAT(RUN_TO_PARITY, true)
 10 
 11 /*
 12  * Prefer to schedule the task we woke last (assuming it failed
 13  * wakeup-preemption), since its likely going to consume data we
 14  * touched, increases cache locality.
 15  */
 16 SCHED_FEAT(NEXT_BUDDY, false)
 17 
 18 /*
 19  * Consider buddies to be cache hot, decreases the likeliness of a
 20  * cache buddy being migrated away, increases cache locality.
 21  */
 22 SCHED_FEAT(CACHE_HOT_BUDDY, true)
 23 
 24 /*
 25  * Allow wakeup-time preemption of the current task:
 26  */
 27 SCHED_FEAT(WAKEUP_PREEMPTION, true)
 28 
 29 SCHED_FEAT(HRTICK, false)
 30 SCHED_FEAT(HRTICK_DL, false)
 31 SCHED_FEAT(DOUBLE_TICK, false)
 32 
 33 /*
 34  * Decrement CPU capacity based on time not spent running tasks
 35  */
 36 SCHED_FEAT(NONTASK_CAPACITY, true)
 37 
 38 #ifdef CONFIG_PREEMPT_RT
 39 SCHED_FEAT(TTWU_QUEUE, false)
 40 #else
 41 
 42 /*
 43  * Queue remote wakeups on the target CPU and process them
 44  * using the scheduler IPI. Reduces rq->lock contention/bounces.
 45  */
 46 SCHED_FEAT(TTWU_QUEUE, true)
 47 #endif
 48 
 49 /*
 50  * When doing wakeups, attempt to limit superfluous scans of the LLC domain.
 51  */
 52 SCHED_FEAT(SIS_UTIL, true)
 53 
 54 /*
 55  * Issue a WARN when we do multiple update_rq_clock() calls
 56  * in a single rq->lock section. Default disabled because the
 57  * annotations are not complete.
 58  */
 59 SCHED_FEAT(WARN_DOUBLE_CLOCK, false)
 60 
 61 #ifdef HAVE_RT_PUSH_IPI
 62 /*
 63  * In order to avoid a thundering herd attack of CPUs that are
 64  * lowering their priorities at the same time, and there being
 65  * a single CPU that has an RT task that can migrate and is waiting
 66  * to run, where the other CPUs will try to take that CPUs
 67  * rq lock and possibly create a large contention, sending an
 68  * IPI to that CPU and let that CPU push the RT task to where
 69  * it should go may be a better scenario.
 70  */
 71 SCHED_FEAT(RT_PUSH_IPI, true)
 72 #endif
 73 
 74 SCHED_FEAT(RT_RUNTIME_SHARE, false)
 75 SCHED_FEAT(LB_MIN, false)
 76 SCHED_FEAT(ATTACH_AGE_LOAD, true)
 77 
 78 SCHED_FEAT(WA_IDLE, true)
 79 SCHED_FEAT(WA_WEIGHT, true)
 80 SCHED_FEAT(WA_BIAS, true)
 81 
 82 /*
 83  * UtilEstimation. Use estimated CPU utilization.
 84  */
 85 SCHED_FEAT(UTIL_EST, true)
 86 
 87 SCHED_FEAT(LATENCY_WARN, false)
 88 
 89 SCHED_FEAT(HZ_BW, true)
 90 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php