Commit 12bf6fbc authored by Arnd Bergmann's avatar Arnd Bergmann Committed by Greg Kroah-Hartman

gfs2: remove IS_ERR_VALUE abuse

Picked from commit 287980e4 ("remove lots
of IS_ERR_VALUE abuses") upstream.

The original fix that was backported to 3.18 already addressed the warning
in some configurations, but not in others, leaving us with the same output:

../fs/gfs2/dir.c: In function 'get_first_leaf':
../fs/gfs2/dir.c:768:9: warning: 'leaf_no' may be used uninitialized in this function [-Wmaybe-uninitialized]
   error = get_leaf(dip, leaf_no, bh_out);
         ^
../fs/gfs2/dir.c: In function 'dir_split_leaf.isra.20':
../fs/gfs2/dir.c:987:8: warning: 'leaf_no' may be used uninitialized in this function [-Wmaybe-uninitialized]

This takes the approach that we took in later versions in mainline,
but does not backport the entire patch, as that would be too large
for stable and IIRC caused regressions in other drivers.

Fixes: 9d46d31e ("gfs2: avoid uninitialized variable warning")
Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 8d86ef0c
...@@ -749,12 +749,15 @@ static int get_leaf_nr(struct gfs2_inode *dip, u32 index, ...@@ -749,12 +749,15 @@ static int get_leaf_nr(struct gfs2_inode *dip, u32 index,
u64 *leaf_out) u64 *leaf_out)
{ {
__be64 *hash; __be64 *hash;
int error;
hash = gfs2_dir_get_hash_table(dip); hash = gfs2_dir_get_hash_table(dip);
if (IS_ERR(hash)) error = PTR_ERR_OR_ZERO(hash);
return PTR_ERR(hash);
if (!error)
*leaf_out = be64_to_cpu(*(hash + index)); *leaf_out = be64_to_cpu(*(hash + index));
return 0;
return error;
} }
static int get_first_leaf(struct gfs2_inode *dip, u32 index, static int get_first_leaf(struct gfs2_inode *dip, u32 index,
...@@ -764,7 +767,7 @@ static int get_first_leaf(struct gfs2_inode *dip, u32 index, ...@@ -764,7 +767,7 @@ static int get_first_leaf(struct gfs2_inode *dip, u32 index,
int error; int error;
error = get_leaf_nr(dip, index, &leaf_no); error = get_leaf_nr(dip, index, &leaf_no);
if (!IS_ERR_VALUE(error)) if (!error)
error = get_leaf(dip, leaf_no, bh_out); error = get_leaf(dip, leaf_no, bh_out);
return error; return error;
...@@ -980,7 +983,7 @@ static int dir_split_leaf(struct inode *inode, const struct qstr *name) ...@@ -980,7 +983,7 @@ static int dir_split_leaf(struct inode *inode, const struct qstr *name)
index = name->hash >> (32 - dip->i_depth); index = name->hash >> (32 - dip->i_depth);
error = get_leaf_nr(dip, index, &leaf_no); error = get_leaf_nr(dip, index, &leaf_no);
if (IS_ERR_VALUE(error)) if (error)
return error; return error;
/* Get the old leaf block */ /* Get the old leaf block */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment