summaryrefslogtreecommitdiffstats
path: root/api
diff options
context:
space:
mode:
authorAtin Mukherjee <amukherj@redhat.com>2014-06-06 12:51:57 +0530
committerAnand Avati <avati@redhat.com>2014-07-28 23:35:17 -0700
commit67a6f402d4a4af2e7d9b8d80b25c94f1a08ef029 (patch)
tree1b5f398bf404c851a3989295ad64d7438e1e6228 /api
parenta95444c95cfde4d80c179f2af2f0334565049a51 (diff)
libgfapi : glfs_create()/glfs_h_creat()/glfs_open()/glfs_h_open() should set
fd->flags before syncop_open() glfs_create() and glfs_open() do not set fd->flags before calling syncop_open(). This patch addresses this problem and ensure the flags are set in fd before invoking syncop_open() Change-Id: I9ef3243b1de610e1dd1a3e37b66fc2f763a865f9 BUG: 1096047 Signed-off-by: Atin Mukherjee <amukherj@redhat.com> Reviewed-on: http://review.gluster.org/7999 Tested-by: Gluster Build System <jenkins@build.gluster.com> Reviewed-by: Krishnan Parthasarathi <kparthas@redhat.com> Reviewed-by: Humble Devassy Chirammal <humble.devassy@gmail.com> Reviewed-by: Anand Avati <avati@redhat.com>
Diffstat (limited to 'api')
-rw-r--r--api/src/glfs-fops.c4
-rw-r--r--api/src/glfs-handleops.c3
2 files changed, 4 insertions, 3 deletions
diff --git a/api/src/glfs-fops.c b/api/src/glfs-fops.c
index bc9c758a9c9..a5ab8e43961 100644
--- a/api/src/glfs-fops.c
+++ b/api/src/glfs-fops.c
@@ -124,6 +124,7 @@ retry:
errno = ENOMEM;
goto out;
}
+ glfd->fd->flags = flags;
ret = syncop_open (subvol, &loc, flags, glfd->fd);
DECODE_SYNCOP_ERR (ret);
@@ -136,7 +137,6 @@ out:
glfs_fd_destroy (glfd);
glfd = NULL;
} else if (glfd) {
- glfd->fd->flags = flags;
fd_bind (glfd->fd);
glfs_fd_bind (glfd);
}
@@ -394,6 +394,7 @@ retry:
errno = ENOMEM;
goto out;
}
+ glfd->fd->flags = flags;
if (ret == 0) {
ret = syncop_open (subvol, &loc, flags, glfd->fd);
@@ -418,7 +419,6 @@ out:
glfs_fd_destroy (glfd);
glfd = NULL;
} else if (glfd) {
- glfd->fd->flags = flags;
fd_bind (glfd->fd);
glfs_fd_bind (glfd);
}
diff --git a/api/src/glfs-handleops.c b/api/src/glfs-handleops.c
index ba468382077..0188128f712 100644
--- a/api/src/glfs-handleops.c
+++ b/api/src/glfs-handleops.c
@@ -500,6 +500,7 @@ glfs_h_open (struct glfs *fs, struct glfs_object *object, int flags)
errno = ENOMEM;
goto out;
}
+ glfd->fd->flags = flags;
/* populate loc */
GLFS_LOC_FILL_INODE (inode, loc, out);
@@ -518,7 +519,6 @@ out:
glfs_fd_destroy (glfd);
glfd = NULL;
} else {
- glfd->fd->flags = flags;
fd_bind (glfd->fd);
glfs_fd_bind (glfd);
}
@@ -592,6 +592,7 @@ glfs_h_creat (struct glfs *fs, struct glfs_object *parent, const char *path,
errno = ENOMEM;
goto out;
}
+ glfd->fd->flags = flags;
/* fop/op */
ret = syncop_create (subvol, &loc, flags, mode, glfd->fd,