2010-11-06 10:20:45 -04:00
|
|
|
/*
|
|
|
|
* wlantest - IEEE 802.11 protocol monitoring and testing tool
|
|
|
|
* Copyright (c) 2010, Jouni Malinen <j@w1.fi>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* Alternatively, this software may be distributed under the terms of BSD
|
|
|
|
* license.
|
|
|
|
*
|
|
|
|
* See README and COPYING for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "utils/includes.h"
|
|
|
|
|
|
|
|
#include "utils/common.h"
|
|
|
|
#include "utils/eloop.h"
|
|
|
|
#include "wlantest.h"
|
|
|
|
|
|
|
|
|
|
|
|
extern int wpa_debug_level;
|
2010-11-06 16:57:49 -04:00
|
|
|
extern int wpa_debug_show_keys;
|
2010-11-06 10:20:45 -04:00
|
|
|
|
|
|
|
|
|
|
|
static void wlantest_terminate(int sig, void *signal_ctx)
|
|
|
|
{
|
|
|
|
eloop_terminate();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void usage(void)
|
|
|
|
{
|
2010-11-06 16:57:49 -04:00
|
|
|
printf("wlantest [-ddhqq] [-i<ifname>] [-r<pcap file>] "
|
2010-11-07 10:59:50 -05:00
|
|
|
"[-p<passphrase>]\n"
|
|
|
|
" [-I<wired ifname>] [-R<wired pcap file>]\n");
|
2010-11-06 16:57:49 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void passphrase_deinit(struct wlantest_passphrase *p)
|
|
|
|
{
|
|
|
|
dl_list_del(&p->list);
|
|
|
|
os_free(p);
|
2010-11-06 10:20:45 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-11-06 11:11:12 -04:00
|
|
|
static void wlantest_init(struct wlantest *wt)
|
|
|
|
{
|
|
|
|
os_memset(wt, 0, sizeof(*wt));
|
|
|
|
wt->monitor_sock = -1;
|
2010-11-06 16:57:49 -04:00
|
|
|
dl_list_init(&wt->passphrase);
|
2010-11-06 11:11:12 -04:00
|
|
|
dl_list_init(&wt->bss);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void wlantest_deinit(struct wlantest *wt)
|
|
|
|
{
|
|
|
|
struct wlantest_bss *bss, *n;
|
2010-11-06 16:57:49 -04:00
|
|
|
struct wlantest_passphrase *p, *pn;
|
2010-11-06 11:11:12 -04:00
|
|
|
if (wt->monitor_sock >= 0)
|
|
|
|
monitor_deinit(wt);
|
|
|
|
dl_list_for_each_safe(bss, n, &wt->bss, struct wlantest_bss, list)
|
|
|
|
bss_deinit(bss);
|
2010-11-06 16:57:49 -04:00
|
|
|
dl_list_for_each_safe(p, pn, &wt->passphrase,
|
|
|
|
struct wlantest_passphrase, list)
|
|
|
|
passphrase_deinit(p);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void add_passphrase(struct wlantest *wt, const char *passphrase)
|
|
|
|
{
|
|
|
|
struct wlantest_passphrase *p;
|
|
|
|
size_t len = os_strlen(passphrase);
|
|
|
|
|
|
|
|
if (len < 8 || len > 63)
|
|
|
|
return;
|
|
|
|
p = os_zalloc(sizeof(*p));
|
|
|
|
if (p == NULL)
|
|
|
|
return;
|
|
|
|
os_memcpy(p->passphrase, passphrase, len);
|
|
|
|
dl_list_add(&wt->passphrase, &p->list);
|
2010-11-06 11:11:12 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-11-06 10:20:45 -04:00
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
int c;
|
|
|
|
const char *read_file = NULL;
|
2010-11-07 10:59:50 -05:00
|
|
|
const char *read_wired_file = NULL;
|
2010-11-06 10:20:45 -04:00
|
|
|
const char *ifname = NULL;
|
2010-11-07 10:59:50 -05:00
|
|
|
const char *ifname_wired = NULL;
|
2010-11-06 10:20:45 -04:00
|
|
|
struct wlantest wt;
|
|
|
|
|
|
|
|
wpa_debug_level = MSG_INFO;
|
2010-11-06 16:57:49 -04:00
|
|
|
wpa_debug_show_keys = 1;
|
2010-11-06 10:20:45 -04:00
|
|
|
|
|
|
|
if (os_program_init())
|
|
|
|
return -1;
|
|
|
|
|
2010-11-06 11:11:12 -04:00
|
|
|
wlantest_init(&wt);
|
2010-11-06 10:20:45 -04:00
|
|
|
|
|
|
|
for (;;) {
|
2010-11-07 10:59:50 -05:00
|
|
|
c = getopt(argc, argv, "dhi:I:p:qr:R:");
|
2010-11-06 10:20:45 -04:00
|
|
|
if (c < 0)
|
|
|
|
break;
|
|
|
|
switch (c) {
|
|
|
|
case 'd':
|
|
|
|
if (wpa_debug_level > 0)
|
|
|
|
wpa_debug_level--;
|
|
|
|
break;
|
|
|
|
case 'h':
|
|
|
|
usage();
|
|
|
|
return 0;
|
|
|
|
case 'i':
|
|
|
|
ifname = optarg;
|
|
|
|
break;
|
2010-11-07 10:59:50 -05:00
|
|
|
case 'I':
|
|
|
|
ifname_wired = optarg;
|
|
|
|
break;
|
2010-11-06 16:57:49 -04:00
|
|
|
case 'p':
|
|
|
|
add_passphrase(&wt, optarg);
|
|
|
|
break;
|
2010-11-06 10:20:45 -04:00
|
|
|
case 'q':
|
|
|
|
wpa_debug_level++;
|
|
|
|
break;
|
|
|
|
case 'r':
|
|
|
|
read_file = optarg;
|
|
|
|
break;
|
2010-11-07 10:59:50 -05:00
|
|
|
case 'R':
|
|
|
|
read_wired_file = optarg;
|
|
|
|
break;
|
2010-11-06 10:20:45 -04:00
|
|
|
default:
|
|
|
|
usage();
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-11-07 10:59:50 -05:00
|
|
|
if (ifname == NULL && ifname_wired == NULL &&
|
|
|
|
read_file == NULL && read_wired_file == NULL) {
|
2010-11-06 10:20:45 -04:00
|
|
|
usage();
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (eloop_init())
|
|
|
|
return -1;
|
|
|
|
|
2010-11-07 10:59:50 -05:00
|
|
|
if (read_wired_file && read_wired_cap_file(&wt, read_wired_file) < 0)
|
|
|
|
return -1;
|
|
|
|
|
2010-11-06 10:20:45 -04:00
|
|
|
if (read_file && read_cap_file(&wt, read_file) < 0)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (ifname && monitor_init(&wt, ifname) < 0)
|
|
|
|
return -1;
|
|
|
|
|
2010-11-07 10:59:50 -05:00
|
|
|
if (ifname_wired && monitor_init_wired(&wt, ifname_wired) < 0)
|
|
|
|
return -1;
|
|
|
|
|
2010-11-06 10:20:45 -04:00
|
|
|
eloop_register_signal_terminate(wlantest_terminate, &wt);
|
|
|
|
|
|
|
|
eloop_run();
|
|
|
|
|
|
|
|
wpa_printf(MSG_INFO, "Processed: rx_mgmt=%u rx_ctrl=%u rx_data=%u "
|
|
|
|
"fcs_error=%u",
|
|
|
|
wt.rx_mgmt, wt.rx_ctrl, wt.rx_data, wt.fcs_error);
|
|
|
|
|
2010-11-06 11:11:12 -04:00
|
|
|
wlantest_deinit(&wt);
|
2010-11-06 10:20:45 -04:00
|
|
|
|
|
|
|
eloop_destroy();
|
|
|
|
os_program_deinit();
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|