public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* Lock ordering, inquiring minds want to know.
@ 2000-12-07 23:07 george anzinger
  2000-12-08  1:53 ` Mike Kravetz
  0 siblings, 1 reply; 3+ messages in thread
From: george anzinger @ 2000-12-07 23:07 UTC (permalink / raw)
  To: linux-kernel@vger.redhat.com, Andrew Morton

In looking over sched.c I find:

	spin_lock_irq(&runqueue_lock);
	read_lock(&tasklist_lock);


This seems to me to be the wrong order of things.  The read lock
unavailable (some one holds a write lock) for relatively long periods of
time, for example, wait holds it in a while loop.  On the other hand the
runqueue_lock, being a "irq" lock will always be held for short periods
of time.  It would seem better to wait for the runqueue lock while
holding the read_lock with the interrupts on than to wait for the
read_lock with interrupts off.  As near as I can tell this is the only
place in the system that both of these locks are held (of course, all
cases of two locks being held at the same time, both locker must use the
same order).  So...


What am I missing here? 

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

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2000-12-08 22:55 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2000-12-07 23:07 Lock ordering, inquiring minds want to know george anzinger
2000-12-08  1:53 ` Mike Kravetz
2000-12-08 21:53   ` george anzinger

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox