diff options
| author | Rajesh Joseph <rjoseph@redhat.com> | 2015-02-17 06:55:22 +0530 | 
|---|---|---|
| committer | Krishnan Parthasarathi <kparthas@redhat.com> | 2015-02-20 08:04:47 -0800 | 
| commit | 2b821b114836901bf1e661fc6c4e212298c9768d (patch) | |
| tree | afa60f8a2a864a03ff245828c4069a5cca7e2d68 | |
| parent | df9f1cd96854c82338c62897d788319b560e43ad (diff) | |
gfapi: handle inode_link failures gracefully
Bug: 1193757
Change-Id: I73bfb91a6a73ad4f06e8828d2d7efd34d9873888
Signed-off-by: Rajesh Joseph <rjoseph@redhat.com>
Reviewed-on: http://review.gluster.org/9671
Reviewed-by: Niels de Vos <ndevos@redhat.com>
Tested-by: Gluster Build System <jenkins@build.gluster.com>
Reviewed-by: Krishnan Parthasarathi <kparthas@redhat.com>
Tested-by: Krishnan Parthasarathi <kparthas@redhat.com>
| -rw-r--r-- | api/src/glfs-resolve.c | 10 | 
1 files changed, 9 insertions, 1 deletions
| diff --git a/api/src/glfs-resolve.c b/api/src/glfs-resolve.c index 5efe91b8d5b..9aeac57b75e 100644 --- a/api/src/glfs-resolve.c +++ b/api/src/glfs-resolve.c @@ -402,8 +402,10 @@ priv_glfs_resolve_at (struct glfs *fs, xlator_t *subvol, inode_t *at,  						*/  						(reval || (!next_component &&  						iatt))); -		if (!inode) +		if (!inode) { +                        ret = -1;  			break; +                }  		if (IA_ISLNK (ciatt.ia_type) && (next_component || follow)) {  			/* If the component is not the last piece, @@ -509,12 +511,18 @@ glfs_resolve_path (struct glfs *fs, xlator_t *subvol, const char *origpath,                                               iatt, follow, reval);  	cwd = glfs_cwd_get (fs); +        if (NULL == cwd) { +                gf_log (subvol->name, GF_LOG_WARNING, "Failed to get cwd"); +                errno = EIO; +                goto out; +        }  	ret = priv_glfs_resolve_at (fs, subvol, cwd, origpath, loc, iatt,                                      follow, reval);  	if (cwd)  		inode_unref (cwd); +out:  	return ret;  } | 
