diff options
Diffstat (limited to 'xlators/cluster/dht/src')
| -rw-r--r-- | xlators/cluster/dht/src/dht-rebalance.c | 31 | 
1 files changed, 16 insertions, 15 deletions
| diff --git a/xlators/cluster/dht/src/dht-rebalance.c b/xlators/cluster/dht/src/dht-rebalance.c index 56e90f69866..bcb19f23e96 100644 --- a/xlators/cluster/dht/src/dht-rebalance.c +++ b/xlators/cluster/dht/src/dht-rebalance.c @@ -243,7 +243,7 @@ out:  static inline int  __dht_rebalance_create_dst_file (xlator_t *to, xlator_t *from, loc_t *loc, struct iatt *stbuf, -                                 dict_t *dict, fd_t **dst_fd) +                                 dict_t *dict, fd_t **dst_fd, dict_t *xattr)  {          xlator_t    *this = NULL;          int          ret  = -1; @@ -307,6 +307,12 @@ __dht_rebalance_create_dst_file (xlator_t *to, xlator_t *from, loc_t *loc, struc                  goto out;          } +        ret = syncop_fsetxattr (to, fd, xattr, 0); +        if (ret == -1) +                gf_log (this->name, GF_LOG_WARNING, +                        "%s: failed to set xattr on %s (%s)", +                        loc->path, to->name, strerror (errno)); +          ret = syncop_ftruncate (to, fd, stbuf->ia_size);          if (ret < 0)                  gf_log (this->name, GF_LOG_ERROR, @@ -723,9 +729,16 @@ dht_migrate_file (xlator_t *this, loc_t *loc, xlator_t *from, xlator_t *to,                  goto out;          } +        /* TODO: move all xattr related operations to fd based operations */ +        ret = syncop_listxattr (from, loc, &xattr); +        if (ret == -1) +                gf_log (this->name, GF_LOG_WARNING, +                        "%s: failed to get xattr from %s (%s)", +                        loc->path, from->name, strerror (errno)); +          /* create the destination, with required modes/xattr */          ret = __dht_rebalance_create_dst_file (to, from, loc, &stbuf, -                                               dict, &dst_fd); +                                               dict, &dst_fd, xattr);          if (ret)                  goto out; @@ -742,6 +755,7 @@ dht_migrate_file (xlator_t *this, loc_t *loc, xlator_t *from, xlator_t *to,                  goto out;          } +          ret = syncop_fstat (from, src_fd, &stbuf);          if (ret) {                  gf_log (this->name, GF_LOG_ERROR, "failed to lookup %s on %s (%s)", @@ -771,19 +785,6 @@ dht_migrate_file (xlator_t *this, loc_t *loc, xlator_t *from, xlator_t *to,                  goto out;          } -        /* TODO: move all xattr related operations to fd based operations */ -        ret = syncop_listxattr (from, loc, &xattr); -        if (ret == -1) -                gf_log (this->name, GF_LOG_WARNING, -                        "%s: failed to get xattr from %s (%s)", -                        loc->path, from->name, strerror (errno)); - -        ret = syncop_setxattr (to, loc, xattr, 0); -        if (ret == -1) -                gf_log (this->name, GF_LOG_WARNING, -                        "%s: failed to set xattr on %s (%s)", -                        loc->path, to->name, strerror (errno)); -          /* TODO: Sync the locks */          ret = syncop_fsync (to, dst_fd, 0); | 
