Re: Real-Time Preemption and RCU

From: Manfred Spraul
Date: Sun Mar 20 2005 - 11:59:29 EST


Thomas Gleixner wrote:

On Sun, 2005-03-20 at 07:36 +0100, Manfred Spraul wrote:


cpu 1:
acquire random networking spin_lock_bh()

cpu 2:
read_lock(&tasklist_lock) from process context
interrupt. softirq. within softirq: try to acquire the networking lock.
* spins.

cpu 1:
hardware interrupt
within hw interrupt: signal delivery. tries to acquire tasklist_lock.

--> deadlock.



Signal delivery from hw interrupt context (interrupt is flagged
SA_NODELAY) is not possible in RT preemption mode. The
local_irq_save_nort() check in __cache_alloc will catch you.



That was just one random example.
Another one would be :

drivers/chat/tty_io.c, __do_SAK() contains
read_lock(&tasklist_lock);
task_lock(p);

kernel/sys.c, sys_setrlimit contains
task_lock(current->group_leader);
read_lock(&tasklist_lock);

task_lock is a shorthand for spin_lock(&p->alloc_lock). If read_lock is a normal spinlock, then this is an A/B B/A deadlock.

--
Manfred
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/