Ingo Molnar | cc19ca8 | 2005-06-25 14:57:36 -0700 | [diff] [blame] | 1 | |
Ingo Molnar | f8cbd99 | 2005-06-25 14:57:39 -0700 | [diff] [blame] | 2 | choice |
| 3 | prompt "Preemption Model" |
| 4 | default PREEMPT_NONE |
| 5 | |
| 6 | config PREEMPT_NONE |
| 7 | bool "No Forced Preemption (Server)" |
Ingo Molnar | cc19ca8 | 2005-06-25 14:57:36 -0700 | [diff] [blame] | 8 | help |
Ingo Molnar | f8cbd99 | 2005-06-25 14:57:39 -0700 | [diff] [blame] | 9 | This is the traditional Linux preemption model, geared towards |
| 10 | throughput. It will still provide good latencies most of the |
| 11 | time, but there are no guarantees and occasional longer delays |
| 12 | are possible. |
| 13 | |
| 14 | Select this option if you are building a kernel for a server or |
| 15 | scientific/computation system, or if you want to maximize the |
| 16 | raw processing power of the kernel, irrespective of scheduling |
| 17 | latencies. |
| 18 | |
| 19 | config PREEMPT_VOLUNTARY |
| 20 | bool "Voluntary Kernel Preemption (Desktop)" |
| 21 | help |
| 22 | This option reduces the latency of the kernel by adding more |
| 23 | "explicit preemption points" to the kernel code. These new |
| 24 | preemption points have been selected to reduce the maximum |
| 25 | latency of rescheduling, providing faster application reactions, |
David Sterba | 3dde6ad | 2007-05-09 07:12:20 +0200 | [diff] [blame] | 26 | at the cost of slightly lower throughput. |
Ingo Molnar | f8cbd99 | 2005-06-25 14:57:39 -0700 | [diff] [blame] | 27 | |
| 28 | This allows reaction to interactive events by allowing a |
| 29 | low priority process to voluntarily preempt itself even if it |
| 30 | is in kernel mode executing a system call. This allows |
| 31 | applications to run more 'smoothly' even when the system is |
Ingo Molnar | cc19ca8 | 2005-06-25 14:57:36 -0700 | [diff] [blame] | 32 | under load. |
| 33 | |
Ingo Molnar | f8cbd99 | 2005-06-25 14:57:39 -0700 | [diff] [blame] | 34 | Select this if you are building a kernel for a desktop system. |
| 35 | |
| 36 | config PREEMPT |
| 37 | bool "Preemptible Kernel (Low-Latency Desktop)" |
| 38 | help |
| 39 | This option reduces the latency of the kernel by making |
| 40 | all kernel code (that is not executing in a critical section) |
| 41 | preemptible. This allows reaction to interactive events by |
| 42 | permitting a low priority process to be preempted involuntarily |
| 43 | even if it is in kernel mode executing a system call and would |
| 44 | otherwise not be about to reach a natural preemption point. |
| 45 | This allows applications to run more 'smoothly' even when the |
David Sterba | 3dde6ad | 2007-05-09 07:12:20 +0200 | [diff] [blame] | 46 | system is under load, at the cost of slightly lower throughput |
Ingo Molnar | f8cbd99 | 2005-06-25 14:57:39 -0700 | [diff] [blame] | 47 | and a slight runtime overhead to kernel code. |
| 48 | |
| 49 | Select this if you are building a kernel for a desktop or |
| 50 | embedded system with latency requirements in the milliseconds |
| 51 | range. |
| 52 | |
| 53 | endchoice |
Ingo Molnar | cc19ca8 | 2005-06-25 14:57:36 -0700 | [diff] [blame] | 54 | |
Paul E. McKenney | 21bbb39 | 2008-03-10 11:43:57 -0700 | [diff] [blame] | 55 | config PREEMPT_RCU |
| 56 | bool "Preemptible RCU" |
| 57 | depends on PREEMPT |
| 58 | default n |
| 59 | help |
| 60 | This option reduces the latency of the kernel by making certain |
| 61 | RCU sections preemptible. Normally RCU code is non-preemptible, if |
| 62 | this option is selected then read-only RCU sections become |
| 63 | preemptible. This helps latency, but may expose bugs due to |
| 64 | now-naive assumptions about each RCU read-side critical section |
| 65 | remaining on a given CPU through its execution. |
| 66 | |
| 67 | Say N if you are unsure. |
| 68 | |
Paul E. McKenney | e260be6 | 2008-01-25 21:08:24 +0100 | [diff] [blame] | 69 | config RCU_TRACE |
| 70 | bool "Enable tracing for RCU - currently stats in debugfs" |
Paul E. McKenney | 21bbb39 | 2008-03-10 11:43:57 -0700 | [diff] [blame] | 71 | depends on PREEMPT_RCU |
Paul E. McKenney | e260be6 | 2008-01-25 21:08:24 +0100 | [diff] [blame] | 72 | select DEBUG_FS |
| 73 | default y |
| 74 | help |
| 75 | This option provides tracing in RCU which presents stats |
| 76 | in debugfs for debugging RCU implementation. |
| 77 | |
| 78 | Say Y here if you want to enable RCU tracing |
| 79 | Say N if you are unsure. |