On Sat, Dec 14, 2024 at 09:53:13PM +0100, Greg Kroah-Hartman wrote:
I'm announcing the release of the 6.1.120 kernel.
All users of the 6.1 kernel series must upgrade.
The updated 6.1.y git tree can be found at: git://git.kernel.org/pub/scm/linux/kernel/git/stable/linux-stable.git linux-6.1.y and can be browsed at the normal kernel.org git web browser: https://git.kernel.org/?p=linux/kernel/git/stable/linux-stable.git%3Ba=summa...
thanks,
greg k-h
Zqiang (1): rcu-tasks: Fix access non-existent percpu rtpcp variable in rcu_tasks_need_gpcb()
I was AFK last week so I missed reporting this, but on riscv this patch causes: [ 0.145463] BUG: sleeping function called from invalid context at include/linux/sched/mm.h:274 [ 0.155273] in_atomic(): 1, irqs_disabled(): 1, non_block: 0, pid: 1, name: swapper/0 [ 0.164160] preempt_count: 1, expected: 0 [ 0.168716] RCU nest depth: 0, expected: 0 [ 0.173370] 1 lock held by swapper/0/1: [ 0.177726] #0: ffffffff81494d78 (rcu_tasks.cbs_gbl_lock){....}-{2:2}, at: cblist_init_generic+0x2e/0x374 [ 0.188768] irq event stamp: 718 [ 0.192439] hardirqs last enabled at (717): [<ffffffff8098df90>] _raw_spin_unlock_irqrestore+0x34/0x5e [ 0.203098] hardirqs last disabled at (718): [<ffffffff8098de32>] _raw_spin_lock_irqsave+0x24/0x60 [ 0.213254] softirqs last enabled at (0): [<ffffffff800105d2>] copy_process+0x50c/0xdac [ 0.222445] softirqs last disabled at (0): [<0000000000000000>] 0x0 [ 0.229551] CPU: 0 PID: 1 Comm: swapper/0 Not tainted 6.1.119-00350-g224fd631c41b #1 [ 0.238330] Hardware name: Microchip PolarFire-SoC Icicle Kit (DT) [ 0.245329] Call Trace: [ 0.248113] [<ffffffff8000678c>] show_stack+0x2c/0x38 [ 0.253868] [<ffffffff80984e66>] dump_stack_lvl+0x5e/0x80 [ 0.260022] [<ffffffff80984e9c>] dump_stack+0x14/0x20 [ 0.265768] [<ffffffff800499b0>] __might_resched+0x200/0x20a [ 0.272217] [<ffffffff80049784>] __might_sleep+0x3c/0x68 [ 0.278258] [<ffffffff802022aa>] __kmem_cache_alloc_node+0x64/0x240 [ 0.285385] [<ffffffff801b1760>] __kmalloc+0xc0/0x180 [ 0.291140] [<ffffffff8008c752>] cblist_init_generic+0x84/0x374 [ 0.297857] [<ffffffff80a0b212>] rcu_spawn_tasks_kthread+0x1c/0x72 [ 0.304888] [<ffffffff80a0b0e8>] rcu_init_tasks_generic+0x20/0x12e [ 0.311902] [<ffffffff80a00eb8>] kernel_init_freeable+0x56/0xa8 [ 0.318638] [<ffffffff80985c10>] kernel_init+0x1a/0x18e [ 0.324574] [<ffffffff80004124>] ret_from_exception+0x0/0x1a
Hello, Xiangyu
For v6.1.x kernels, the cblist_init_generic() is invoke in init task context, rtp->rtpcp_array is allocated use GFP_KERENL and in the critical section holding rcu_tasks.cbs_gbl_lock spinlock. so might_resched() trigger warnings. You should perform the operation of allocating rtpcp_array memory outside the spinlock. Are you willing to resend the patch?
Thanks Zqiang
Reverting it fixed the problem.
Cheers, Conor.