d2787b
From b3647eb5415b2e3d9e1a11ad6c4689e520f17b39 Mon Sep 17 00:00:00 2001
d2787b
From: mohit84 <moagrawa@redhat.com>
d2787b
Date: Mon, 22 Feb 2021 10:09:34 +0530
d2787b
Subject: [PATCH 534/538] glusterd: Resolve use after free bug (#2181)
d2787b
d2787b
In the commit 61ae58e67567ea4de8f8efc6b70a9b1f8e0f1bea
d2787b
introduced a coverity bug use object after cleanup
d2787b
the object.
d2787b
d2787b
Cleanup memory after comeout from a critical section
d2787b
>Fixes: #2180
d2787b
d2787b
>Change-Id: Iee2050c4883a0dd44b8523bb822b664462ab6041
d2787b
>Signed-off-by: Mohit Agrawal <moagrawa@redhat.com>
d2787b
Upstream Patch : https://github.com/gluster/glusterfs/pull/2181
d2787b
d2787b
BUG: 1832306
d2787b
Change-Id: Iee2050c4883a0dd44b8523bb822b664462ab6041
d2787b
Signed-off-by: srijan-sivakumar <ssivakum@redhat.com>
d2787b
Reviewed-on: https://code.engineering.redhat.com/gerrit/228578
d2787b
Tested-by: RHGS Build Bot <nigelb@redhat.com>
d2787b
Reviewed-by: Sunil Kumar Heggodu Gopala Acharya <sheggodu@redhat.com>
d2787b
---
d2787b
 xlators/mgmt/glusterd/src/glusterd-utils.c | 5 ++---
d2787b
 1 file changed, 2 insertions(+), 3 deletions(-)
d2787b
d2787b
diff --git a/xlators/mgmt/glusterd/src/glusterd-utils.c b/xlators/mgmt/glusterd/src/glusterd-utils.c
d2787b
index 9fb8eab..6d40be5 100644
d2787b
--- a/xlators/mgmt/glusterd/src/glusterd-utils.c
d2787b
+++ b/xlators/mgmt/glusterd/src/glusterd-utils.c
d2787b
@@ -122,11 +122,10 @@ glusterd_defrag_unref(glusterd_defrag_info_t *defrag)
d2787b
     LOCK(&defrag->lock);
d2787b
     {
d2787b
         refcnt = --defrag->refcnt;
d2787b
-        if (refcnt <= 0)
d2787b
-            GF_FREE(defrag);
d2787b
     }
d2787b
     UNLOCK(&defrag->lock);
d2787b
-
d2787b
+    if (refcnt <= 0)
d2787b
+        GF_FREE(defrag);
d2787b
 out:
d2787b
     return refcnt;
d2787b
 }
d2787b
-- 
d2787b
1.8.3.1
d2787b