准备工作
1.系统先要安装 libssl-dev,libnl-dev
2.make & sudo make install
3.标准wpa_supplicant调用过程非常复杂,为了看清函数间的调用关系,对源代码进行了如下修改:
在wpa_debug.h文件中,对wpa_printf进行了重新的定义(将原来的wpa_printf改名为wpa_printf_manfeel)以便能够看清调用的文件、行数和具体的函数
// ============== manfeel ====================
#define HELP printf("[%s(%d) => %s]\n",__FILE__,__LINE__,__FUNCTION__)
#define wpa_printf(args...) do { HELP;wpa_printf_manfeel(args); } while(0)
#define wpa_dbg(args...) do { HELP;wpa_msg_manfeel(args); } while(0)
#define wpa_msg(args...) do { HELP;wpa_msg_manfeel(args); } while(0)
#ifdef CONFIG_NO_STDOUT_DEBUG
/*
#define wpa_debug_print_timestamp() do { } while (0)
#define wpa_printf(args...) do { } while (0)
#define wpa_hexdump(l,t,b,le) do { } while (0)
#define wpa_hexdump_buf(l,t,b) do { } while (0)
#define wpa_hexdump_key(l,t,b,le) do { } while (0)
#define wpa_hexdump_buf_key(l,t,b) do { } while (0)
#define wpa_hexdump_ascii(l,t,b,le) do { } while (0)
#define wpa_hexdump_ascii_key(l,t,b,le) do { } while (0)
#define wpa_debug_open_file(p) do { } while (0)
#define wpa_debug_close_file() do { } while (0)
#define wpa_dbg(args...) do { } while (0)
*/
同时,还要在src/crypto/random.c头部加入:
#define wpa_printf(args...) do { printf("[%s(%d) => %s]\n",__FILE__,__LINE__,__FUNCTION__);wpa_printf_manfeel(args); } while(0)
extern void wpa_printf_manfeel(int level, const char *fmt, ...)
PRINTF_FORMAT(2, 3);
还要修改wpa_debug.c文件
// modified to show all msg!
int wpa_debug_level = MSG_EXCESSIVE;
好,准备工作做完,开始分析代码!
需要用到ethereal封包捕捉工具。
运行:sudo wpa_supplicant -Dwired -ieth0 -c/etc/wpa_supplicant1.conf
wpa_supplicant1.conf文件格式如下:
ctrl_interface=/var/run/wpa_supplicant
ap_scan=0
fast_reauth=1
network={
key_mgmt=IEEE8021X
eap=MD5
identity="2013841110014"
password="password"
eapol_flags=0
}
[wpas_glue.c(177) => wpa_supplicant_eapol_send]
TX EAPOL: dst=01:80:c2:00:00:03
TX EAPOL - hexdump_ascii(len=22):
01 00 00 12 02 01 00 12 01 32 30 31 33 38 34 31 _________2013841
31 31 30 30 31 34 110014