diff options
Diffstat (limited to 'xlators/cluster/dht/src/dht-common.c')
| -rw-r--r-- | xlators/cluster/dht/src/dht-common.c | 27 | 
1 files changed, 23 insertions, 4 deletions
| diff --git a/xlators/cluster/dht/src/dht-common.c b/xlators/cluster/dht/src/dht-common.c index f9e7141604a..301d776dac4 100644 --- a/xlators/cluster/dht/src/dht-common.c +++ b/xlators/cluster/dht/src/dht-common.c @@ -53,6 +53,17 @@ dht_set_dir_xattr_req(xlator_t *this, loc_t *loc, dict_t *xattr_req);  int  dht_do_fresh_lookup(call_frame_t *frame, xlator_t *this, loc_t *loc); +/* Check the xdata to make sure EBADF has been set by client xlator */ +int32_t +dht_check_remote_fd_failed_error(dht_local_t *local, int op_ret, int op_errno) +{ +    if (op_ret == -1 && (op_errno == EBADF || op_errno == EBADFD) && +        !(local->fd_checked)) { +        return 1; +    } +    return 0; +} +  /* Sets the blocks and size values to fixed values. This is to be called   * only for dirs. The caller is responsible for checking the type   */ @@ -4528,6 +4539,7 @@ dht_getxattr_cbk(call_frame_t *frame, void *cookie, xlator_t *this, int op_ret,      int this_call_cnt = 0;      dht_local_t *local = NULL;      dht_conf_t *conf = NULL; +    int ret = 0;      VALIDATE_OR_GOTO(frame, err);      VALIDATE_OR_GOTO(frame->local, err); @@ -4536,6 +4548,13 @@ dht_getxattr_cbk(call_frame_t *frame, void *cookie, xlator_t *this, int op_ret,      conf = this->private;      local = frame->local; +    if (dht_check_remote_fd_failed_error(local, op_ret, op_errno)) { +        ret = dht_check_and_open_fd_on_subvol(this, frame); +        if (ret) +            goto err; +        return 0; +    } +      LOCK(&frame->lock);      {          if (!xattr || (op_ret == -1)) { @@ -5203,8 +5222,8 @@ dht_file_setxattr_cbk(call_frame_t *frame, void *cookie, xlator_t *this,      local->op_errno = op_errno; -    if ((local->fop == GF_FOP_FSETXATTR) && op_ret == -1 && -        (op_errno == EBADF) && !(local->fd_checked)) { +    if ((local->fop == GF_FOP_FSETXATTR) && +        dht_check_remote_fd_failed_error(local, op_ret, op_errno)) {          ret = dht_check_and_open_fd_on_subvol(this, frame);          if (ret)              goto out; @@ -5928,8 +5947,8 @@ dht_file_removexattr_cbk(call_frame_t *frame, void *cookie, xlator_t *this,      local->op_errno = op_errno; -    if ((local->fop == GF_FOP_FREMOVEXATTR) && (op_ret == -1) && -        (op_errno == EBADF) && !(local->fd_checked)) { +    if ((local->fop == GF_FOP_FREMOVEXATTR) && +        dht_check_remote_fd_failed_error(local, op_ret, op_errno)) {          ret = dht_check_and_open_fd_on_subvol(this, frame);          if (ret)              goto out; | 
