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