summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--xlators/cluster/dht/src/dht-common.c55
1 files changed, 53 insertions, 2 deletions
diff --git a/xlators/cluster/dht/src/dht-common.c b/xlators/cluster/dht/src/dht-common.c
index 63e505c8c91..7cf5229aad1 100644
--- a/xlators/cluster/dht/src/dht-common.c
+++ b/xlators/cluster/dht/src/dht-common.c
@@ -1276,6 +1276,38 @@ err:
return 0;
}
+static int
+dht_ufo_xattr_cbk (call_frame_t *frame, void *cookie, xlator_t *this,
+ int op_ret, int op_errno)
+{
+ dht_local_t *local = NULL;
+ int this_call_cnt = 0;
+ call_frame_t *prev = NULL;
+
+ local = frame->local;
+ prev = cookie;
+
+ LOCK (&frame->lock);
+ {
+ if (op_ret == -1) {
+ local->op_ret = -1;
+ local->op_errno = op_errno;
+ gf_log (this->name, GF_LOG_DEBUG,
+ "subvolume %s returned -1 (%s)",
+ prev->this->name, strerror (op_errno));
+ goto unlock;
+ }
+ }
+unlock:
+ UNLOCK (&frame->lock);
+
+ this_call_cnt = dht_frame_return (frame);
+ if (is_last_call (this_call_cnt)) {
+ DHT_STACK_UNWIND (setxattr, frame, local->op_ret, local->op_errno);
+ }
+
+ return 0;
+}
int
@@ -1790,6 +1822,27 @@ dht_setxattr (call_frame_t *frame, xlator_t *this,
goto err;
}
+ local->call_cnt = layout->cnt;
+
+ /* This key is sent by Unified File and Object storage
+ * to test xattr support in backend.
+ */
+ tmp = dict_get (xattr, "user.ufo-test");
+ if (tmp) {
+ if (IA_ISREG (loc->inode->ia_type)) {
+ op_errno = ENOTSUP;
+ goto err;
+ }
+ local->op_ret = 0;
+ for (i = 0; i < layout->cnt; i++) {
+ STACK_WIND (frame, dht_ufo_xattr_cbk,
+ layout->list[i].xlator,
+ layout->list[i].xlator->fops->setxattr,
+ loc, xattr, flags);
+ }
+ return 0;
+ }
+
tmp = dict_get (xattr, "distribute.migrate-data");
if (tmp) {
if (!IA_ISREG (loc->inode->ia_type)) {
@@ -1878,8 +1931,6 @@ dht_setxattr (call_frame_t *frame, xlator_t *this,
goto err;
}
- local->call_cnt = layout->cnt;
-
for (i = 0; i < layout->cnt; i++) {
STACK_WIND (frame, dht_err_cbk,
layout->list[i].xlator,