|
@@ -14,6 +14,7 @@
|
|
|
#include <dirent.h>
|
|
|
#endif /* CONFIG_CTRL_IFACE_UNIX */
|
|
|
|
|
|
+#include "common/cli.h"
|
|
|
#include "common/wpa_ctrl.h"
|
|
|
#include "utils/common.h"
|
|
|
#include "utils/eloop.h"
|
|
@@ -90,11 +91,6 @@ static int ping_interval = 5;
|
|
|
static int interactive = 0;
|
|
|
static char *ifname_prefix = NULL;
|
|
|
|
|
|
-struct cli_txt_entry {
|
|
|
- struct dl_list list;
|
|
|
- char *txt;
|
|
|
-};
|
|
|
-
|
|
|
static DEFINE_DL_LIST(bsses); /* struct cli_txt_entry */
|
|
|
static DEFINE_DL_LIST(p2p_peers); /* struct cli_txt_entry */
|
|
|
static DEFINE_DL_LIST(p2p_groups); /* struct cli_txt_entry */
|
|
@@ -130,144 +126,6 @@ static void usage(void)
|
|
|
}
|
|
|
|
|
|
|
|
|
-static void cli_txt_list_free(struct cli_txt_entry *e)
|
|
|
-{
|
|
|
- dl_list_del(&e->list);
|
|
|
- os_free(e->txt);
|
|
|
- os_free(e);
|
|
|
-}
|
|
|
-
|
|
|
-
|
|
|
-static void cli_txt_list_flush(struct dl_list *list)
|
|
|
-{
|
|
|
- struct cli_txt_entry *e;
|
|
|
- while ((e = dl_list_first(list, struct cli_txt_entry, list)))
|
|
|
- cli_txt_list_free(e);
|
|
|
-}
|
|
|
-
|
|
|
-
|
|
|
-static struct cli_txt_entry * cli_txt_list_get(struct dl_list *txt_list,
|
|
|
- const char *txt)
|
|
|
-{
|
|
|
- struct cli_txt_entry *e;
|
|
|
- dl_list_for_each(e, txt_list, struct cli_txt_entry, list) {
|
|
|
- if (os_strcmp(e->txt, txt) == 0)
|
|
|
- return e;
|
|
|
- }
|
|
|
- return NULL;
|
|
|
-}
|
|
|
-
|
|
|
-
|
|
|
-static void cli_txt_list_del(struct dl_list *txt_list, const char *txt)
|
|
|
-{
|
|
|
- struct cli_txt_entry *e;
|
|
|
- e = cli_txt_list_get(txt_list, txt);
|
|
|
- if (e)
|
|
|
- cli_txt_list_free(e);
|
|
|
-}
|
|
|
-
|
|
|
-
|
|
|
-static void cli_txt_list_del_addr(struct dl_list *txt_list, const char *txt)
|
|
|
-{
|
|
|
- u8 addr[ETH_ALEN];
|
|
|
- char buf[18];
|
|
|
- if (hwaddr_aton(txt, addr) < 0)
|
|
|
- return;
|
|
|
- os_snprintf(buf, sizeof(buf), MACSTR, MAC2STR(addr));
|
|
|
- cli_txt_list_del(txt_list, buf);
|
|
|
-}
|
|
|
-
|
|
|
-
|
|
|
-#ifdef CONFIG_P2P
|
|
|
-static void cli_txt_list_del_word(struct dl_list *txt_list, const char *txt,
|
|
|
- int separator)
|
|
|
-{
|
|
|
- const char *end;
|
|
|
- char *buf;
|
|
|
- end = os_strchr(txt, separator);
|
|
|
- if (end == NULL)
|
|
|
- end = txt + os_strlen(txt);
|
|
|
- buf = dup_binstr(txt, end - txt);
|
|
|
- if (buf == NULL)
|
|
|
- return;
|
|
|
- cli_txt_list_del(txt_list, buf);
|
|
|
- os_free(buf);
|
|
|
-}
|
|
|
-#endif /* CONFIG_P2P */
|
|
|
-
|
|
|
-
|
|
|
-static int cli_txt_list_add(struct dl_list *txt_list, const char *txt)
|
|
|
-{
|
|
|
- struct cli_txt_entry *e;
|
|
|
- e = cli_txt_list_get(txt_list, txt);
|
|
|
- if (e)
|
|
|
- return 0;
|
|
|
- e = os_zalloc(sizeof(*e));
|
|
|
- if (e == NULL)
|
|
|
- return -1;
|
|
|
- e->txt = os_strdup(txt);
|
|
|
- if (e->txt == NULL) {
|
|
|
- os_free(e);
|
|
|
- return -1;
|
|
|
- }
|
|
|
- dl_list_add(txt_list, &e->list);
|
|
|
- return 0;
|
|
|
-}
|
|
|
-
|
|
|
-
|
|
|
-#ifdef CONFIG_P2P
|
|
|
-static int cli_txt_list_add_addr(struct dl_list *txt_list, const char *txt)
|
|
|
-{
|
|
|
- u8 addr[ETH_ALEN];
|
|
|
- char buf[18];
|
|
|
- if (hwaddr_aton(txt, addr) < 0)
|
|
|
- return -1;
|
|
|
- os_snprintf(buf, sizeof(buf), MACSTR, MAC2STR(addr));
|
|
|
- return cli_txt_list_add(txt_list, buf);
|
|
|
-}
|
|
|
-#endif /* CONFIG_P2P */
|
|
|
-
|
|
|
-
|
|
|
-static int cli_txt_list_add_word(struct dl_list *txt_list, const char *txt,
|
|
|
- int separator)
|
|
|
-{
|
|
|
- const char *end;
|
|
|
- char *buf;
|
|
|
- int ret;
|
|
|
- end = os_strchr(txt, separator);
|
|
|
- if (end == NULL)
|
|
|
- end = txt + os_strlen(txt);
|
|
|
- buf = dup_binstr(txt, end - txt);
|
|
|
- if (buf == NULL)
|
|
|
- return -1;
|
|
|
- ret = cli_txt_list_add(txt_list, buf);
|
|
|
- os_free(buf);
|
|
|
- return ret;
|
|
|
-}
|
|
|
-
|
|
|
-
|
|
|
-static char ** cli_txt_list_array(struct dl_list *txt_list)
|
|
|
-{
|
|
|
- unsigned int i, count = dl_list_len(txt_list);
|
|
|
- char **res;
|
|
|
- struct cli_txt_entry *e;
|
|
|
-
|
|
|
- res = os_calloc(count + 1, sizeof(char *));
|
|
|
- if (res == NULL)
|
|
|
- return NULL;
|
|
|
-
|
|
|
- i = 0;
|
|
|
- dl_list_for_each(e, txt_list, struct cli_txt_entry, list) {
|
|
|
- res[i] = os_strdup(e->txt);
|
|
|
- if (res[i] == NULL)
|
|
|
- break;
|
|
|
- i++;
|
|
|
- }
|
|
|
-
|
|
|
- return res;
|
|
|
-}
|
|
|
-
|
|
|
-
|
|
|
static int get_cmd_arg_num(const char *str, int pos)
|
|
|
{
|
|
|
int arg = 0, i;
|