From: Ingo Molnar Date: Fri, 13 Mar 2009 09:32:07 +0000 (+0100) Subject: futex: remove the pointer math from double_unlock_hb, fix X-Git-Tag: 2.1b_release~13698^2~1 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=88f502fedba82eff252b6420e8b8328e4ae25c67;p=platform%2Fkernel%2Fkernel-mfld-blackbay.git futex: remove the pointer math from double_unlock_hb, fix Impact: fix double unlock crash Thomas Gleixner noticed that the simplified double_unlock_hb() became ... too unsophisticated: in the hb1 == hb2 case it will do a double unlock. Reported-by: Thomas Gleixner Cc: Darren Hart LKML-Reference: <20090312221118.11146.68610.stgit@Aeon> Signed-off-by: Ingo Molnar --- diff --git a/kernel/futex.c b/kernel/futex.c index 2331b73..6b50a02 100644 --- a/kernel/futex.c +++ b/kernel/futex.c @@ -659,7 +659,8 @@ static inline void double_unlock_hb(struct futex_hash_bucket *hb1, struct futex_hash_bucket *hb2) { spin_unlock(&hb1->lock); - spin_unlock(&hb2->lock); + if (hb1 != hb2) + spin_unlock(&hb2->lock); } /*