]> git.ipfire.org Git - thirdparty/hostap.git/blame - wlantest/wlantest.h
tests: Make WPS test cases more robust
[thirdparty/hostap.git] / wlantest / wlantest.h
CommitLineData
a149fcc7
JM
1/*
2 * wlantest - IEEE 802.11 protocol monitoring and testing tool
c99a721e 3 * Copyright (c) 2010-2013, Jouni Malinen <j@w1.fi>
a149fcc7 4 *
0f3d578e
JM
5 * This software may be distributed under the terms of the BSD license.
6 * See README for more details.
a149fcc7
JM
7 */
8
9#ifndef WLANTEST_H
10#define WLANTEST_H
11
d84d3893 12#include "utils/list.h"
53650bca 13#include "common/wpa_common.h"
6d5ce9fc 14#include "wlantest_ctrl.h"
d84d3893 15
b50111fb 16struct ieee802_11_elems;
d06df64d 17struct radius_msg;
d318c534 18struct ieee80211_hdr;
327f7160 19struct wlantest_bss;
b50111fb 20
d06df64d
JM
21#define MAX_RADIUS_SECRET_LEN 128
22
23struct wlantest_radius_secret {
24 struct dl_list list;
25 char secret[MAX_RADIUS_SECRET_LEN];
26};
d84d3893 27
53650bca
JM
28struct wlantest_passphrase {
29 struct dl_list list;
30 char passphrase[64];
31 u8 ssid[32];
32 size_t ssid_len;
33 u8 bssid[ETH_ALEN];
34};
35
36struct wlantest_pmk {
37 struct dl_list list;
38 u8 pmk[32];
39};
40
a0530dff
JM
41struct wlantest_ptk {
42 struct dl_list list;
43 struct wpa_ptk ptk;
44 size_t ptk_len;
45};
46
2e479416
JM
47struct wlantest_wep {
48 struct dl_list list;
49 size_t key_len;
50 u8 key[13];
51};
52
422ef7d2
JM
53struct wlantest_sta {
54 struct dl_list list;
327f7160 55 struct wlantest_bss *bss;
422ef7d2 56 u8 addr[ETH_ALEN];
d30edf54
JM
57 enum {
58 STATE1 /* not authenticated */,
59 STATE2 /* authenticated */,
60 STATE3 /* associated */
61 } state;
62 u16 aid;
021a6fe4 63 u8 rsnie[257]; /* WPA/RSN IE */
327f7160
JM
64 int proto;
65 int pairwise_cipher;
66 int group_cipher;
67 int key_mgmt;
68 int rsn_capab;
53650bca
JM
69 u8 anonce[32]; /* ANonce from the previous EAPOL-Key msg 1/4 or 3/4 */
70 u8 snonce[32]; /* SNonce from the previous EAPOL-Key msg 2/4 */
71 struct wpa_ptk ptk; /* Derived PTK */
72 int ptk_set;
d0b251d2
JM
73 struct wpa_ptk tptk; /* Derived PTK during rekeying */
74 int tptk_set;
47fe6880
JM
75 u8 rsc_tods[16 + 1][6];
76 u8 rsc_fromds[16 + 1][6];
0819b65b
JM
77 u8 ap_sa_query_tr[2];
78 u8 sta_sa_query_tr[2];
6d5ce9fc 79 u32 counters[NUM_WLANTEST_STA_COUNTER];
990153b4
JM
80 u16 assocreq_capab_info;
81 u16 assocreq_listen_int;
82 u8 *assocreq_ies;
83 size_t assocreq_ies_len;
ee3b84be
JM
84
85 /* Last ICMP Echo request information */
86 u32 icmp_echo_req_src;
87 u32 icmp_echo_req_dst;
88 u16 icmp_echo_req_id;
89 u16 icmp_echo_req_seq;
a912dd16
JM
90
91 le16 seq_ctrl_to_sta[17];
92 le16 seq_ctrl_to_ap[17];
7e7a57ae
JM
93
94 int pwrmgt;
95 int pspoll;
fd848ab9
JM
96
97 u8 gtk[32];
98 size_t gtk_len;
99 int gtk_idx;
99d7c1de
JM
100
101 u32 tx_tid[16 + 1];
102 u32 rx_tid[16 + 1];
422ef7d2
JM
103};
104
b39f5834
JM
105struct wlantest_tdls {
106 struct dl_list list;
107 struct wlantest_sta *init;
108 struct wlantest_sta *resp;
109 struct tpk {
110 u8 kck[16];
111 u8 tk[16];
112 } tpk;
113 int link_up;
29ec7457 114 u8 dialog_token;
b39f5834
JM
115 u8 rsc_init[16 + 1][6];
116 u8 rsc_resp[16 + 1][6];
0e42fff3 117 u32 counters[NUM_WLANTEST_TDLS_COUNTER];
4ac800db
JM
118 u8 inonce[32];
119 u8 rnonce[32];
b39f5834
JM
120};
121
d84d3893
JM
122struct wlantest_bss {
123 struct dl_list list;
124 u8 bssid[ETH_ALEN];
125 u16 capab_info;
2e479416 126 u16 prev_capab_info;
d84d3893
JM
127 u8 ssid[32];
128 size_t ssid_len;
129 int proberesp_seen;
130 int parse_error_reported;
131 u8 wpaie[257];
132 u8 rsnie[257];
327f7160
JM
133 int proto;
134 int pairwise_cipher;
135 int group_cipher;
136 int mgmt_group_cipher;
137 int key_mgmt;
138 int rsn_capab;
422ef7d2 139 struct dl_list sta; /* struct wlantest_sta */
53650bca 140 struct dl_list pmk; /* struct wlantest_pmk */
4d9f9ee7
JM
141 u8 gtk[4][32];
142 size_t gtk_len[4];
2e4c3469 143 int gtk_idx;
2edd5c23 144 u8 rsc[4][6];
4d9f9ee7
JM
145 u8 igtk[6][16];
146 int igtk_set[6];
2e4c3469 147 int igtk_idx;
bacc3128 148 u8 ipn[6][6];
6d5ce9fc 149 u32 counters[NUM_WLANTEST_BSS_COUNTER];
b39f5834 150 struct dl_list tdls; /* struct wlantest_tdls */
d84d3893
JM
151};
152
d06df64d
JM
153struct wlantest_radius {
154 struct dl_list list;
155 u32 srv;
156 u32 cli;
157 struct radius_msg *last_req;
158};
159
644fb8c8
JM
160
161#define MAX_CTRL_CONNECTIONS 10
ba2beacc 162#define MAX_NOTES 10
644fb8c8 163
a149fcc7
JM
164struct wlantest {
165 int monitor_sock;
3215df77 166 int monitor_wired;
a149fcc7 167
644fb8c8
JM
168 int ctrl_sock;
169 int ctrl_socks[MAX_CTRL_CONNECTIONS];
170
53650bca 171 struct dl_list passphrase; /* struct wlantest_passphrase */
d84d3893 172 struct dl_list bss; /* struct wlantest_bss */
d06df64d
JM
173 struct dl_list secret; /* struct wlantest_radius_secret */
174 struct dl_list radius; /* struct wlantest_radius */
175 struct dl_list pmk; /* struct wlantest_pmk */
a0530dff 176 struct dl_list ptk; /* struct wlantest_ptk */
2e479416 177 struct dl_list wep; /* struct wlantest_wep */
d84d3893 178
a149fcc7
JM
179 unsigned int rx_mgmt;
180 unsigned int rx_ctrl;
181 unsigned int rx_data;
182 unsigned int fcs_error;
64f45d07
JM
183
184 void *write_pcap; /* pcap_t* */
185 void *write_pcap_dumper; /* pcpa_dumper_t */
186 struct timeval write_pcap_time;
ba2beacc
JM
187 u8 *decrypted;
188 size_t decrypted_len;
189 FILE *pcapng;
190 u32 write_pcapng_time_high;
191 u32 write_pcapng_time_low;
fb8f5fc6
JM
192
193 u8 last_hdr[30];
194 size_t last_len;
195 int last_mgmt_valid;
25315176
JM
196
197 unsigned int assume_fcs:1;
ba2beacc
JM
198
199 char *notes[MAX_NOTES];
200 size_t num_notes;
c99a721e
JM
201
202 const char *write_file;
203 const char *pcapng_file;
a149fcc7
JM
204};
205
ba2beacc
JM
206void add_note(struct wlantest *wt, int level, const char *fmt, ...)
207PRINTF_FORMAT(3, 4);
208void clear_notes(struct wlantest *wt);
209size_t notes_len(struct wlantest *wt, size_t hdrlen);
210
9a994178 211int add_wep(struct wlantest *wt, const char *key);
a149fcc7 212int read_cap_file(struct wlantest *wt, const char *fname);
3215df77 213int read_wired_cap_file(struct wlantest *wt, const char *fname);
ba2beacc 214
64f45d07
JM
215int write_pcap_init(struct wlantest *wt, const char *fname);
216void write_pcap_deinit(struct wlantest *wt);
217void write_pcap_captured(struct wlantest *wt, const u8 *buf, size_t len);
218void write_pcap_decrypted(struct wlantest *wt, const u8 *buf1, size_t len1,
219 const u8 *buf2, size_t len2);
ba2beacc
JM
220
221int write_pcapng_init(struct wlantest *wt, const char *fname);
222void write_pcapng_deinit(struct wlantest *wt);
223struct pcap_pkthdr;
224void write_pcapng_write_read(struct wlantest *wt, int dlt,
225 struct pcap_pkthdr *hdr, const u8 *data);
226void write_pcapng_captured(struct wlantest *wt, const u8 *buf, size_t len);
227
a149fcc7 228void wlantest_process(struct wlantest *wt, const u8 *data, size_t len);
350132be 229void wlantest_process_prism(struct wlantest *wt, const u8 *data, size_t len);
0f3e4f2a 230void wlantest_process_80211(struct wlantest *wt, const u8 *data, size_t len);
3215df77 231void wlantest_process_wired(struct wlantest *wt, const u8 *data, size_t len);
a149fcc7
JM
232u32 crc32(const u8 *frame, size_t frame_len);
233int monitor_init(struct wlantest *wt, const char *ifname);
3215df77 234int monitor_init_wired(struct wlantest *wt, const char *ifname);
a149fcc7 235void monitor_deinit(struct wlantest *wt);
2d73f0a8 236void rx_mgmt(struct wlantest *wt, const u8 *data, size_t len);
fb8f5fc6 237void rx_mgmt_ack(struct wlantest *wt, const struct ieee80211_hdr *hdr);
2d73f0a8 238void rx_data(struct wlantest *wt, const u8 *data, size_t len);
161d0339
JM
239void rx_data_eapol(struct wlantest *wt, const u8 *dst, const u8 *src,
240 const u8 *data, size_t len, int prot);
ee3b84be 241void rx_data_ip(struct wlantest *wt, const u8 *bssid, const u8 *sta_addr,
244c9303
JM
242 const u8 *dst, const u8 *src, const u8 *data, size_t len,
243 const u8 *peer_addr);
b39f5834
JM
244void rx_data_80211_encap(struct wlantest *wt, const u8 *bssid,
245 const u8 *sta_addr, const u8 *dst, const u8 *src,
246 const u8 *data, size_t len);
a149fcc7 247
57f7d03f 248struct wlantest_bss * bss_find(struct wlantest *wt, const u8 *bssid);
d84d3893
JM
249struct wlantest_bss * bss_get(struct wlantest *wt, const u8 *bssid);
250void bss_deinit(struct wlantest_bss *bss);
53650bca
JM
251void bss_update(struct wlantest *wt, struct wlantest_bss *bss,
252 struct ieee802_11_elems *elems);
d356bd63 253void bss_flush(struct wlantest *wt);
221519de
JM
254int bss_add_pmk_from_passphrase(struct wlantest_bss *bss,
255 const char *passphrase);
d06df64d 256void pmk_deinit(struct wlantest_pmk *pmk);
0d2e395d 257void tdls_deinit(struct wlantest_tdls *tdls);
d84d3893 258
57f7d03f 259struct wlantest_sta * sta_find(struct wlantest_bss *bss, const u8 *addr);
422ef7d2
JM
260struct wlantest_sta * sta_get(struct wlantest_bss *bss, const u8 *addr);
261void sta_deinit(struct wlantest_sta *sta);
021a6fe4
JM
262void sta_update_assoc(struct wlantest_sta *sta,
263 struct ieee802_11_elems *elems);
422ef7d2 264
d318c534
JM
265u8 * ccmp_decrypt(const u8 *tk, const struct ieee80211_hdr *hdr,
266 const u8 *data, size_t data_len, size_t *decrypted_len);
571ab37b
JM
267u8 * ccmp_encrypt(const u8 *tk, u8 *frame, size_t len, size_t hdrlen, u8 *qos,
268 u8 *pn, int keyid, size_t *encrypted_len);
2edd5c23 269void ccmp_get_pn(u8 *pn, const u8 *data);
7d19d3e9
JM
270u8 * ccmp_256_decrypt(const u8 *tk, const struct ieee80211_hdr *hdr,
271 const u8 *data, size_t data_len, size_t *decrypted_len);
272u8 * ccmp_256_encrypt(const u8 *tk, u8 *frame, size_t len, size_t hdrlen,
273 u8 *qos, u8 *pn, int keyid, size_t *encrypted_len);
d318c534 274
2924b0eb
JM
275u8 * tkip_decrypt(const u8 *tk, const struct ieee80211_hdr *hdr,
276 const u8 *data, size_t data_len, size_t *decrypted_len);
571ab37b
JM
277u8 * tkip_encrypt(const u8 *tk, u8 *frame, size_t len, size_t hdrlen, u8 *qos,
278 u8 *pn, int keyid, size_t *encrypted_len);
4dac8453 279void tkip_get_pn(u8 *pn, const u8 *data);
2924b0eb 280
2e479416
JM
281u8 * wep_decrypt(struct wlantest *wt, const struct ieee80211_hdr *hdr,
282 const u8 *data, size_t data_len, size_t *decrypted_len);
283
a9eae7ef
JM
284u8 * bip_protect(const u8 *igtk, u8 *frame, size_t len, u8 *ipn, int keyid,
285 size_t *prot_len);
e88f0901
JM
286u8 * bip_gmac_protect(const u8 *igtk, size_t igtk_len, u8 *frame, size_t len,
287 u8 *ipn, int keyid, size_t *prot_len);
a9eae7ef 288
f1732956 289u8 * gcmp_decrypt(const u8 *tk, size_t tk_len, const struct ieee80211_hdr *hdr,
455bcc0f 290 const u8 *data, size_t data_len, size_t *decrypted_len);
f1732956
JM
291u8 * gcmp_encrypt(const u8 *tk, size_t tk_len, u8 *frame, size_t len,
292 size_t hdrlen, u8 *qos,
455bcc0f
JM
293 u8 *pn, int keyid, size_t *encrypted_len);
294
644fb8c8
JM
295int ctrl_init(struct wlantest *wt);
296void ctrl_deinit(struct wlantest *wt);
297
7d23e971
JM
298int wlantest_inject(struct wlantest *wt, struct wlantest_bss *bss,
299 struct wlantest_sta *sta, u8 *frame, size_t len,
300 enum wlantest_inject_protection prot);
301
c99a721e
JM
302int wlantest_relog(struct wlantest *wt);
303
a149fcc7 304#endif /* WLANTEST_H */