|  | # SPDX-License-Identifier: GPL-2.0-only | 
|  |  | 
|  | config PREEMPT_NONE_BUILD | 
|  | bool | 
|  |  | 
|  | config PREEMPT_VOLUNTARY_BUILD | 
|  | bool | 
|  |  | 
|  | config PREEMPT_BUILD | 
|  | bool | 
|  | select PREEMPTION | 
|  | select UNINLINE_SPIN_UNLOCK if !ARCH_INLINE_SPIN_UNLOCK | 
|  |  | 
|  | choice | 
|  | prompt "Preemption Model" | 
|  | default PREEMPT_NONE | 
|  |  | 
|  | config PREEMPT_NONE | 
|  | bool "No Forced Preemption (Server)" | 
|  | select PREEMPT_NONE_BUILD if !PREEMPT_DYNAMIC | 
|  | help | 
|  | This is the traditional Linux preemption model, geared towards | 
|  | throughput. It will still provide good latencies most of the | 
|  | time, but there are no guarantees and occasional longer delays | 
|  | are possible. | 
|  |  | 
|  | Select this option if you are building a kernel for a server or | 
|  | scientific/computation system, or if you want to maximize the | 
|  | raw processing power of the kernel, irrespective of scheduling | 
|  | latencies. | 
|  |  | 
|  | config PREEMPT_VOLUNTARY | 
|  | bool "Voluntary Kernel Preemption (Desktop)" | 
|  | depends on !ARCH_NO_PREEMPT | 
|  | select PREEMPT_VOLUNTARY_BUILD if !PREEMPT_DYNAMIC | 
|  | help | 
|  | This option reduces the latency of the kernel by adding more | 
|  | "explicit preemption points" to the kernel code. These new | 
|  | preemption points have been selected to reduce the maximum | 
|  | latency of rescheduling, providing faster application reactions, | 
|  | at the cost of slightly lower throughput. | 
|  |  | 
|  | This allows reaction to interactive events by allowing a | 
|  | low priority process to voluntarily preempt itself even if it | 
|  | is in kernel mode executing a system call. This allows | 
|  | applications to run more 'smoothly' even when the system is | 
|  | under load. | 
|  |  | 
|  | Select this if you are building a kernel for a desktop system. | 
|  |  | 
|  | config PREEMPT | 
|  | bool "Preemptible Kernel (Low-Latency Desktop)" | 
|  | depends on !ARCH_NO_PREEMPT | 
|  | select PREEMPT_BUILD | 
|  | help | 
|  | This option reduces the latency of the kernel by making | 
|  | all kernel code (that is not executing in a critical section) | 
|  | preemptible.  This allows reaction to interactive events by | 
|  | permitting a low priority process to be preempted involuntarily | 
|  | even if it is in kernel mode executing a system call and would | 
|  | otherwise not be about to reach a natural preemption point. | 
|  | This allows applications to run more 'smoothly' even when the | 
|  | system is under load, at the cost of slightly lower throughput | 
|  | and a slight runtime overhead to kernel code. | 
|  |  | 
|  | Select this if you are building a kernel for a desktop or | 
|  | embedded system with latency requirements in the milliseconds | 
|  | range. | 
|  |  | 
|  | config PREEMPT_RT | 
|  | bool "Fully Preemptible Kernel (Real-Time)" | 
|  | depends on EXPERT && ARCH_SUPPORTS_RT | 
|  | select PREEMPTION | 
|  | help | 
|  | This option turns the kernel into a real-time kernel by replacing | 
|  | various locking primitives (spinlocks, rwlocks, etc.) with | 
|  | preemptible priority-inheritance aware variants, enforcing | 
|  | interrupt threading and introducing mechanisms to break up long | 
|  | non-preemptible sections. This makes the kernel, except for very | 
|  | low level and critical code paths (entry code, scheduler, low | 
|  | level interrupt handling) fully preemptible and brings most | 
|  | execution contexts under scheduler control. | 
|  |  | 
|  | Select this if you are building a kernel for systems which | 
|  | require real-time guarantees. | 
|  |  | 
|  | endchoice | 
|  |  | 
|  | config PREEMPT_COUNT | 
|  | bool | 
|  |  | 
|  | config PREEMPTION | 
|  | bool | 
|  | select PREEMPT_COUNT | 
|  |  | 
|  | config PREEMPT_DYNAMIC | 
|  | bool "Preemption behaviour defined on boot" | 
|  | depends on HAVE_PREEMPT_DYNAMIC && !PREEMPT_RT | 
|  | select JUMP_LABEL if HAVE_PREEMPT_DYNAMIC_KEY | 
|  | select PREEMPT_BUILD | 
|  | default y if HAVE_PREEMPT_DYNAMIC_CALL | 
|  | help | 
|  | This option allows to define the preemption model on the kernel | 
|  | command line parameter and thus override the default preemption | 
|  | model defined during compile time. | 
|  |  | 
|  | The feature is primarily interesting for Linux distributions which | 
|  | provide a pre-built kernel binary to reduce the number of kernel | 
|  | flavors they offer while still offering different usecases. | 
|  |  | 
|  | The runtime overhead is negligible with HAVE_STATIC_CALL_INLINE enabled | 
|  | but if runtime patching is not available for the specific architecture | 
|  | then the potential overhead should be considered. | 
|  |  | 
|  | Interesting if you want the same pre-built kernel should be used for | 
|  | both Server and Desktop workloads. | 
|  |  | 
|  | config SCHED_CORE | 
|  | bool "Core Scheduling for SMT" | 
|  | depends on SCHED_SMT | 
|  | help | 
|  | This option permits Core Scheduling, a means of coordinated task | 
|  | selection across SMT siblings. When enabled -- see | 
|  | prctl(PR_SCHED_CORE) -- task selection ensures that all SMT siblings | 
|  | will execute a task from the same 'core group', forcing idle when no | 
|  | matching task is found. | 
|  |  | 
|  | Use of this feature includes: | 
|  | - mitigation of some (not all) SMT side channels; | 
|  | - limiting SMT interference to improve determinism and/or performance. | 
|  |  | 
|  | SCHED_CORE is default disabled. When it is enabled and unused, | 
|  | which is the likely usage by Linux distributions, there should | 
|  | be no measurable impact on performance. | 
|  |  | 
|  |  |