Skip to content

Commit

Permalink
[PATCH] nfsd: replace kmalloc+memset with kcalloc + simplify NULL check
Browse files Browse the repository at this point in the history
Replace kmalloc+memset with kcalloc and simplify

Signed-off-by: Yan Burman <[email protected]>
Cc: Neil Brown <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
  • Loading branch information
yanburman authored and Linus Torvalds committed Dec 8, 2006
1 parent 14d2b59 commit 4b3bb06
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 21 deletions.
3 changes: 1 addition & 2 deletions fs/nfsd/nfscache.c
Original file line number Diff line number Diff line change
Expand Up @@ -66,14 +66,13 @@ nfsd_cache_init(void)
printk (KERN_ERR "nfsd: cannot allocate all %d cache entries, only got %d\n",
CACHESIZE, CACHESIZE-i);

hash_list = kmalloc (HASHSIZE * sizeof(struct hlist_head), GFP_KERNEL);
hash_list = kcalloc (HASHSIZE, sizeof(struct hlist_head), GFP_KERNEL);
if (!hash_list) {
nfsd_cache_shutdown();
printk (KERN_ERR "nfsd: cannot allocate %Zd bytes for hash list\n",
HASHSIZE * sizeof(struct hlist_head));
return;
}
memset(hash_list, 0, HASHSIZE * sizeof(struct hlist_head));

cache_disabled = 0;
}
Expand Down
37 changes: 18 additions & 19 deletions fs/nfsd/vfs.c
Original file line number Diff line number Diff line change
Expand Up @@ -1885,28 +1885,27 @@ nfsd_racache_init(int cache_size)
return 0;
if (cache_size < 2*RAPARM_HASH_SIZE)
cache_size = 2*RAPARM_HASH_SIZE;
raparml = kmalloc(sizeof(struct raparms) * cache_size, GFP_KERNEL);

if (raparml != NULL) {
dprintk("nfsd: allocating %d readahead buffers.\n",
cache_size);
for (i = 0 ; i < RAPARM_HASH_SIZE ; i++) {
raparm_hash[i].pb_head = NULL;
spin_lock_init(&raparm_hash[i].pb_lock);
}
nperbucket = cache_size >> RAPARM_HASH_BITS;
memset(raparml, 0, sizeof(struct raparms) * cache_size);
for (i = 0; i < cache_size - 1; i++) {
if (i % nperbucket == 0)
raparm_hash[j++].pb_head = raparml + i;
if (i % nperbucket < nperbucket-1)
raparml[i].p_next = raparml + i + 1;
}
} else {
raparml = kcalloc(cache_size, sizeof(struct raparms), GFP_KERNEL);

if (!raparml) {
printk(KERN_WARNING
"nfsd: Could not allocate memory read-ahead cache.\n");
"nfsd: Could not allocate memory read-ahead cache.\n");
return -ENOMEM;
}

dprintk("nfsd: allocating %d readahead buffers.\n", cache_size);
for (i = 0 ; i < RAPARM_HASH_SIZE ; i++) {
raparm_hash[i].pb_head = NULL;
spin_lock_init(&raparm_hash[i].pb_lock);
}
nperbucket = cache_size >> RAPARM_HASH_BITS;
for (i = 0; i < cache_size - 1; i++) {
if (i % nperbucket == 0)
raparm_hash[j++].pb_head = raparml + i;
if (i % nperbucket < nperbucket-1)
raparml[i].p_next = raparml + i + 1;
}

nfsdstats.ra_size = cache_size;
return 0;
}
Expand Down

0 comments on commit 4b3bb06

Please sign in to comment.