|
|
d1681e |
From e1e80bc293f5a84087d5a35054cd8bc0abfa4836 Mon Sep 17 00:00:00 2001
|
|
|
d1681e |
From: Pranith Kumar K <pkarampu@redhat.com>
|
|
|
d1681e |
Date: Wed, 13 Jun 2018 12:17:28 +0530
|
|
|
d1681e |
Subject: [PATCH 302/305] storage/posix: Handle ENOSPC correctly in zero_fill
|
|
|
d1681e |
|
|
|
d1681e |
Upstream patch: https://review.gluster.org/20254
|
|
|
d1681e |
|
|
|
d1681e |
BUG: 1594658
|
|
|
d1681e |
Change-Id: Icc521d86cc510f88b67d334b346095713899087a
|
|
|
d1681e |
Signed-off-by: Pranith Kumar K <pkarampu@redhat.com>
|
|
|
d1681e |
Reviewed-on: https://code.engineering.redhat.com/gerrit/142311
|
|
|
d1681e |
Tested-by: RHGS Build Bot <nigelb@redhat.com>
|
|
|
d1681e |
Reviewed-by: Sunil Kumar Heggodu Gopala Acharya <sheggodu@redhat.com>
|
|
|
d1681e |
---
|
|
|
d1681e |
tests/basic/posix/zero-fill-enospace.c | 64 ++++++++++++++++++++++++++++++++++
|
|
|
d1681e |
tests/basic/posix/zero-fill-enospace.t | 35 +++++++++++++++++++
|
|
|
d1681e |
xlators/storage/posix/src/posix.c | 23 +++++++++++-
|
|
|
d1681e |
3 files changed, 121 insertions(+), 1 deletion(-)
|
|
|
d1681e |
create mode 100644 tests/basic/posix/zero-fill-enospace.c
|
|
|
d1681e |
create mode 100644 tests/basic/posix/zero-fill-enospace.t
|
|
|
d1681e |
|
|
|
d1681e |
diff --git a/tests/basic/posix/zero-fill-enospace.c b/tests/basic/posix/zero-fill-enospace.c
|
|
|
d1681e |
new file mode 100644
|
|
|
d1681e |
index 0000000..b1aaa57
|
|
|
d1681e |
--- /dev/null
|
|
|
d1681e |
+++ b/tests/basic/posix/zero-fill-enospace.c
|
|
|
d1681e |
@@ -0,0 +1,64 @@
|
|
|
d1681e |
+#include <stdio.h>
|
|
|
d1681e |
+#include <glusterfs/api/glfs.h>
|
|
|
d1681e |
+#include <glusterfs/api/glfs-handles.h>
|
|
|
d1681e |
+
|
|
|
d1681e |
+int
|
|
|
d1681e |
+main (int argc, char *argv[])
|
|
|
d1681e |
+{
|
|
|
d1681e |
+ glfs_t *fs = NULL;
|
|
|
d1681e |
+ glfs_fd_t *fd = NULL;
|
|
|
d1681e |
+ int ret = 1;
|
|
|
d1681e |
+ int size = 0;
|
|
|
d1681e |
+
|
|
|
d1681e |
+ if (argc != 6) {
|
|
|
d1681e |
+ fprintf (stderr, "Syntax: %s <host> <volname> <file-path> <log-file> <size>\n", argv[0]);
|
|
|
d1681e |
+ return 1;
|
|
|
d1681e |
+ }
|
|
|
d1681e |
+
|
|
|
d1681e |
+ fs = glfs_new (argv[2]);
|
|
|
d1681e |
+ if (!fs) {
|
|
|
d1681e |
+ fprintf (stderr, "glfs_new: returned NULL\n");
|
|
|
d1681e |
+ return 1;
|
|
|
d1681e |
+ }
|
|
|
d1681e |
+
|
|
|
d1681e |
+ ret = glfs_set_volfile_server (fs, "tcp", argv[1], 24007);
|
|
|
d1681e |
+ if (ret != 0) {
|
|
|
d1681e |
+ fprintf (stderr, "glfs_set_volfile_server: retuned %d\n", ret);
|
|
|
d1681e |
+ goto out;
|
|
|
d1681e |
+ }
|
|
|
d1681e |
+ ret = glfs_set_logging (fs, argv[4], 7);
|
|
|
d1681e |
+ if (ret != 0) {
|
|
|
d1681e |
+ fprintf (stderr, "glfs_set_logging: returned %d\n", ret);
|
|
|
d1681e |
+ goto out;
|
|
|
d1681e |
+ }
|
|
|
d1681e |
+ ret = glfs_init (fs);
|
|
|
d1681e |
+ if (ret != 0) {
|
|
|
d1681e |
+ fprintf (stderr, "glfs_init: returned %d\n", ret);
|
|
|
d1681e |
+ goto out;
|
|
|
d1681e |
+ }
|
|
|
d1681e |
+
|
|
|
d1681e |
+ fd = glfs_open (fs, argv[3], O_RDWR);
|
|
|
d1681e |
+ if (fd == NULL) {
|
|
|
d1681e |
+ fprintf (stderr, "glfs_open: returned NULL\n");
|
|
|
d1681e |
+ goto out;
|
|
|
d1681e |
+ }
|
|
|
d1681e |
+
|
|
|
d1681e |
+ size = atoi(argv[5]);
|
|
|
d1681e |
+ if (size < 0) {
|
|
|
d1681e |
+ fprintf (stderr, "Wrong size %s", argv[5]);
|
|
|
d1681e |
+ goto out;
|
|
|
d1681e |
+ }
|
|
|
d1681e |
+ ret = glfs_zerofill (fd, 0, atoi(argv[5]));
|
|
|
d1681e |
+ if (ret <= 0) {
|
|
|
d1681e |
+ fprintf (stderr, "glfs_zerofill: returned %d\n", ret);
|
|
|
d1681e |
+ goto out;
|
|
|
d1681e |
+ }
|
|
|
d1681e |
+
|
|
|
d1681e |
+ ret = 0;
|
|
|
d1681e |
+
|
|
|
d1681e |
+out:
|
|
|
d1681e |
+ if (fd)
|
|
|
d1681e |
+ glfs_close(fd);
|
|
|
d1681e |
+ glfs_fini (fs);
|
|
|
d1681e |
+ return ret;
|
|
|
d1681e |
+}
|
|
|
d1681e |
diff --git a/tests/basic/posix/zero-fill-enospace.t b/tests/basic/posix/zero-fill-enospace.t
|
|
|
d1681e |
new file mode 100644
|
|
|
d1681e |
index 0000000..ac2e61b
|
|
|
d1681e |
--- /dev/null
|
|
|
d1681e |
+++ b/tests/basic/posix/zero-fill-enospace.t
|
|
|
d1681e |
@@ -0,0 +1,35 @@
|
|
|
d1681e |
+#!/bin/bash
|
|
|
d1681e |
+
|
|
|
d1681e |
+. $(dirname $0)/../../include.rc
|
|
|
d1681e |
+. $(dirname $0)/../../volume.rc
|
|
|
d1681e |
+. $(dirname $0)/../../dht.rc
|
|
|
d1681e |
+
|
|
|
d1681e |
+cleanup;
|
|
|
d1681e |
+
|
|
|
d1681e |
+TEST glusterd;
|
|
|
d1681e |
+TEST pidof glusterd;
|
|
|
d1681e |
+
|
|
|
d1681e |
+TEST truncate -s 100M $B0/brick1
|
|
|
d1681e |
+
|
|
|
d1681e |
+TEST L1=`SETUP_LOOP $B0/brick1`
|
|
|
d1681e |
+TEST MKFS_LOOP $L1
|
|
|
d1681e |
+
|
|
|
d1681e |
+TEST mkdir -p $B0/${V0}1
|
|
|
d1681e |
+
|
|
|
d1681e |
+TEST MOUNT_LOOP $L1 $B0/${V0}1
|
|
|
d1681e |
+
|
|
|
d1681e |
+TEST $CLI volume create $V0 $H0:$B0/${V0}1
|
|
|
d1681e |
+
|
|
|
d1681e |
+TEST $CLI volume start $V0;
|
|
|
d1681e |
+
|
|
|
d1681e |
+TEST glusterfs -s $H0 --volfile-id=$V0 $M0
|
|
|
d1681e |
+TEST touch $M0/foo
|
|
|
d1681e |
+TEST build_tester $(dirname $0)/zero-fill-enospace.c -lgfapi -Wall -O2
|
|
|
d1681e |
+TEST ! $(dirname $0)/zero-fill-enospace $H0 $V0 /foo `gluster --print-logdir`/glfs-$V0.log 104857600
|
|
|
d1681e |
+
|
|
|
d1681e |
+TEST force_umount $M0
|
|
|
d1681e |
+TEST $CLI volume stop $V0
|
|
|
d1681e |
+UMOUNT_LOOP ${B0}/${V0}1
|
|
|
d1681e |
+rm -f ${B0}/brick1
|
|
|
d1681e |
+
|
|
|
d1681e |
+cleanup
|
|
|
d1681e |
diff --git a/xlators/storage/posix/src/posix.c b/xlators/storage/posix/src/posix.c
|
|
|
d1681e |
index af54882..01f472b 100644
|
|
|
d1681e |
--- a/xlators/storage/posix/src/posix.c
|
|
|
d1681e |
+++ b/xlators/storage/posix/src/posix.c
|
|
|
d1681e |
@@ -943,17 +943,32 @@ _posix_do_zerofill(int fd, off_t offset, off_t len, int o_direct)
|
|
|
d1681e |
op_ret = sys_writev (fd, vector, num_vect);
|
|
|
d1681e |
if (op_ret < 0)
|
|
|
d1681e |
goto err;
|
|
|
d1681e |
+ if (op_ret != (vect_size * num_vect)) {
|
|
|
d1681e |
+ op_ret = -1;
|
|
|
d1681e |
+ errno = ENOSPC;
|
|
|
d1681e |
+ goto err;
|
|
|
d1681e |
+ }
|
|
|
d1681e |
}
|
|
|
d1681e |
if (extra) {
|
|
|
d1681e |
op_ret = sys_writev (fd, vector, extra);
|
|
|
d1681e |
if (op_ret < 0)
|
|
|
d1681e |
goto err;
|
|
|
d1681e |
+ if (op_ret != (vect_size * extra)) {
|
|
|
d1681e |
+ op_ret = -1;
|
|
|
d1681e |
+ errno = ENOSPC;
|
|
|
d1681e |
+ goto err;
|
|
|
d1681e |
+ }
|
|
|
d1681e |
}
|
|
|
d1681e |
if (remain) {
|
|
|
d1681e |
vector[0].iov_len = remain;
|
|
|
d1681e |
op_ret = sys_writev (fd, vector , 1);
|
|
|
d1681e |
if (op_ret < 0)
|
|
|
d1681e |
goto err;
|
|
|
d1681e |
+ if (op_ret != remain) {
|
|
|
d1681e |
+ op_ret = -1;
|
|
|
d1681e |
+ errno = ENOSPC;
|
|
|
d1681e |
+ goto err;
|
|
|
d1681e |
+ }
|
|
|
d1681e |
}
|
|
|
d1681e |
err:
|
|
|
d1681e |
if (o_direct)
|
|
|
d1681e |
@@ -1014,8 +1029,14 @@ posix_do_zerofill (call_frame_t *frame, xlator_t *this, fd_t *fd, off_t offset,
|
|
|
d1681e |
*/
|
|
|
d1681e |
flags = FALLOC_FL_ZERO_RANGE;
|
|
|
d1681e |
ret = sys_fallocate (pfd->fd, flags, offset, len);
|
|
|
d1681e |
- if (ret == 0)
|
|
|
d1681e |
+ if (ret == 0) {
|
|
|
d1681e |
goto fsync;
|
|
|
d1681e |
+ } else {
|
|
|
d1681e |
+ ret = -errno;
|
|
|
d1681e |
+ if ((ret != -ENOSYS) && (ret != -EOPNOTSUPP)) {
|
|
|
d1681e |
+ goto out;
|
|
|
d1681e |
+ }
|
|
|
d1681e |
+ }
|
|
|
d1681e |
|
|
|
d1681e |
ret = _posix_do_zerofill (pfd->fd, offset, len, pfd->flags & O_DIRECT);
|
|
|
d1681e |
if (ret < 0) {
|
|
|
d1681e |
--
|
|
|
d1681e |
1.8.3.1
|
|
|
d1681e |
|