diff options
-rw-r--r-- | include/linux/kernel.h | 18 | ||||
-rw-r--r-- | kernel/Kconfig.preempt | 57 |
2 files changed, 62 insertions, 13 deletions
diff --git a/include/linux/kernel.h b/include/linux/kernel.h index e25b97062ce1..687ba8c9973d 100644 --- a/include/linux/kernel.h +++ b/include/linux/kernel.h | |||
@@ -58,15 +58,23 @@ struct completion; | |||
58 | * be biten later when the calling function happens to sleep when it is not | 58 | * be biten later when the calling function happens to sleep when it is not |
59 | * supposed to. | 59 | * supposed to. |
60 | */ | 60 | */ |
61 | #ifdef CONFIG_PREEMPT_VOLUNTARY | ||
62 | extern int cond_resched(void); | ||
63 | # define might_resched() cond_resched() | ||
64 | #else | ||
65 | # define might_resched() do { } while (0) | ||
66 | #endif | ||
67 | |||
61 | #ifdef CONFIG_DEBUG_SPINLOCK_SLEEP | 68 | #ifdef CONFIG_DEBUG_SPINLOCK_SLEEP |
62 | #define might_sleep() __might_sleep(__FILE__, __LINE__) | 69 | void __might_sleep(char *file, int line); |
63 | #define might_sleep_if(cond) do { if (unlikely(cond)) might_sleep(); } while (0) | 70 | # define might_sleep() \ |
64 | void __might_sleep(char *file, int line); | 71 | do { __might_sleep(__FILE__, __LINE__); might_resched(); } while (0) |
65 | #else | 72 | #else |
66 | #define might_sleep() do {} while(0) | 73 | # define might_sleep() do { might_resched(); } while (0) |
67 | #define might_sleep_if(cond) do {} while (0) | ||
68 | #endif | 74 | #endif |
69 | 75 | ||
76 | #define might_sleep_if(cond) do { if (unlikely(cond)) might_sleep(); } while (0) | ||
77 | |||
70 | #define abs(x) ({ \ | 78 | #define abs(x) ({ \ |
71 | int __x = (x); \ | 79 | int __x = (x); \ |
72 | (__x < 0) ? -__x : __x; \ | 80 | (__x < 0) ? -__x : __x; \ |
diff --git a/kernel/Kconfig.preempt b/kernel/Kconfig.preempt index 34c631221aa3..0b46a5dff4c0 100644 --- a/kernel/Kconfig.preempt +++ b/kernel/Kconfig.preempt | |||
@@ -1,15 +1,56 @@ | |||
1 | 1 | ||
2 | config PREEMPT | 2 | choice |
3 | bool "Preemptible Kernel" | 3 | prompt "Preemption Model" |
4 | default PREEMPT_NONE | ||
5 | |||
6 | config PREEMPT_NONE | ||
7 | bool "No Forced Preemption (Server)" | ||
8 | help | ||
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)" | ||
4 | help | 21 | help |
5 | This option reduces the latency of the kernel when reacting to | 22 | This option reduces the latency of the kernel by adding more |
6 | real-time or interactive events by allowing a low priority process to | 23 | "explicit preemption points" to the kernel code. These new |
7 | be preempted even if it is in kernel mode executing a system call. | 24 | preemption points have been selected to reduce the maximum |
8 | This allows applications to run more reliably even when the system is | 25 | latency of rescheduling, providing faster application reactions, |
26 | at the cost of slighly lower throughput. | ||
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 | ||
9 | under load. | 32 | under load. |
10 | 33 | ||
11 | Say Y here if you are building a kernel for a desktop, embedded | 34 | Select this if you are building a kernel for a desktop system. |
12 | or real-time system. Say N if you are unsure. | 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 | ||
46 | system is under load, at the cost of slighly lower throughput | ||
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 | ||
13 | 54 | ||
14 | config PREEMPT_BKL | 55 | config PREEMPT_BKL |
15 | bool "Preempt The Big Kernel Lock" | 56 | bool "Preempt The Big Kernel Lock" |