aboutsummaryrefslogtreecommitdiffstats
path: root/fs/xfs/xfs_iops.c
diff options
context:
space:
mode:
authorMitsuo Hayasaka <mitsuo.hayasaka.hu@hitachi.com>2011-09-17 09:38:38 -0400
committerAlex Elder <aelder@sgi.com>2011-10-11 22:15:02 -0400
commited32201e65e15f3e6955cb84cbb544b08f81e5a5 (patch)
tree208caf358e04fd5ffd1af304f2c78a5f9be22df1 /fs/xfs/xfs_iops.c
parenteabbaf118239d0d4188298b52751040f3b4cc28f (diff)
xfs: Return -EIO when xfs_vn_getattr() failed
An attribute of inode can be fetched via xfs_vn_getattr() in XFS. Currently it returns EIO, not negative value, when it failed. As a result, the system call returns not negative value even though an error occured. The stat(2), ls and mv commands cannot handle this error and do not work correctly. This patch fixes this bug, and returns -EIO, not EIO when an error is detected in xfs_vn_getattr(). Signed-off-by: Mitsuo Hayasaka <mitsuo.hayasaka.hu@hitachi.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Alex Elder <aelder@sgi.com>
Diffstat (limited to 'fs/xfs/xfs_iops.c')
-rw-r--r--fs/xfs/xfs_iops.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/xfs/xfs_iops.c b/fs/xfs/xfs_iops.c
index e041e917c1d..e6b3e762088 100644
--- a/fs/xfs/xfs_iops.c
+++ b/fs/xfs/xfs_iops.c
@@ -465,7 +465,7 @@ xfs_vn_getattr(
465 trace_xfs_getattr(ip); 465 trace_xfs_getattr(ip);
466 466
467 if (XFS_FORCED_SHUTDOWN(mp)) 467 if (XFS_FORCED_SHUTDOWN(mp))
468 return XFS_ERROR(EIO); 468 return -XFS_ERROR(EIO);
469 469
470 stat->size = XFS_ISIZE(ip); 470 stat->size = XFS_ISIZE(ip);
471 stat->dev = inode->i_sb->s_dev; 471 stat->dev = inode->i_sb->s_dev;