summaryrefslogtreecommitdiffstats
path: root/xlators/meta/src/measure-file.c
diff options
context:
space:
mode:
authorAnand Avati <avati@redhat.com>2014-05-16 21:31:02 -0700
committerAnand Avati <avati@redhat.com>2014-05-17 11:53:53 -0700
commit98f5f436dd9106819dea8bc6c9a42e03ee1e31be (patch)
tree653676af2f22db83dc3f03fff7947ee3a1aae7de /xlators/meta/src/measure-file.c
parent618d465295df02ae6d53be1327947a210bb8b47d (diff)
downloadglusterfs-98f5f436dd9106819dea8bc6c9a42e03ee1e31be.tar.gz
glusterfs-98f5f436dd9106819dea8bc6c9a42e03ee1e31be.tar.xz
glusterfs-98f5f436dd9106819dea8bc6c9a42e03ee1e31be.zip
meta: add .file_write method into meta_ops
Add .file_write method in meta_ops and make write support into virtual files (like loglevel, measure_latency) much simpler. Change-Id: I812f782f645605c56f81b158bb0f289b3c8f909a BUG: 1089216 Signed-off-by: Anand Avati <avati@redhat.com> Reviewed-on: http://review.gluster.org/7785 Reviewed-by: Krishnan Parthasarathi <kparthas@redhat.com> Reviewed-by: Vijay Bellur <vbellur@redhat.com> Tested-by: Gluster Build System <jenkins@build.gluster.com>
Diffstat (limited to 'xlators/meta/src/measure-file.c')
-rw-r--r--xlators/meta/src/measure-file.c41
1 files changed, 3 insertions, 38 deletions
diff --git a/xlators/meta/src/measure-file.c b/xlators/meta/src/measure-file.c
index ccc78232df..e4498ab092 100644
--- a/xlators/meta/src/measure-file.c
+++ b/xlators/meta/src/measure-file.c
@@ -31,54 +31,19 @@ measure_file_fill (xlator_t *this, inode_t *file, strfd_t *strfd)
static int
-measure_writev (call_frame_t *frame, xlator_t *this, fd_t *fd,
- struct iovec *iov, int count, off_t offset,
- uint32_t flags, struct iobref *iobref, dict_t *xdata)
+measure_file_write (xlator_t *this, fd_t *fd, struct iovec *iov, int count)
{
- struct iatt dummy = { };
long int num = -1;
num = strtol (iov[0].iov_base, NULL, 0);
this->ctx->measure_latency = !!num;
- META_STACK_UNWIND (writev, frame, iov_length (iov, count), 0,
- &dummy, &dummy, xdata);
- return 0;
-}
-
-
-int
-measure_truncate (call_frame_t *frame, xlator_t *this, loc_t *loc,
- off_t offset, dict_t *xdata)
-{
- struct iatt iatt = { };
-
- meta_iatt_fill (&iatt, loc->inode, IA_IFREG);
-
- META_STACK_UNWIND (truncate, frame, 0, 0, &iatt, &iatt, xdata);
- return 0;
-}
-
-
-int
-measure_ftruncate (call_frame_t *frame, xlator_t *this, fd_t *fd,
- off_t offset, dict_t *xdata)
-{
- struct iatt iatt = { };
-
- meta_iatt_fill (&iatt, fd->inode, IA_IFREG);
-
- META_STACK_UNWIND (ftruncate, frame, 0, 0, &iatt, &iatt, xdata);
- return 0;
+ return iov_length (iov, count);
}
static struct meta_ops measure_file_ops = {
.file_fill = measure_file_fill,
- .fops = {
- .truncate = measure_truncate,
- .ftruncate = measure_ftruncate,
- .writev = measure_writev
- }
+ .file_write = measure_file_write,
};