public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] atomic: Only take lock when the counter drops to zero on UP as well
@ 2009-04-10 16:13 Jan Blunck
  2009-04-11 17:49 ` Paul E. McKenney
                   ` (2 more replies)
  0 siblings, 3 replies; 10+ messages in thread
From: Jan Blunck @ 2009-04-10 16:13 UTC (permalink / raw)
  To: Nick Piggin; +Cc: Paul E. McKenney, Linux-Kernel Mailinglist

I think it is wrong to unconditionally take the lock before calling
atomic_dec_and_test() in _atomic_dec_and_lock(). This will deadlock in
situation where it is known that the counter will not reach zero (e.g. holding
another reference to the same object) but the lock is already taken.

Signed-off-by: Jan Blunck <jblunck@suse.de>
---
 lib/dec_and_lock.c |    3 +--
 1 files changed, 1 insertions(+), 2 deletions(-)

diff --git a/lib/dec_and_lock.c b/lib/dec_and_lock.c
index a65c314..e73822a 100644
--- a/lib/dec_and_lock.c
+++ b/lib/dec_and_lock.c
@@ -19,11 +19,10 @@
  */
 int _atomic_dec_and_lock(atomic_t *atomic, spinlock_t *lock)
 {
-#ifdef CONFIG_SMP
 	/* Subtract 1 from counter unless that drops it to 0 (ie. it was 1) */
 	if (atomic_add_unless(atomic, -1, 1))
 		return 0;
-#endif
+
 	/* Otherwise do it the slow way */
 	spin_lock(lock);
 	if (atomic_dec_and_test(atomic))
-- 
1.6.0.2


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

end of thread, other threads:[~2009-04-23 13:32 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-04-10 16:13 [PATCH] atomic: Only take lock when the counter drops to zero on UP as well Jan Blunck
2009-04-11 17:49 ` Paul E. McKenney
2009-04-12 11:32   ` Jan Blunck
2009-04-13  6:02     ` Paul E. McKenney
2009-04-22 12:56       ` Jan Blunck
2009-04-22 14:08         ` Paul E. McKenney
2009-04-14  6:52 ` Nick Piggin
2009-04-14 16:48   ` Paul E. McKenney
2009-04-17 22:14 ` Andrew Morton
2009-04-23 13:32   ` Jan Blunck

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