On Thu, Mar 05, 2026 at 10:22:35AM -0800, Boqun Feng wrote:
> Hi Paul,
>
> On Wed, Mar 04, 2026 at 04:01:19PM -0800, Paul E. McKenney wrote:
> > As of v7.0-rc1, architectures that support preemption, including x86 and
> > arm64, no longer support CONFIG_PREEMPT_NONE or CONFIG_PREEMPT_VOLUNTARY.
> > Attempting to build kernels with these two Kconfig options results in
> > .config errors. This commit therefore switches such rcutorture scenarios
> > to CONFIG_PREEMPT_LAZY.
> >
> > Signed-off-by: Paul E. McKenney <[email protected]>
> >
> > ---
> >
> > Changes since v2:
> >
> > o Fold in c69ac5693540 ("rcutorture: Adjust scenarios for default
> > lazy preemption")
> >
>
> I'm not sure I got what the "Fold" here means? I think you didn't do the
> fold? Because..
>
> > Changes since v1:
> >
> > o Add CONFIG_PREEMPT_DYNAMIC=n in order to test non-preemptible RCU.
> >
> > o Remove CONFIG_PREEMPT_COUNT=n because it conflicts with
> > CONFIG_PREEMPT_LAZY=y.
> >
> > o Remove some stray conflicting CONFIG_PREEMPT_LAZY=n instances.
> >
> > diff --git a/tools/testing/selftests/rcutorture/configs/rcu/SRCU-N
> > b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-N
> > index 07f5e0a70ae70..f943cdfb0a741 100644
> > --- a/tools/testing/selftests/rcutorture/configs/rcu/SRCU-N
> > +++ b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-N
> > @@ -2,7 +2,9 @@ CONFIG_RCU_TRACE=n
> > CONFIG_SMP=y
> > CONFIG_NR_CPUS=4
> > CONFIG_HOTPLUG_CPU=y
> > -CONFIG_PREEMPT_NONE=y
> > +CONFIG_PREEMPT_DYNAMIC=n
> > +CONFIG_PREEMPT_LAZY=y
> > +CONFIG_PREEMPT_NONE=n
> > CONFIG_PREEMPT_VOLUNTARY=n
> > CONFIG_PREEMPT=n
> > #CHECK#CONFIG_RCU_EXPERT=n
> > diff --git a/tools/testing/selftests/rcutorture/configs/rcu/SRCU-T
> > b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-T
> > index c70cf0405f248..06e4d1030279c 100644
> > --- a/tools/testing/selftests/rcutorture/configs/rcu/SRCU-T
> > +++ b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-T
> > @@ -1,5 +1,6 @@
> > CONFIG_SMP=n
> > -CONFIG_PREEMPT_NONE=y
> > +CONFIG_PREEMPT_LAZY=y
> > +CONFIG_PREEMPT_NONE=n
> > CONFIG_PREEMPT_VOLUNTARY=n
> > CONFIG_PREEMPT=n
> > CONFIG_PREEMPT_DYNAMIC=n
> > diff --git a/tools/testing/selftests/rcutorture/configs/rcu/SRCU-U
> > b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-U
> > index bc9eeabaa1b18..71da6e3e94886 100644
> > --- a/tools/testing/selftests/rcutorture/configs/rcu/SRCU-U
> > +++ b/tools/testing/selftests/rcutorture/configs/rcu/SRCU-U
> > @@ -1,5 +1,6 @@
> > CONFIG_SMP=n
> > -CONFIG_PREEMPT_NONE=y
> > +CONFIG_PREEMPT_LAZY=y
> > +CONFIG_PREEMPT_NONE=n
> > CONFIG_PREEMPT_VOLUNTARY=n
> > CONFIG_PREEMPT=n
> > CONFIG_PREEMPT_DYNAMIC=n
> > @@ -7,4 +8,3 @@ CONFIG_PREEMPT_DYNAMIC=n
> > CONFIG_RCU_TRACE=n
> > CONFIG_DEBUG_LOCK_ALLOC=n
> > CONFIG_DEBUG_OBJECTS_RCU_HEAD=n
> > -CONFIG_PREEMPT_COUNT=n
> > diff --git a/tools/testing/selftests/rcutorture/configs/rcu/TASKS02
> > b/tools/testing/selftests/rcutorture/configs/rcu/TASKS02
> > index 2f9fcffff5ae3..dd2bd4e08da4e 100644
> > --- a/tools/testing/selftests/rcutorture/configs/rcu/TASKS02
> > +++ b/tools/testing/selftests/rcutorture/configs/rcu/TASKS02
> > @@ -1,5 +1,6 @@
> > CONFIG_SMP=n
> > -CONFIG_PREEMPT_NONE=y
> > +CONFIG_PREEMPT_LAZY=y
> > +CONFIG_PREEMPT_NONE=n
> > CONFIG_PREEMPT_VOLUNTARY=n
> > CONFIG_PREEMPT=n
> > CONFIG_PREEMPT_DYNAMIC=n
> > diff --git a/tools/testing/selftests/rcutorture/configs/rcu/TINY01
> > b/tools/testing/selftests/rcutorture/configs/rcu/TINY01
> > index bd5ed7b0da5f0..2be53bf60d65b 100644
> > --- a/tools/testing/selftests/rcutorture/configs/rcu/TINY01
> > +++ b/tools/testing/selftests/rcutorture/configs/rcu/TINY01
> > @@ -1,9 +1,9 @@
> > CONFIG_SMP=n
> > -CONFIG_PREEMPT_NONE=y
> > +CONFIG_PREEMPT_LAZY=y
> > +CONFIG_PREEMPT_NONE=n
> > CONFIG_PREEMPT_VOLUNTARY=n
> > CONFIG_PREEMPT=n
> > CONFIG_PREEMPT_DYNAMIC=n
> > -CONFIG_PREEMPT_LAZY=n
>
> This is the line that was introduced by the said commit, hence this
> patch is still separate from that commit I think?
I *think* I have them folded/squashed correctly.
I pushed this out to my -rcu "dev" branch. The relevant commits are,
in order of increasing time of commit:
c69ac5693540 ("rcutorture: Adjust scenarios for default lazy preemption")
86126bc6d7ad ("rcutorture: Update due to x86 not supporting none/voluntary
preemption")
5631c1565493 ("Revert "rcutorture: Adjust scenarios for default lazy
preemption"")
6fd95cee7427 ("Revert "rcutorture: Update due to x86 not supporting
none/voluntary preemption"")
17c52d7b31a1 ("rcutorture: Update due to x86 not supporting none/voluntary
preemption")
The first was applied by Joel to the shared RCU tree, the second is in my
-rcu tree, and the last three are consecutive commits in my -rcu tree.
The following command gives no output, which I was interpreting as my
having done it correctly. But please double-check.
git diff 5631c1565493^..17c52d7b31a1
Thanx, Paul
> Regards,
> Boqun
>
> > #CHECK#CONFIG_TINY_RCU=y
> > CONFIG_HZ_PERIODIC=n
> > CONFIG_NO_HZ_IDLE=y
> > @@ -12,4 +12,3 @@ CONFIG_RCU_TRACE=n
> > #CHECK#CONFIG_RCU_STALL_COMMON=n
> > CONFIG_DEBUG_LOCK_ALLOC=n
> > CONFIG_DEBUG_OBJECTS_RCU_HEAD=n
> > -CONFIG_PREEMPT_COUNT=n
> > diff --git a/tools/testing/selftests/rcutorture/configs/rcu/TINY02
> > b/tools/testing/selftests/rcutorture/configs/rcu/TINY02
> > index 30439f6fc20e6..be8860342ef71 100644
> > --- a/tools/testing/selftests/rcutorture/configs/rcu/TINY02
> > +++ b/tools/testing/selftests/rcutorture/configs/rcu/TINY02
> > @@ -1,5 +1,6 @@
> > CONFIG_SMP=n
> > -CONFIG_PREEMPT_NONE=y
> > +CONFIG_PREEMPT_LAZY=y
> > +CONFIG_PREEMPT_NONE=n
> > CONFIG_PREEMPT_VOLUNTARY=n
> > CONFIG_PREEMPT=n
> > CONFIG_PREEMPT_DYNAMIC=n
> > diff --git a/tools/testing/selftests/rcutorture/configs/rcu/TRACE01
> > b/tools/testing/selftests/rcutorture/configs/rcu/TRACE01
> > index 18efab346381a..8fb124c28f283 100644
> > --- a/tools/testing/selftests/rcutorture/configs/rcu/TRACE01
> > +++ b/tools/testing/selftests/rcutorture/configs/rcu/TRACE01
> > @@ -1,7 +1,8 @@
> > CONFIG_SMP=y
> > CONFIG_NR_CPUS=5
> > CONFIG_HOTPLUG_CPU=y
> > -CONFIG_PREEMPT_NONE=y
> > +CONFIG_PREEMPT_LAZY=y
> > +CONFIG_PREEMPT_NONE=n
> > CONFIG_PREEMPT_VOLUNTARY=n
> > CONFIG_PREEMPT=n
> > CONFIG_PREEMPT_DYNAMIC=n
> > diff --git a/tools/testing/selftests/rcutorture/configs/rcu/TREE04
> > b/tools/testing/selftests/rcutorture/configs/rcu/TREE04
> > index 34aee1acb8662..ac857d5bcb222 100644
> > --- a/tools/testing/selftests/rcutorture/configs/rcu/TREE04
> > +++ b/tools/testing/selftests/rcutorture/configs/rcu/TREE04
> > @@ -1,11 +1,12 @@
> > CONFIG_SMP=y
> > CONFIG_NR_CPUS=8
> > +CONFIG_PREEMPT_LAZY=y
> > CONFIG_PREEMPT_NONE=n
> > -CONFIG_PREEMPT_VOLUNTARY=y
> > +CONFIG_PREEMPT_VOLUNTARY=n
> > CONFIG_PREEMPT=n
> > CONFIG_PREEMPT_DYNAMIC=n
> > -CONFIG_PREEMPT_LAZY=n
> > #CHECK#CONFIG_TREE_RCU=y
> > +#CHECK#CONFIG_PREEMPT_RCU=n
> > CONFIG_HZ_PERIODIC=n
> > CONFIG_NO_HZ_IDLE=n
> > CONFIG_NO_HZ_FULL=y
> > diff --git a/tools/testing/selftests/rcutorture/configs/rcu/TREE05
> > b/tools/testing/selftests/rcutorture/configs/rcu/TREE05
> > index 0513aa33c32c4..61d15b1b54d16 100644
> > --- a/tools/testing/selftests/rcutorture/configs/rcu/TREE05
> > +++ b/tools/testing/selftests/rcutorture/configs/rcu/TREE05
> > @@ -1,9 +1,10 @@
> > CONFIG_SMP=y
> > CONFIG_NR_CPUS=8
> > -CONFIG_PREEMPT_NONE=y
> > +CONFIG_PREEMPT_DYNAMIC=n
> > +CONFIG_PREEMPT_LAZY=y
> > +CONFIG_PREEMPT_NONE=n
> > CONFIG_PREEMPT_VOLUNTARY=n
> > CONFIG_PREEMPT=n
> > -CONFIG_PREEMPT_LAZY=n
> > #CHECK#CONFIG_TREE_RCU=y
> > CONFIG_HZ_PERIODIC=n
> > CONFIG_NO_HZ_IDLE=y
> > diff --git a/tools/testing/selftests/rcutorture/configs/rcu/TREE06
> > b/tools/testing/selftests/rcutorture/configs/rcu/TREE06
> > index cc3ea23c76557..0e090bb68a0f6 100644
> > --- a/tools/testing/selftests/rcutorture/configs/rcu/TREE06
> > +++ b/tools/testing/selftests/rcutorture/configs/rcu/TREE06
> > @@ -1,10 +1,12 @@
> > CONFIG_SMP=y
> > CONFIG_NR_CPUS=8
> > -CONFIG_PREEMPT_NONE=y
> > +CONFIG_PREEMPT_DYNAMIC=n
> > +CONFIG_PREEMPT_LAZY=y
> > +CONFIG_PREEMPT_NONE=n
> > CONFIG_PREEMPT_VOLUNTARY=n
> > CONFIG_PREEMPT=n
> > -CONFIG_PREEMPT_LAZY=n
> > #CHECK#CONFIG_TREE_RCU=y
> > +#CHECK#CONFIG_PREEMPT_RCU=n
> > CONFIG_HZ_PERIODIC=n
> > CONFIG_NO_HZ_IDLE=y
> > CONFIG_NO_HZ_FULL=n
> > diff --git a/tools/testing/selftests/rcutorture/configs/rcu/TREE10
> > b/tools/testing/selftests/rcutorture/configs/rcu/TREE10
> > index 420632b030dc4..b2ce37861e71a 100644
> > --- a/tools/testing/selftests/rcutorture/configs/rcu/TREE10
> > +++ b/tools/testing/selftests/rcutorture/configs/rcu/TREE10
> > @@ -6,6 +6,7 @@ CONFIG_PREEMPT_VOLUNTARY=n
> > CONFIG_PREEMPT=n
> > CONFIG_PREEMPT_DYNAMIC=n
> > #CHECK#CONFIG_TREE_RCU=y
> > +CONFIG_PREEMPT_RCU=n
> > CONFIG_HZ_PERIODIC=n
> > CONFIG_NO_HZ_IDLE=y
> > CONFIG_NO_HZ_FULL=n
> > diff --git a/tools/testing/selftests/rcutorture/configs/rcu/TRIVIAL
> > b/tools/testing/selftests/rcutorture/configs/rcu/TRIVIAL
> > index 5d546efa68e83..696fba9968c60 100644
> > --- a/tools/testing/selftests/rcutorture/configs/rcu/TRIVIAL
> > +++ b/tools/testing/selftests/rcutorture/configs/rcu/TRIVIAL
> > @@ -1,6 +1,8 @@
> > CONFIG_SMP=y
> > CONFIG_NR_CPUS=8
> > -CONFIG_PREEMPT_NONE=y
> > +CONFIG_PREEMPT_DYNAMIC=n
> > +CONFIG_PREEMPT_LAZY=y
> > +CONFIG_PREEMPT_NONE=n
> > CONFIG_PREEMPT_VOLUNTARY=n
> > CONFIG_PREEMPT=n
> > CONFIG_HZ_PERIODIC=n
> >