diff options
| -rw-r--r-- | xlators/meta/src/loglevel-file.c | 40 | ||||
| -rw-r--r-- | xlators/meta/src/measure-file.c | 41 | ||||
| -rw-r--r-- | xlators/meta/src/meta-defaults.c | 33 | ||||
| -rw-r--r-- | xlators/meta/src/meta.h | 1 | 
4 files changed, 38 insertions, 77 deletions
diff --git a/xlators/meta/src/loglevel-file.c b/xlators/meta/src/loglevel-file.c index 24ac68ddc69..6b00d123a2c 100644 --- a/xlators/meta/src/loglevel-file.c +++ b/xlators/meta/src/loglevel-file.c @@ -31,55 +31,21 @@ loglevel_file_fill (xlator_t *this, inode_t *file, strfd_t *strfd)  static int -loglevel_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) +loglevel_file_write (xlator_t *this, fd_t *fd, struct iovec *iov, int count)  { -	struct iatt dummy = { };  	long int level = -1;  	level = strtol (iov[0].iov_base, NULL, 0);  	if (level >= GF_LOG_NONE && level <= GF_LOG_TRACE)  		gf_log_set_loglevel (level); -	META_STACK_UNWIND (writev, frame, iov_length (iov, count), 0, -			   &dummy, &dummy, xdata); -	return 0; -} - - -int -loglevel_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; +	return iov_length (iov, count);  } -int -loglevel_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; -} -  static struct meta_ops loglevel_file_ops = {  	.file_fill = loglevel_file_fill, -	.fops = { -		.truncate = loglevel_truncate, -		.ftruncate = loglevel_ftruncate, -		.writev = loglevel_writev -	} +	.file_write = loglevel_file_write,  }; diff --git a/xlators/meta/src/measure-file.c b/xlators/meta/src/measure-file.c index ccc78232dfe..e4498ab092e 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,  }; diff --git a/xlators/meta/src/meta-defaults.c b/xlators/meta/src/meta-defaults.c index 905b38554a0..76244c7ee01 100644 --- a/xlators/meta/src/meta-defaults.c +++ b/xlators/meta/src/meta-defaults.c @@ -96,6 +96,23 @@ meta_default_writev (call_frame_t *frame, xlator_t *this, fd_t *fd,  		     struct iovec *vector, int32_t count, off_t off,  		     uint32_t flags, struct iobref *iobref, dict_t *xdata)  { +	struct meta_ops *ops = NULL; +	int ret = 0; +	struct iatt dummy = { }; + +	ops = meta_ops_get (fd->inode, this); +	if (!ops) +		goto err; + +	if (!ops->file_write) +		goto err; + +	ret = ops->file_write (this, fd, vector, count); + +	META_STACK_UNWIND (writev, frame, (ret >= 0 ? : -1), (ret < 0 ? -ret : 0), +			   &dummy, &dummy, xdata); +	return 0; +err:          return default_writev_failure_cbk (frame, EPERM);  } @@ -266,7 +283,13 @@ int  meta_default_ftruncate (call_frame_t *frame, xlator_t *this, fd_t *fd,  			off_t offset, dict_t *xdata)  { -        return default_ftruncate_failure_cbk (frame, EPERM); +	struct iatt iatt = { }; + +	meta_iatt_fill (&iatt, fd->inode, IA_IFREG); + +	META_STACK_UNWIND (ftruncate, frame, 0, 0, &iatt, &iatt, xdata); + +        return 0;  }  int @@ -458,7 +481,13 @@ int  meta_default_truncate (call_frame_t *frame, xlator_t *this, loc_t *loc,  		       off_t offset, dict_t *xdata)  { -        return default_truncate_failure_cbk (frame, EPERM); +	struct iatt iatt = { }; + +	meta_iatt_fill (&iatt, loc->inode, IA_IFREG); + +	META_STACK_UNWIND (truncate, frame, 0, 0, &iatt, &iatt, xdata); + +        return 0;  }  int diff --git a/xlators/meta/src/meta.h b/xlators/meta/src/meta.h index f6ec8cb9cb7..652ebd7321c 100644 --- a/xlators/meta/src/meta.h +++ b/xlators/meta/src/meta.h @@ -47,6 +47,7 @@ struct meta_ops {  	int (*file_fill) (xlator_t *this, inode_t *file, strfd_t *strfd);  	int (*iatt_fill) (xlator_t *this, inode_t *inode, struct iatt *iatt);  	int (*link_fill) (xlator_t *this, inode_t *inode, strfd_t *strfd); +	int (*file_write) (xlator_t *this, fd_t *fd, struct iovec *iov, int count);  	struct xlator_fops fops;  	struct xlator_cbks cbks;  };  | 
