| .. | .. |
|---|
| 1 | +# SPDX-License-Identifier: GPL-2.0-only |
|---|
| 1 | 2 | # |
|---|
| 2 | 3 | # RCU-related debugging configuration options |
|---|
| 3 | 4 | # |
|---|
| .. | .. |
|---|
| 7 | 8 | config PROVE_RCU |
|---|
| 8 | 9 | def_bool PROVE_LOCKING |
|---|
| 9 | 10 | |
|---|
| 11 | +config PROVE_RCU_LIST |
|---|
| 12 | + bool "RCU list lockdep debugging" |
|---|
| 13 | + depends on PROVE_RCU && RCU_EXPERT |
|---|
| 14 | + default n |
|---|
| 15 | + help |
|---|
| 16 | + Enable RCU lockdep checking for list usages. By default it is |
|---|
| 17 | + turned off since there are several list RCU users that still |
|---|
| 18 | + need to be converted to pass a lockdep expression. To prevent |
|---|
| 19 | + false-positive splats, we keep it default disabled but once all |
|---|
| 20 | + users are converted, we can remove this config option. |
|---|
| 21 | + |
|---|
| 10 | 22 | config TORTURE_TEST |
|---|
| 11 | 23 | tristate |
|---|
| 12 | 24 | default n |
|---|
| 13 | 25 | |
|---|
| 14 | | -config RCU_PERF_TEST |
|---|
| 26 | +config RCU_SCALE_TEST |
|---|
| 15 | 27 | tristate "performance tests for RCU" |
|---|
| 16 | 28 | depends on DEBUG_KERNEL |
|---|
| 17 | 29 | select TORTURE_TEST |
|---|
| 18 | 30 | select SRCU |
|---|
| 19 | 31 | select TASKS_RCU |
|---|
| 32 | + select TASKS_RUDE_RCU |
|---|
| 33 | + select TASKS_TRACE_RCU |
|---|
| 20 | 34 | default n |
|---|
| 21 | 35 | help |
|---|
| 22 | 36 | This option provides a kernel module that runs performance |
|---|
| .. | .. |
|---|
| 34 | 48 | select TORTURE_TEST |
|---|
| 35 | 49 | select SRCU |
|---|
| 36 | 50 | select TASKS_RCU |
|---|
| 51 | + select TASKS_RUDE_RCU |
|---|
| 52 | + select TASKS_TRACE_RCU |
|---|
| 37 | 53 | default n |
|---|
| 38 | 54 | help |
|---|
| 39 | 55 | This option provides a kernel module that runs torture tests |
|---|
| .. | .. |
|---|
| 43 | 59 | Say Y here if you want RCU torture tests to be built into |
|---|
| 44 | 60 | the kernel. |
|---|
| 45 | 61 | Say M if you want the RCU torture tests to build as a module. |
|---|
| 62 | + Say N if you are unsure. |
|---|
| 63 | + |
|---|
| 64 | +config RCU_REF_SCALE_TEST |
|---|
| 65 | + tristate "Scalability tests for read-side synchronization (RCU and others)" |
|---|
| 66 | + depends on DEBUG_KERNEL |
|---|
| 67 | + select TORTURE_TEST |
|---|
| 68 | + select SRCU |
|---|
| 69 | + select TASKS_RCU |
|---|
| 70 | + select TASKS_RUDE_RCU |
|---|
| 71 | + select TASKS_TRACE_RCU |
|---|
| 72 | + default n |
|---|
| 73 | + help |
|---|
| 74 | + This option provides a kernel module that runs performance tests |
|---|
| 75 | + useful comparing RCU with various read-side synchronization mechanisms. |
|---|
| 76 | + The kernel module may be built after the fact on the running kernel to be |
|---|
| 77 | + tested, if desired. |
|---|
| 78 | + |
|---|
| 79 | + Say Y here if you want these performance tests built into the kernel. |
|---|
| 80 | + Say M if you want to build it as a module instead. |
|---|
| 46 | 81 | Say N if you are unsure. |
|---|
| 47 | 82 | |
|---|
| 48 | 83 | config RCU_CPU_STALL_TIMEOUT |
|---|
| .. | .. |
|---|
| 102 | 137 | Say N here if you need ultimate kernel/user switch latencies |
|---|
| 103 | 138 | Say Y if you are unsure |
|---|
| 104 | 139 | |
|---|
| 140 | +config RCU_STRICT_GRACE_PERIOD |
|---|
| 141 | + bool "Provide debug RCU implementation with short grace periods" |
|---|
| 142 | + depends on DEBUG_KERNEL && RCU_EXPERT |
|---|
| 143 | + default n |
|---|
| 144 | + select PREEMPT_COUNT if PREEMPT=n |
|---|
| 145 | + help |
|---|
| 146 | + Select this option to build an RCU variant that is strict about |
|---|
| 147 | + grace periods, making them as short as it can. This limits |
|---|
| 148 | + scalability, destroys real-time response, degrades battery |
|---|
| 149 | + lifetime and kills performance. Don't try this on large |
|---|
| 150 | + machines, as in systems with more than about 10 or 20 CPUs. |
|---|
| 151 | + But in conjunction with tools like KASAN, it can be helpful |
|---|
| 152 | + when looking for certain types of RCU usage bugs, for example, |
|---|
| 153 | + too-short RCU read-side critical sections. |
|---|
| 154 | + |
|---|
| 105 | 155 | endmenu # "RCU Debugging" |
|---|