diff options
| author | Krutika Dhananjay <kdhananj@redhat.com> | 2016-11-08 17:24:41 +0530 | 
|---|---|---|
| committer | Pranith Kumar Karampuri <pkarampu@redhat.com> | 2016-11-11 04:23:54 -0800 | 
| commit | 0f97f880b0d01baf94e10950e63e4bb823ed2e40 (patch) | |
| tree | 961eb4e0333f13bad7a78d3379cbc44f22a77064 | |
| parent | 42c945015e0ffa5f88db7d28bd992c31abae0c17 (diff) | |
cluster/afr: When failing fop due to lack of quorum, also log error string
        Backport of: http://review.gluster.org/#/c/15800/
Change-Id: I2dd7ed69a456e8b9e54a4093f14dc16950bef081
BUG: 1393630
Signed-off-by: Krutika Dhananjay <kdhananj@redhat.com>
Reviewed-on: http://review.gluster.org/15813
Smoke: Gluster Build System <jenkins@build.gluster.org>
CentOS-regression: Gluster Build System <jenkins@build.gluster.org>
NetBSD-regression: NetBSD Build System <jenkins@build.gluster.org>
Reviewed-by: Pranith Kumar Karampuri <pkarampu@redhat.com>
| -rw-r--r-- | xlators/cluster/afr/src/afr-transaction.c | 23 | 
1 files changed, 12 insertions, 11 deletions
diff --git a/xlators/cluster/afr/src/afr-transaction.c b/xlators/cluster/afr/src/afr-transaction.c index 5733cc1c1ca..848387fc0db 100644 --- a/xlators/cluster/afr/src/afr-transaction.c +++ b/xlators/cluster/afr/src/afr-transaction.c @@ -782,6 +782,16 @@ afr_handle_quorum (call_frame_t *frame)          if (afr_has_fop_cbk_quorum (frame))                  return; +        for (i = 0; i < priv->child_count; i++) { +                if (local->transaction.pre_op[i]) +                        afr_transaction_fop_failed (frame, frame->this, i); +        } + +        local->op_ret = -1; +        local->op_errno = afr_final_errno (local, priv); +        if (local->op_errno == 0) +                local->op_errno = afr_quorum_errno (priv); +          if (local->fd) {                  gf_uuid_copy (gfid, local->fd->inode->gfid);                  file = uuid_utoa (gfid); @@ -790,19 +800,10 @@ afr_handle_quorum (call_frame_t *frame)                  file = local->loc.path;          } -        gf_msg (frame->this->name, GF_LOG_WARNING, 0, AFR_MSG_QUORUM_FAIL, -                "%s: Failing %s as quorum is not met", +        gf_msg (frame->this->name, GF_LOG_WARNING, local->op_errno, +                AFR_MSG_QUORUM_FAIL, "%s: Failing %s as quorum is not met",                  file, gf_fop_list[local->op]); -        for (i = 0; i < priv->child_count; i++) { -                if (local->transaction.pre_op[i]) -                        afr_transaction_fop_failed (frame, frame->this, i); -        } - -        local->op_ret = -1; -        local->op_errno = afr_final_errno (local, priv); -        if (local->op_errno == 0) -                local->op_errno = afr_quorum_errno (priv);          switch (local->transaction.type) {          case AFR_ENTRY_TRANSACTION:          case AFR_ENTRY_RENAME_TRANSACTION:  | 
