features.h 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * Only give sleepers 50% of their service deficit. This allows
  4. * them to run sooner, but does not allow tons of sleepers to
  5. * rip the spread apart.
  6. */
  7. SCHED_FEAT(GENTLE_FAIR_SLEEPERS, true)
  8. /*
  9. * Place new tasks ahead so that they do not starve already running
  10. * tasks
  11. */
  12. SCHED_FEAT(START_DEBIT, true)
  13. /*
  14. * Prefer to schedule the task we woke last (assuming it failed
  15. * wakeup-preemption), since its likely going to consume data we
  16. * touched, increases cache locality.
  17. */
  18. SCHED_FEAT(NEXT_BUDDY, false)
  19. /*
  20. * Prefer to schedule the task that ran last (when we did
  21. * wake-preempt) as that likely will touch the same data, increases
  22. * cache locality.
  23. */
  24. SCHED_FEAT(LAST_BUDDY, true)
  25. /*
  26. * Consider buddies to be cache hot, decreases the likeliness of a
  27. * cache buddy being migrated away, increases cache locality.
  28. */
  29. SCHED_FEAT(CACHE_HOT_BUDDY, true)
  30. /*
  31. * Allow wakeup-time preemption of the current task:
  32. */
  33. SCHED_FEAT(WAKEUP_PREEMPTION, true)
  34. SCHED_FEAT(HRTICK, false)
  35. SCHED_FEAT(HRTICK_DL, false)
  36. SCHED_FEAT(DOUBLE_TICK, false)
  37. /*
  38. * Decrement CPU capacity based on time not spent running tasks
  39. */
  40. SCHED_FEAT(NONTASK_CAPACITY, true)
  41. #ifdef CONFIG_PREEMPT_RT
  42. SCHED_FEAT(TTWU_QUEUE, false)
  43. #else
  44. /*
  45. * Queue remote wakeups on the target CPU and process them
  46. * using the scheduler IPI. Reduces rq->lock contention/bounces.
  47. */
  48. SCHED_FEAT(TTWU_QUEUE, true)
  49. #endif
  50. /*
  51. * When doing wakeups, attempt to limit superfluous scans of the LLC domain.
  52. */
  53. SCHED_FEAT(SIS_PROP, false)
  54. SCHED_FEAT(SIS_UTIL, true)
  55. /*
  56. * Issue a WARN when we do multiple update_rq_clock() calls
  57. * in a single rq->lock section. Default disabled because the
  58. * annotations are not complete.
  59. */
  60. SCHED_FEAT(WARN_DOUBLE_CLOCK, false)
  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. SCHED_FEAT(RT_RUNTIME_SHARE, false)
  74. SCHED_FEAT(LB_MIN, false)
  75. SCHED_FEAT(ATTACH_AGE_LOAD, true)
  76. SCHED_FEAT(WA_IDLE, true)
  77. SCHED_FEAT(WA_WEIGHT, true)
  78. SCHED_FEAT(WA_BIAS, true)
  79. /*
  80. * UtilEstimation. Use estimated CPU utilization.
  81. */
  82. SCHED_FEAT(UTIL_EST, true)
  83. SCHED_FEAT(UTIL_EST_FASTUP, true)
  84. SCHED_FEAT(LATENCY_WARN, false)
  85. SCHED_FEAT(ALT_PERIOD, true)
  86. SCHED_FEAT(BASE_SLICE, true)