]> git.ipfire.org Git - thirdparty/iw.git/blobdiff - phy.c
info: macro-ify ext_feat_print()
[thirdparty/iw.git] / phy.c
diff --git a/phy.c b/phy.c
index 77df7a7609a74375c4f5087ffb963fcb4e91bc76..716677eff28d4462fdb7d448f531b346fd9df389 100644 (file)
--- a/phy.c
+++ b/phy.c
@@ -1,6 +1,7 @@
 #include <stdbool.h>
 #include <errno.h>
 #include <strings.h>
+#include <unistd.h>
 #include <sys/param.h>
 #include <sys/stat.h>
 #include <fcntl.h>
@@ -328,12 +329,16 @@ static int handle_cac(struct nl80211_state *state,
        } else if (strcmp(argv[2], "freq") == 0) {
                err = parse_freqchan(&chandef, false, argc - 3, argv + 3, NULL);
        } else {
-               return 1;
+               err = 1;
        }
+       if (err)
+               goto err_out;
 
        cac_trigger_argv = calloc(argc + 1, sizeof(char*));
-       if (!cac_trigger_argv)
-               return -ENOMEM;
+       if (!cac_trigger_argv) {
+               err = -ENOMEM;
+               goto err_out;
+       }
 
        cac_trigger_argv[0] = argv[0];
        cac_trigger_argv[1] = "cac";
@@ -341,9 +346,8 @@ static int handle_cac(struct nl80211_state *state,
        memcpy(&cac_trigger_argv[3], &argv[2], (argc - 2) * sizeof(char*));
 
        err = handle_cmd(state, id, argc + 1, cac_trigger_argv);
-       free(cac_trigger_argv);
        if (err)
-               return err;
+               goto err_out;
 
        cac_event.ret = 1;
        cac_event.freq = chandef.control_freq;
@@ -357,7 +361,13 @@ static int handle_cac(struct nl80211_state *state,
        while (cac_event.ret > 0)
                nl_recvmsgs(state->nl_sock, radar_cb);
 
-       return 0;
+       err = 0;
+err_out:
+       if (radar_cb)
+               nl_cb_put(radar_cb);
+       if (cac_trigger_argv)
+               free(cac_trigger_argv);
+       return err;
 }
 TOPLEVEL(cac, "channel <channel> [NOHT|HT20|HT40+|HT40-|5MHz|10MHz|80MHz]\n"
              "freq <freq> [NOHT|HT20|HT40+|HT40-|5MHz|10MHz|80MHz]\n"
@@ -523,7 +533,7 @@ static int handle_netns(struct nl80211_state *state,
                        enum id_input id)
 {
        char *end;
-       int fd;
+       int fd = -1;
 
        if (argc < 1 || !*argv[0])
                return 1;
@@ -551,6 +561,8 @@ static int handle_netns(struct nl80211_state *state,
        return 1;
 
  nla_put_failure:
+       if (fd >= 0)
+               close(fd);
        return -ENOBUFS;
 }
 COMMAND(set, netns, "{ <pid> | name <nsname> }",