| To: | Alex Elder <aelder@xxxxxxx>, Christoph Hellwig <hch@xxxxxxxxxxxxx> |
|---|---|
| Subject: | [PATCH] Return -EIO when xfs_vn_getattr() failed |
| From: | Mitsuo Hayasaka <mitsuo.hayasaka.hu@xxxxxxxxxxx> |
| Date: | Sat, 17 Sep 2011 22:38:38 +0900 |
| Cc: | xfs-masters@xxxxxxxxxxx, xfs@xxxxxxxxxxx, linux-kernel@xxxxxxxxxxxxxxx, yrl.pp-manager.tt@xxxxxxxxxxx, Mitsuo Hayasaka <mitsuo.hayasaka.hu@xxxxxxxxxxx>, Alex Elder <aelder@xxxxxxx>, Christoph Hellwig <hch@xxxxxxxxxxxxx> |
| User-agent: | StGIT/0.14.3 |
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@xxxxxxxxxxx>
Cc: Alex Elder <aelder@xxxxxxx>
Cc: Christoph Hellwig <hch@xxxxxxxxxxxxx>
---
fs/xfs/xfs_iops.c | 2 +-
1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/fs/xfs/xfs_iops.c b/fs/xfs/xfs_iops.c
index b9c172b..33136d6 100644
--- a/fs/xfs/xfs_iops.c
+++ b/fs/xfs/xfs_iops.c
@@ -457,7 +457,7 @@ xfs_vn_getattr(
trace_xfs_getattr(ip);
if (XFS_FORCED_SHUTDOWN(mp))
- return XFS_ERROR(EIO);
+ return -XFS_ERROR(EIO);
stat->size = XFS_ISIZE(ip);
stat->dev = inode->i_sb->s_dev;
|
| <Prev in Thread] | Current Thread | [Next in Thread> |
|---|---|---|
| ||
| Previous by Date: | Re: Stalls during writeback for mmaped I/O on XFS in 3.0, Shawn Bohrer |
|---|---|
| Next by Date: | Re: xfs deadlock in stable kernel 3.0.4, Stefan Priebe - Profihost AG |
| Previous by Thread: | Stalls during writeback for mmaped I/O on XFS in 3.0, Shawn Bohrer |
| Next by Thread: | Re: [PATCH] Return -EIO when xfs_vn_getattr() failed, Christoph Hellwig |
| Indexes: | [Date] [Thread] [Top] [All Lists] |