diff options
| -rw-r--r-- | xlators/cluster/afr/src/afr-lk-common.c | 15 | 
1 files changed, 8 insertions, 7 deletions
diff --git a/xlators/cluster/afr/src/afr-lk-common.c b/xlators/cluster/afr/src/afr-lk-common.c index be3de01924d..dff6644eb96 100644 --- a/xlators/cluster/afr/src/afr-lk-common.c +++ b/xlators/cluster/afr/src/afr-lk-common.c @@ -970,6 +970,14 @@ afr_nonblocking_inodelk_cbk (call_frame_t *frame, void *cookie, xlator_t *this,          local    = frame->local;          int_lock = &local->internal_lock; +        if (op_ret == 0 && local->transaction.type == AFR_DATA_TRANSACTION) { +                LOCK (&local->inode->lock); +                { +                        local->inode_ctx->lock_count++; +                } +                UNLOCK (&local->inode->lock); +        } +          LOCK (&frame->lock);          {  		if (op_ret < 0) { @@ -994,13 +1002,6 @@ afr_nonblocking_inodelk_cbk (call_frame_t *frame, void *cookie, xlator_t *this,          }          UNLOCK (&frame->lock); -        if (op_ret == 0 && local->transaction.type == AFR_DATA_TRANSACTION) { -                LOCK (&local->inode->lock); -                { -                        local->inode_ctx->lock_count++; -                } -                UNLOCK (&local->inode->lock); -        }          if (call_count == 0) {                  gf_msg_trace (this->name, 0,                                "Last inode locking reply received");  | 
