diff options
author | Joseph Qi <joseph.qi@huawei.com> | 2013-09-11 17:19:55 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-09-11 18:56:45 -0400 |
commit | 17caf9555edc27a0c6df512de0879b357ebacae4 (patch) | |
tree | 35bca650e011d3b9e6349140666a1f07422b937e | |
parent | 4704aa30fc35010dd9c3ce1d9d2e77af09c2c081 (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.c | 4 |
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)) |