Re: spinlock recursion when running q800 emulation in qemu

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Guenter,

Am 05.03.2024 um 06:58 schrieb Guenter Roeck:
Hi,

when running the q800 qemu emulation, am seeing random "spinlock recursion"
messages every few test runs. Some examples are below. This is not a new
problem, but it keeps popping up.

Is this a potential problem or just noise ?

Looking at the backtraces some more, I think what happens here is that the swapper kernel task is stalled for long enough here that on the next scheduler tick, it is still running. With no other tasks scheduled to run in the meantime, it may still be the current task.

The stalled swapper task still holds the run queue lock, hence the recursion message.

I do not think this is a bug, just a reflection of a slow system with nothing much to do.

There does not appear to be any interrupt nesting here. I cannot recall the interrupt level assignment on the Q800, in particular as regards disk interrupts and whether both VIAs are using the same interrupt level. I'd suppose they would, as these chips date back a long time and probably cannot place a vector number on the bus as part of the interrupt stack frame?

Whether I can hope to see interrupt nesting on my Atari is unclear - pretty much anything on that machine is generating interrupts via the ST-MFP so it's all at the same level.

Cheers,

	Michael



Thanks,
Guenter

---
BUG: spinlock recursion on CPU#0, swapper/1
 lock: 0x5875c0, .magic: dead4ead, .owner: swapper/1, .owner_cpu: 0
CPU: 0 PID: 1 Comm: swapper Not tainted 6.8.0-rc6-mac-00037-g805d849d7c3c #1
Stack from 00c49e80:
        00c49e80 0051c8da 0051c8da 005875c0 00000000 003ec2de 0051c8da 00038e26
        005875c0 004f094b 00c4c010 0003025a 005875c0 00c49ec4 00030272 005875c0
        00000000 00c49ed4 00031592 00000000 00c15100 0003df46 0004b6b6 00000000
        00006b1e 00000000 0003dfc0 0000000e 00000000 00000000 00042608 0000000f
        00000000 005ba9b0 005baa0c 00000000 00000000 0003e050 005ba9b0 00000000
        005ba9b0 0003e0a6 005ba9b0 005baa0c 00000000 005ba9b0 005baa0c 00040524
Call Trace: [<003ec2de>] dump_stack+0xc/0x10
 [<00038e26>] do_raw_spin_lock+0x34/0x58
 [<0003025a>] raw_spin_rq_lock_nested+0xe/0x14
 [<00030272>] raw_spin_rq_lock.constprop.0+0x12/0x18
 [<00031592>] scheduler_tick+0x18/0x62
 [<0003df46>] __irq_wake_thread+0x0/0x40
 [<0004b6b6>] update_process_times+0x5e/0x68
 [<00006b1e>] via_timer_handler+0x1a/0x20
 [<0003dfc0>] __handle_irq_event_percpu+0x3a/0xba
 [<00042608>] check_all_holdout_tasks_trace+0x114/0x25a
 [<0003e050>] handle_irq_event_percpu+0x10/0x3a
 [<0003e0a6>] handle_irq_event+0x2c/0x4e
 [<00040524>] handle_simple_irq+0x64/0x68
 [<003ec3ba>] kernel_init+0x0/0xec
 [<0003db76>] handle_irq_desc+0x1e/0x28
 [<000069be>] via1_irq+0x42/0x80
 [<00046914>] resolve_symbol+0x192/0x27e
 [<003ec3ba>] kernel_init+0x0/0xec
 [<0003db76>] handle_irq_desc+0x1e/0x28
 [<00002798>] do_IRQ+0x20/0x32
 [<00002698>] auto_irqhandler_fixup+0x4/0xc
 [<00046914>] resolve_symbol+0x192/0x27e
 [<00002530>] ret_from_kernel_thread+0x0/0x14
RCU Tasks Trace: Setting shift to 0 and lim to 1 rcu_task_cb_adjust=1.

---
BUG: spinlock recursion on CPU#0, swapper/2
 lock: 0x5875c0, .magic: dead4ead, .owner: swapper/2, .owner_cpu: 0
CPU: 0 PID: 2 Comm: swapper Not tainted 6.8.0-rc7-mac #1
Stack from 00c81e80:
        00c81e80 0051c8ce 0051c8ce 005875c0 00000000 003ec30a 0051c8ce 00038e26
        005875c0 004f093f 00c4c650 0003025a 005875c0 00c81ec4 00030272 005875c0
        00000000 00c81ed4 00031592 00000000 00c15100 0003df46 0004b6b6 00000000
        00006b1e 00000000 0003dfc0 0000000e 00000000 00000000 00c42608 00000102
        00037462 005ba9b0 005baa0c 00000000 00000000 0003e050 005ba9b0 00000000
        005ba9b0 0003e0a6 005ba9b0 005baa0c 00000000 005ba9b0 005baa0c 00040524
Call Trace: [<003ec30a>] dump_stack+0xc/0x10
 [<00038e26>] do_raw_spin_lock+0x34/0x58
 [<0003025a>] raw_spin_rq_lock_nested+0xe/0x14
 [<00030272>] raw_spin_rq_lock.constprop.0+0x12/0x18
 [<00031592>] scheduler_tick+0x18/0x62
 [<0003df46>] __irq_wake_thread+0x0/0x40
 [<0004b6b6>] update_process_times+0x5e/0x68
 [<00006b1e>] via_timer_handler+0x1a/0x20
 [<0003dfc0>] __handle_irq_event_percpu+0x3a/0xba
 [<00037462>] __prepare_to_swait+0x0/0x26
 [<0003e050>] handle_irq_event_percpu+0x10/0x3a
 [<0003e0a6>] handle_irq_event+0x2c/0x4e
 [<00040524>] handle_simple_irq+0x64/0x68
 [<0002c5c0>] kthreadd+0x0/0xf4
 [<0003db76>] handle_irq_desc+0x1e/0x28
 [<000069be>] via1_irq+0x42/0x80
 [<0002c5c0>] kthreadd+0x0/0xf4
 [<0003db76>] handle_irq_desc+0x1e/0x28
 [<00002798>] do_IRQ+0x20/0x32
 [<00002698>] auto_irqhandler_fixup+0x4/0xc
 [<00037462>] __prepare_to_swait+0x0/0x26
 [<00002530>] ret_from_kernel_thread+0x0/0x14
RCU Tasks Trace: Setting shift to 0 and lim to 1 rcu_task_cb_adjust=1.

---
BUG: spinlock recursion on CPU#0, swapper/2
 lock: 0x573580, .magic: dead4ead, .owner: swapper/2, .owner_cpu: 0
CPU: 0 PID: 2 Comm: swapper Not tainted 6.6.20-mac #1
Stack from 0085be80:
        0085be80 0050972e 0050972e 00573580 00000000 003dc00e 0050972e 000385ce
        00573580 004dddb2 0084c630 0002fca0 00573580 0085bec4 0002fcb8 00573580
        00000000 0085bed4 00030f36 00000000 00815100 0003d35e 0004a990 00000000
        00006b0a 00000000 0003d3d8 0000000e 00000000 00000000 00842608 00000102
        00036c08 005a69b4 005a6a10 00000000 00000000 0003d468 005a69b4 00000000
        005a69b4 0003d4be 005a69b4 005a6a10 00000000 005a69b4 005a6a10 0003f9a4
Call Trace: [<003dc00e>] dump_stack+0xc/0x10
 [<000385ce>] do_raw_spin_lock+0x34/0x58
 [<0002fca0>] raw_spin_rq_lock_nested+0xe/0x14
 [<0002fcb8>] raw_spin_rq_lock.constprop.0+0x12/0x18
 [<00030f36>] scheduler_tick+0x18/0x62
 [<0003d35e>] __irq_wake_thread+0x0/0x40
 [<0004a990>] update_process_times+0x5e/0x66
 [<00006b0a>] via_timer_handler+0x1a/0x20
 [<0003d3d8>] __handle_irq_event_percpu+0x3a/0xba
 [<00036c08>] __prepare_to_swait+0x0/0x26
 [<0003d468>] handle_irq_event_percpu+0x10/0x3a
 [<0003d4be>] handle_irq_event+0x2c/0x4e
 [<0003f9a4>] handle_simple_irq+0x64/0x68
 [<0002c1c8>] kthreadd+0x0/0xf4
 [<0003cf8e>] handle_irq_desc+0x1e/0x28
 [<000069aa>] via1_irq+0x42/0x80
 [<0002c1c8>] kthreadd+0x0/0xf4
 [<0003cf8e>] handle_irq_desc+0x1e/0x28
 [<0000276c>] do_IRQ+0x20/0x32
 [<0000266c>] auto_irqhandler_fixup+0x4/0xc
 [<00036c08>] __prepare_to_swait+0x0/0x26
 [<00002504>] ret_from_kernel_thread+0x0/0x14
RCU Tasks Trace: Setting shift to 0 and lim to 1 rcu_task_cb_adjust=1.

---
BUG: spinlock recursion on CPU#0, swapper/2
 lock: 0x52b8d0, .magic: dead4ead, .owner: swapper/2, .owner_cpu: 0
CPU: 0 PID: 2 Comm: swapper Not tainted 6.1.76-mac #1
Stack from 0082fe5c:
        0082fe5c 004ca084 004ca084 00000000 00000000 003ac8d6 004ca084 00038ec6
        0052b8d0 004a1af1 00810040 0002f7ca 0052b8d0 0082fea0 0002f7e2 0052b8d0
        00000000 0082fed4 00030abe 0082fecc 00000000 00000000 0000000e 003a44ea
        00000000 00000000 00810040 0055ecdc 0005b98e 00563214 0003d82e 0004a7f6
        00000000 00006e9e 00000000 0003d8a8 0000000e 00000000 00000000 00522608
        0000000f 005272c8 0055ecdc 0055ed38 00000000 00000000 0003d938 0055ecdc
Call Trace: [<003ac8d6>] dump_stack+0xc/0x10
 [<00038ec6>] do_raw_spin_lock+0x34/0x58
 [<0002f7ca>] raw_spin_rq_lock_nested+0xe/0x14
 [<0002f7e2>] rq_lock.constprop.0+0x12/0x28
 [<00030abe>] scheduler_tick+0x1c/0x142
 [<003a44ea>] _printk+0x0/0x18
 [<0005b98e>] irq_work_tick+0x20/0x26
 [<0003d82e>] __irq_wake_thread+0x0/0x40
 [<0004a7f6>] update_process_times+0x5e/0x68
 [<00006e9e>] via_timer_handler+0x1a/0x20
 [<0003d8a8>] __handle_irq_event_percpu+0x3a/0xba
 [<0003d938>] handle_irq_event_percpu+0x10/0x3a
 [<0003d98e>] handle_irq_event+0x2c/0x4e
 [<0003fe64>] handle_simple_irq+0x64/0x68
 [<0002bb10>] kthreadd+0x0/0xec
 [<0003d3f2>] handle_irq_desc+0x1e/0x28
 [<00006d3e>] via1_irq+0x42/0x80
 [<0002bb10>] kthreadd+0x0/0xec
 [<0003d3f2>] handle_irq_desc+0x1e/0x28
 [<00002b58>] do_IRQ+0x20/0x32
 [<00002a58>] auto_irqhandler_fixup+0x4/0xc
 [<000028f8>] ret_from_kernel_thread+0x0/0x14
cblist_init_generic: Setting adjustable number of callback queues.






[Index of Archives]     [Video for Linux]     [Yosemite News]     [Linux S/390]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux