]> www.infradead.org Git - users/sagi/nvme-cli.git/commitdiff
do_discover: free cfg.device when resetting it
authorMartin Wilck <mwilck@suse.com>
Fri, 5 Mar 2021 20:19:10 +0000 (21:19 +0100)
committerMartin Wilck <mwilck@suse.com>
Tue, 30 Mar 2021 13:14:01 +0000 (15:14 +0200)
cfg.device might have been allocated by a previous call to
find_ctrl_with_connectargs(), therefore free it. We must make sure
that cfg.device is always on the heap, thus change fabrics_discover()
accordingly.

fabrics.c

index bdd0679de2dadb911f7793b64fe1f05322103751..49331cd48172ba5834da8d0d2783f3daa70cf3b1 100644 (file)
--- a/fabrics.c
+++ b/fabrics.c
@@ -1376,7 +1376,11 @@ static int do_discover(char *argstr, bool connect, enum nvme_print_flags flags)
        if (!cargs)
                return -ENOMEM;
 
-       if (!cfg.device || !ctrl_matches_connectargs(cfg.device, cargs))
+       if (cfg.device && !ctrl_matches_connectargs(cfg.device, cargs)) {
+               free(cfg.device);
+               cfg.device = NULL;
+       }
+       if (!cfg.device)
                cfg.device = find_ctrl_with_connectargs(cargs);
        free_connect_args(cargs);
 
@@ -1560,8 +1564,13 @@ int fabrics_discover(const char *desc, int argc, char **argv, bool connect)
        ret = flags = validate_output_format(cfg.output_format);
        if (ret < 0)
                goto out;
-       if (cfg.device && !strcmp(cfg.device, "none"))
-               cfg.device = NULL;
+       if (cfg.device && strcmp(cfg.device, "none")) {
+               cfg.device = strdup(cfg.device);
+               if (!cfg.device) {
+                       ret = -ENOMEM;
+                       goto out;
+               }
+       }
 
        cfg.nqn = NVME_DISC_SUBSYS_NAME;