# git rev-parse -q --verify 99f070b62322a4b8c1252952735806d09eb44b68^{commit} 99f070b62322a4b8c1252952735806d09eb44b68 already have revision, skipping fetch # git checkout -q -f -B kisskb 99f070b62322a4b8c1252952735806d09eb44b68 # git clean -qxdf # < git log -1 # commit 99f070b62322a4b8c1252952735806d09eb44b68 # Author: Qian Cai # Date: Wed Oct 28 14:23:34 2020 -0400 # # powerpc/smp: Call rcu_cpu_starting() earlier # # The call to rcu_cpu_starting() in start_secondary() is not early # enough in the CPU-hotplug onlining process, which results in lockdep # splats as follows (with CONFIG_PROVE_RCU_LIST=y): # # WARNING: suspicious RCU usage # ----------------------------- # kernel/locking/lockdep.c:3497 RCU-list traversed in non-reader section!! # # other info that might help us debug this: # # RCU used illegally from offline CPU! # rcu_scheduler_active = 1, debug_locks = 1 # no locks held by swapper/1/0. # # Call Trace: # dump_stack+0xec/0x144 (unreliable) # lockdep_rcu_suspicious+0x128/0x14c # __lock_acquire+0x1060/0x1c60 # lock_acquire+0x140/0x5f0 # _raw_spin_lock_irqsave+0x64/0xb0 # clockevents_register_device+0x74/0x270 # register_decrementer_clockevent+0x94/0x110 # start_secondary+0x134/0x800 # start_secondary_prolog+0x10/0x14 # # This is avoided by adding a call to rcu_cpu_starting() near the # beginning of the start_secondary() function. Note that the # raw_smp_processor_id() is required in order to avoid calling into # lockdep before RCU has declared the CPU to be watched for readers. # # It's safe to call rcu_cpu_starting() in the arch code as well as later # in generic code, as explained by Paul: # # It uses a per-CPU variable so that RCU pays attention only to the # first call to rcu_cpu_starting() if there is more than one of them. # This is even intentional, due to there being a generic # arch-independent call to rcu_cpu_starting() in # notify_cpu_starting(). # # So multiple calls to rcu_cpu_starting() are fine by design. # # Fixes: 4d004099a668 ("lockdep: Fix lockdep recursion") # Signed-off-by: Qian Cai # Acked-by: Paul E. McKenney # [mpe: Add Fixes tag, reword slightly & expand change log] # Signed-off-by: Michael Ellerman # Link: https://lore.kernel.org/r/20201028182334.13466-1-cai@redhat.com # < /opt/cross/kisskb/korg/gcc-4.9.4-nolibc/powerpc64-linux/bin/powerpc64-linux-gcc --version # < /opt/cross/kisskb/korg/gcc-4.9.4-nolibc/powerpc64-linux/bin/powerpc64-linux-ld --version # < git log --format=%s --max-count=1 99f070b62322a4b8c1252952735806d09eb44b68 # < make -s -j 120 ARCH=powerpc O=/kisskb/build/powerpc-fixes_mpc5200_defconfig_powerpc-gcc4.9 CROSS_COMPILE=/opt/cross/kisskb/korg/gcc-4.9.4-nolibc/powerpc64-linux/bin/powerpc64-linux- mpc5200_defconfig # make -s -j 120 ARCH=powerpc O=/kisskb/build/powerpc-fixes_mpc5200_defconfig_powerpc-gcc4.9 CROSS_COMPILE=/opt/cross/kisskb/korg/gcc-4.9.4-nolibc/powerpc64-linux/bin/powerpc64-linux- /kisskb/src/arch/powerpc/platforms/52xx/lite5200_sleep.S: Assembler messages: /kisskb/src/arch/powerpc/platforms/52xx/lite5200_sleep.S:184: Warning: invalid register expression /kisskb/src/block/genhd.c: In function 'diskstats_show': /kisskb/src/block/genhd.c:1659:1: warning: the frame size of 1160 bytes is larger than 1024 bytes [-Wframe-larger-than=] } ^ /kisskb/src/lib/zstd/compress.c: In function 'ZSTD_compressBlock_doubleFast': /kisskb/src/lib/zstd/compress.c:1393:1: warning: the frame size of 1584 bytes is larger than 1024 bytes [-Wframe-larger-than=] } ^ INFO: Uncompressed kernel (size 0x825954) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0x900000) INFO: Uncompressed kernel (size 0x825954) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0x900000) INFO: Uncompressed kernel (size 0x825954) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0x900000) INFO: Uncompressed kernel (size 0x81529c) overlaps the address of the wrapper(0x400000) INFO: Fixing the link_address of wrapper to (0x900000) Image Name: Linux-5.10.0-rc2-g99f070b62322 Created: Tue Nov 3 00:38:49 2020 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 3781273 Bytes = 3692.65 KiB = 3.61 MiB Load Address: 00000000 Entry Point: 00000000 Image Name: Linux-5.10.0-rc2-g99f070b62322 Created: Tue Nov 3 00:38:49 2020 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 3812540 Bytes = 3723.18 KiB = 3.64 MiB Load Address: 00900000 Entry Point: 00900274 Image Name: Linux-5.10.0-rc2-g99f070b62322 Created: Tue Nov 3 00:38:49 2020 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 3812492 Bytes = 3723.14 KiB = 3.64 MiB Load Address: 00900000 Entry Point: 00900274 Image Name: Linux-5.10.0-rc2-g99f070b62322 Created: Tue Nov 3 00:38:49 2020 Image Type: PowerPC Linux Kernel Image (gzip compressed) Data Size: 3812230 Bytes = 3722.88 KiB = 3.64 MiB Load Address: 00900000 Entry Point: 00900274 Completed OK # rm -rf /kisskb/build/powerpc-fixes_mpc5200_defconfig_powerpc-gcc4.9 # Build took: 0:00:43.141182