Signed-off-by: Erez Zadok <ezk@xxxxxxxxxxxxx> --- fs/unionfs/rdstate.c | 15 ++++++++------- 1 files changed, 8 insertions(+), 7 deletions(-) diff --git a/fs/unionfs/rdstate.c b/fs/unionfs/rdstate.c index 0a18d5c..7ec7f95 100644 --- a/fs/unionfs/rdstate.c +++ b/fs/unionfs/rdstate.c @@ -45,7 +45,7 @@ int unionfs_init_filldir_cache(void) void unionfs_destroy_filldir_cache(void) { - if (unionfs_filldir_cachep) + if (likely(unionfs_filldir_cachep)) kmem_cache_destroy(unionfs_filldir_cachep); } @@ -72,7 +72,8 @@ static int guesstimate_hash_size(struct inode *inode) return UNIONFS_I(inode)->hashsize; for (bindex = ibstart(inode); bindex <= ibend(inode); bindex++) { - if (!(lower_inode = unionfs_lower_inode_idx(inode, bindex))) + lower_inode = unionfs_lower_inode_idx(inode, bindex); + if (unlikely(!lower_inode)) continue; if (lower_inode->i_size == DENTPAGE) @@ -136,7 +137,7 @@ struct unionfs_dir_state *alloc_rdstate(struct inode *inode, int bindex) sizeof(struct list_head); rdstate = kmalloc(mallocsize, GFP_KERNEL); - if (!rdstate) + if (unlikely(!rdstate)) return NULL; spin_lock(&UNIONFS_I(inode)->rdlock); @@ -217,7 +218,7 @@ struct filldir_node *find_filldir_node(struct unionfs_dir_state *rdstate, * if the duplicate is in this branch, then the file * system is corrupted. */ - if (cursor->bindex == rdstate->bindex) { + if (unlikely(cursor->bindex == rdstate->bindex)) { printk(KERN_DEBUG "unionfs: filldir: possible " "I/O error: a file is duplicated " "in the same branch %d: %s\n", @@ -227,7 +228,7 @@ struct filldir_node *find_filldir_node(struct unionfs_dir_state *rdstate, } } - if (!found) + if (unlikely(!found)) cursor = NULL; return cursor; @@ -249,7 +250,7 @@ int add_filldir_node(struct unionfs_dir_state *rdstate, const char *name, head = &(rdstate->list[index]); new = kmem_cache_alloc(unionfs_filldir_cachep, GFP_KERNEL); - if (!new) { + if (unlikely(!new)) { err = -ENOMEM; goto out; } @@ -264,7 +265,7 @@ int add_filldir_node(struct unionfs_dir_state *rdstate, const char *name, new->name = new->iname; else { new->name = kmalloc(namelen + 1, GFP_KERNEL); - if (!new->name) { + if (unlikely(!new->name)) { kmem_cache_free(unionfs_filldir_cachep, new); new = NULL; goto out; -- 1.5.2.2 - To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html