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