SUNRPC: Store the hashtable size in struct rpc_cred_cache
Trond Myklebust [Sat, 31 Jul 2010 18:29:07 +0000 (14:29 -0400)]
Cleanup in preparation for allowing the user to determine the maximum hash
table size.

Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>

include/linux/sunrpc/auth.h
net/sunrpc/auth.c

index 784e78c..84d64b6 100644 (file)
@@ -65,6 +65,7 @@ struct rpc_cred {
 #define RPC_CREDCACHE_NR       (1 << RPC_CREDCACHE_HASHBITS)
 struct rpc_cred_cache {
        struct hlist_head       hashtable[RPC_CREDCACHE_NR];
+       unsigned int            hashbits;
        spinlock_t              lock;
 };
 
index db13554..eef76a1 100644 (file)
@@ -145,12 +145,15 @@ int
 rpcauth_init_credcache(struct rpc_auth *auth)
 {
        struct rpc_cred_cache *new;
+       unsigned int hashsize;
        int i;
 
        new = kmalloc(sizeof(*new), GFP_KERNEL);
        if (!new)
                return -ENOMEM;
-       for (i = 0; i < RPC_CREDCACHE_NR; i++)
+       new->hashbits = RPC_CREDCACHE_HASHBITS;
+       hashsize = 1U << new->hashbits;
+       for (i = 0; i < hashsize; i++)
                INIT_HLIST_HEAD(&new->hashtable[i]);
        spin_lock_init(&new->lock);
        auth->au_credcache = new;
@@ -183,11 +186,12 @@ rpcauth_clear_credcache(struct rpc_cred_cache *cache)
        LIST_HEAD(free);
        struct hlist_head *head;
        struct rpc_cred *cred;
+       unsigned int hashsize = 1U << cache->hashbits;
        int             i;
 
        spin_lock(&rpc_credcache_lock);
        spin_lock(&cache->lock);
-       for (i = 0; i < RPC_CREDCACHE_NR; i++) {
+       for (i = 0; i < hashsize; i++) {
                head = &cache->hashtable[i];
                while (!hlist_empty(head)) {
                        cred = hlist_entry(head->first, struct rpc_cred, cr_hash);
@@ -297,7 +301,7 @@ rpcauth_lookup_credcache(struct rpc_auth *auth, struct auth_cred * acred,
                        *entry, *new;
        unsigned int nr;
 
-       nr = hash_long(acred->uid, RPC_CREDCACHE_HASHBITS);
+       nr = hash_long(acred->uid, cache->hashbits);
 
        rcu_read_lock();
        hlist_for_each_entry_rcu(entry, pos, &cache->hashtable[nr], cr_hash) {