From: Trond Myklebust Date: Tue, 28 Oct 2008 19:21:42 +0000 (-0400) Subject: SUNRPC: Fix potential race in put_rpccred() X-Git-Tag: v2.6.28-rc3~38^2 X-Git-Url: http://pilppa.com/gitweb/?a=commitdiff_plain;h=5f707eb429e2c98dfd564ffbbd9f536bf493d869;p=linux-2.6-omap-h63xx.git SUNRPC: Fix potential race in put_rpccred() We have to be careful when we try to unhash the credential in put_rpccred(), because we're not holding the credcache lock, so the call to rpcauth_unhash_cred() may fail if someone else has looked the cred up, and obtained a reference to it. Signed-off-by: Trond Myklebust --- diff --git a/net/sunrpc/auth.c b/net/sunrpc/auth.c index a045a1253d4..cb216b2df66 100644 --- a/net/sunrpc/auth.c +++ b/net/sunrpc/auth.c @@ -455,7 +455,7 @@ need_lock: } if (test_bit(RPCAUTH_CRED_UPTODATE, &cred->cr_flags) == 0) rpcauth_unhash_cred(cred); - else if (test_bit(RPCAUTH_CRED_HASHED, &cred->cr_flags) != 0) { + if (test_bit(RPCAUTH_CRED_HASHED, &cred->cr_flags) != 0) { cred->cr_expire = jiffies; list_add_tail(&cred->cr_lru, &cred_unused); number_cred_unused++;