[PATCH 6/7] locking: Resolve mem leak in virLockDaemonPreExecRestart

John Ferlan posted 7 patches 5 years, 2 months ago
[PATCH 6/7] locking: Resolve mem leak in virLockDaemonPreExecRestart
Posted by John Ferlan 5 years, 2 months ago
Initialize and free @magic since virJSONValueObjectAppendString
does not free it for us eventually.

Signed-off-by: John Ferlan <jferlan@redhat.com>
---
 src/locking/lock_daemon.c | 7 +++----
 1 file changed, 3 insertions(+), 4 deletions(-)

diff --git a/src/locking/lock_daemon.c b/src/locking/lock_daemon.c
index 57c7fb088f..851e9fc6f0 100644
--- a/src/locking/lock_daemon.c
+++ b/src/locking/lock_daemon.c
@@ -700,7 +700,7 @@ virLockDaemonPreExecRestart(const char *state_file,
     virJSONValuePtr child;
     char *state = NULL;
     virJSONValuePtr object = virJSONValueNewObject();
-    char *magic;
+    char *magic = NULL;
     virHashKeyValuePairPtr pairs = NULL, tmp;
     virJSONValuePtr lockspaces;
 
@@ -748,10 +748,8 @@ virLockDaemonPreExecRestart(const char *state_file,
     if (!(magic = virLockDaemonGetExecRestartMagic()))
         goto cleanup;
 
-    if (virJSONValueObjectAppendString(object, "magic", magic) < 0) {
-        VIR_FREE(magic);
+    if (virJSONValueObjectAppendString(object, "magic", magic) < 0)
         goto cleanup;
-    }
 
     if (!(state = virJSONValueToString(object, true)))
         goto cleanup;
@@ -775,6 +773,7 @@ virLockDaemonPreExecRestart(const char *state_file,
     abort(); /* This should be impossible to reach */
 
  cleanup:
+    VIR_FREE(magic);
     VIR_FREE(pairs);
     VIR_FREE(state);
     virJSONValueFree(object);
-- 
2.28.0

Re: [PATCH 6/7] locking: Resolve mem leak in virLockDaemonPreExecRestart
Posted by Ján Tomko 5 years, 2 months ago
On a Wednesday in 2020, John Ferlan wrote:
>Initialize and free @magic since virJSONValueObjectAppendString
>does not free it for us eventually.
>
>Signed-off-by: John Ferlan <jferlan@redhat.com>
>---
> src/locking/lock_daemon.c | 7 +++----
> 1 file changed, 3 insertions(+), 4 deletions(-)
>

Reviewed-by: Ján Tomko <jtomko@redhat.com>

Jano