aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoseph Qi <joseph.qi@huawei.com>2013-09-11 17:19:55 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2013-09-11 18:56:45 -0400
commit17caf9555edc27a0c6df512de0879b357ebacae4 (patch)
tree35bca650e011d3b9e6349140666a1f07422b937e
parent4704aa30fc35010dd9c3ce1d9d2e77af09c2c081 (diff)
ocfs2: add the missing return value check of ocfs2_xattr_get_clusters
In ocfs2_xattr_value_attach_refcount(), if error occurs when calling ocfs2_xattr_get_clusters(), it will go with unexpected behavior since local variables p_cluster, num_clusters and ext_flags are declared without initialization. Signed-off-by: Joseph Qi <joseph.qi@huawei.com> Cc: Joel Becker <jlbec@evilplan.org> Cc: Mark Fasheh <mfasheh@suse.com> Acked-by: Jie Liu <jeff.liu@oracle.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r--fs/ocfs2/xattr.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/fs/ocfs2/xattr.c b/fs/ocfs2/xattr.c
index 317ef0abccbb..1cbc2231a9f2 100644
--- a/fs/ocfs2/xattr.c
+++ b/fs/ocfs2/xattr.c
@@ -5881,6 +5881,10 @@ static int ocfs2_xattr_value_attach_refcount(struct inode *inode,
5881 while (cpos < clusters) { 5881 while (cpos < clusters) {
5882 ret = ocfs2_xattr_get_clusters(inode, cpos, &p_cluster, 5882 ret = ocfs2_xattr_get_clusters(inode, cpos, &p_cluster,
5883 &num_clusters, el, &ext_flags); 5883 &num_clusters, el, &ext_flags);
5884 if (ret) {
5885 mlog_errno(ret);
5886 break;
5887 }
5884 5888
5885 cpos += num_clusters; 5889 cpos += num_clusters;
5886 if ((ext_flags & OCFS2_EXT_REFCOUNTED)) 5890 if ((ext_flags & OCFS2_EXT_REFCOUNTED))