>
> 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;a=summary
> >
> > 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.

Reply via email to