2 # Copyright (c) 2013-2015, Jouni Malinen <j@w1.fi>
4 # This software may be distributed under the terms of the BSD license.
5 # See README for more details.
8 logger = logging.getLogger()
14 from utils import alloc_fail
16 def connect_ibss_cmd(dev, id, freq=2412):
18 dev.select_network(id, freq=str(freq))
20 def wait_ibss_connection(dev):
21 logger.info(dev.ifname + " waiting for IBSS start/join to complete")
22 ev = dev.wait_connected(timeout=20,
23 error="Connection to the IBSS timed out")
24 exp = r'<.>(CTRL-EVENT-CONNECTED) - Connection to ([0-9a-f:]*) completed.*'
30 def wait_4way_handshake(dev1, dev2):
31 logger.info(dev1.ifname + " waiting for 4-way handshake completion with " + dev2.ifname + " " + dev2.p2p_interface_addr())
32 ev = dev1.wait_event(["IBSS-RSN-COMPLETED " + dev2.p2p_interface_addr()],
35 raise Exception("4-way handshake in IBSS timed out")
37 def wait_4way_handshake2(dev1, dev2, dev3):
38 logger.info(dev1.ifname + " waiting for 4-way handshake completion with " + dev2.ifname + " " + dev2.p2p_interface_addr() + " and " + dev3.p2p_interface_addr())
39 ev = dev1.wait_event(["IBSS-RSN-COMPLETED " + dev2.p2p_interface_addr(),
40 "IBSS-RSN-COMPLETED " + dev3.p2p_interface_addr()],
43 raise Exception("4-way handshake in IBSS timed out")
44 ev = dev1.wait_event(["IBSS-RSN-COMPLETED " + dev2.p2p_interface_addr(),
45 "IBSS-RSN-COMPLETED " + dev3.p2p_interface_addr()],
48 raise Exception("4-way handshake in IBSS timed out")
50 def add_ibss(dev, ssid, psk=None, proto=None, key_mgmt=None, pairwise=None,
51 group=None, beacon_int=None, bssid=None, scan_freq=None,
52 wep_key0=None, freq=2412):
53 id = dev.add_network()
54 dev.set_network(id, "mode", "1")
55 dev.set_network(id, "frequency", str(freq))
57 dev.set_network(id, "scan_freq", str(scan_freq))
58 dev.set_network_quoted(id, "ssid", ssid)
60 dev.set_network_quoted(id, "psk", psk)
62 dev.set_network(id, "proto", proto)
64 dev.set_network(id, "key_mgmt", key_mgmt)
66 dev.set_network(id, "pairwise", pairwise)
68 dev.set_network(id, "group", group)
70 dev.set_network(id, "beacon_int", beacon_int)
72 dev.set_network(id, "bssid", bssid)
74 dev.set_network(id, "wep_key0", wep_key0)
75 dev.request("ENABLE_NETWORK " + str(id) + " no-connect")
78 def add_ibss_rsn(dev, ssid):
79 return add_ibss(dev, ssid, "12345678", "RSN", "WPA-PSK", "CCMP", "CCMP")
81 def add_ibss_rsn_tkip(dev, ssid):
82 return add_ibss(dev, ssid, "12345678", "RSN", "WPA-PSK", "TKIP", "TKIP")
84 def add_ibss_wpa_none(dev, ssid):
85 return add_ibss(dev, ssid, "12345678", "WPA", "WPA-NONE", "TKIP", "TKIP")
87 def add_ibss_wpa_none_ccmp(dev, ssid):
88 return add_ibss(dev, ssid, "12345678", "WPA", "WPA-NONE", "CCMP", "CCMP")
90 def test_ibss_rsn(dev):
94 logger.info("Start IBSS on the first STA")
95 id = add_ibss_rsn(dev[0], ssid)
96 connect_ibss_cmd(dev[0], id)
97 bssid0 = wait_ibss_connection(dev[0])
99 logger.info("Join two STAs to the IBSS")
101 id = add_ibss_rsn(dev[1], ssid)
102 connect_ibss_cmd(dev[1], id)
103 bssid1 = wait_ibss_connection(dev[1])
105 logger.info("STA0 BSSID " + bssid0 + " differs from STA1 BSSID " + bssid1)
106 # try to merge with a scan
108 wait_4way_handshake(dev[0], dev[1])
109 wait_4way_handshake(dev[1], dev[0])
111 id = add_ibss_rsn(dev[2], ssid)
112 connect_ibss_cmd(dev[2], id)
113 bssid2 = wait_ibss_connection(dev[2])
115 logger.info("STA0 BSSID " + bssid0 + " differs from STA2 BSSID " + bssid2)
116 # try to merge with a scan
118 wait_4way_handshake(dev[0], dev[2])
119 wait_4way_handshake2(dev[2], dev[0], dev[1])
121 # Allow some time for all peers to complete key setup
123 hwsim_utils.test_connectivity(dev[0], dev[1])
124 hwsim_utils.test_connectivity(dev[0], dev[2])
125 hwsim_utils.test_connectivity(dev[1], dev[2])
127 dev[1].request("REMOVE_NETWORK all")
129 id = add_ibss_rsn(dev[1], ssid)
130 connect_ibss_cmd(dev[1], id)
131 bssid1 = wait_ibss_connection(dev[1])
133 logger.info("STA0 BSSID " + bssid0 + " differs from STA1 BSSID " + bssid1)
134 # try to merge with a scan
136 wait_4way_handshake(dev[0], dev[1])
137 wait_4way_handshake(dev[1], dev[0])
139 hwsim_utils.test_connectivity(dev[0], dev[1])
141 if "OK" not in dev[0].request("IBSS_RSN " + dev[1].p2p_interface_addr()):
142 raise Exception("IBSS_RSN command failed")
144 def test_ibss_wpa_none(dev):
148 logger.info("Start IBSS on the first STA")
149 id = add_ibss_wpa_none(dev[0], ssid)
150 connect_ibss_cmd(dev[0], id)
151 bssid0 = wait_ibss_connection(dev[0])
153 # This is a bit ugly, but no one really cares about WPA-None, so there may
154 # not be enough justification to clean this up.. For now, wpa_supplicant
155 # will show two connection events with mac80211_hwsim where the first one
156 # comes with all zeros address.
157 if bssid0 == "00:00:00:00:00:00":
158 logger.info("Waiting for real BSSID on the first STA")
159 bssid0 = wait_ibss_connection(dev[0])
161 logger.info("Join two STAs to the IBSS")
163 id = add_ibss_wpa_none(dev[1], ssid)
164 connect_ibss_cmd(dev[1], id)
165 id = add_ibss_wpa_none(dev[2], ssid)
166 connect_ibss_cmd(dev[2], id)
168 bssid1 = wait_ibss_connection(dev[1])
170 logger.info("STA0 BSSID " + bssid0 + " differs from STA1 BSSID " + bssid1)
171 bssid1 = wait_ibss_connection(dev[1])
173 bssid2 = wait_ibss_connection(dev[2])
175 logger.info("STA0 BSSID " + bssid0 + " differs from STA2 BSSID " + bssid2)
176 bssid2 = wait_ibss_connection(dev[2])
178 logger.info("bssid0=%s bssid1=%s bssid2=%s" % (bssid0, bssid1, bssid2))
180 bss = dev[0].get_bss(bssid0)
182 bss = dev[1].get_bss(bssid1)
184 raise Exception("Could not find BSS entry for IBSS")
185 if 'flags' not in bss:
186 raise Exception("Could not get BSS flags from BSS table")
187 if "[WPA-None-TKIP]" not in bss['flags']:
188 raise Exception("Unexpected BSS flags: " + bss['flags'])
190 # Allow some time for all peers to complete key setup
193 # This is supposed to work, but looks like WPA-None does not work with
194 # mac80211 currently..
196 hwsim_utils.test_connectivity(dev[0], dev[1])
198 logger.info("Ignoring known connectivity failure: " + str(e))
200 hwsim_utils.test_connectivity(dev[0], dev[2])
202 logger.info("Ignoring known connectivity failure: " + str(e))
204 hwsim_utils.test_connectivity(dev[1], dev[2])
206 logger.info("Ignoring known connectivity failure: " + str(e))
208 def test_ibss_wpa_none_ccmp(dev):
209 """IBSS WPA-None/CCMP"""
212 logger.info("Start IBSS on the first STA")
213 id = add_ibss_wpa_none(dev[0], ssid)
214 connect_ibss_cmd(dev[0], id)
215 bssid0 = wait_ibss_connection(dev[0])
217 # This is a bit ugly, but no one really cares about WPA-None, so there may
218 # not be enough justification to clean this up.. For now, wpa_supplicant
219 # will show two connection events with mac80211_hwsim where the first one
220 # comes with all zeros address.
221 if bssid0 == "00:00:00:00:00:00":
222 logger.info("Waiting for real BSSID on the first STA")
223 bssid0 = wait_ibss_connection(dev[0])
226 logger.info("Join a STA to the IBSS")
227 id = add_ibss_wpa_none(dev[1], ssid)
228 connect_ibss_cmd(dev[1], id)
230 bssid1 = wait_ibss_connection(dev[1])
232 logger.info("STA0 BSSID " + bssid0 + " differs from STA1 BSSID " + bssid1)
233 bssid1 = wait_ibss_connection(dev[1])
235 logger.info("bssid0=%s bssid1=%s" % (bssid0, bssid1))
237 # Allow some time for all peers to complete key setup
240 # This is supposed to work, but looks like WPA-None does not work with
241 # mac80211 currently..
243 hwsim_utils.test_connectivity(dev[0], dev[1])
245 logger.info("Ignoring known connectivity failure: " + str(e))
247 def test_ibss_open(dev):
248 """IBSS open (no security)"""
250 id = add_ibss(dev[0], ssid, key_mgmt="NONE", beacon_int="150")
251 connect_ibss_cmd(dev[0], id)
252 bssid0 = wait_ibss_connection(dev[0])
254 id = add_ibss(dev[1], ssid, key_mgmt="NONE", beacon_int="200")
255 connect_ibss_cmd(dev[1], id)
256 bssid1 = wait_ibss_connection(dev[1])
258 logger.info("STA0 BSSID " + bssid0 + " differs from STA1 BSSID " + bssid1)
260 res = dev[0].request("SCAN_RESULTS")
261 if "[IBSS]" not in res:
262 res = dev[1].request("SCAN_RESULTS")
263 if "[IBSS]" not in res:
264 raise Exception("IBSS flag missing from scan results: " + res)
265 bss = dev[0].get_bss(bssid0)
267 bss = dev[1].get_bss(bssid1)
269 raise Exception("Could not find BSS entry for IBSS")
270 if 'flags' not in bss:
271 raise Exception("Could not get BSS flags from BSS table")
272 if "[IBSS]" not in bss['flags']:
273 raise Exception("Unexpected BSS flags: " + bss['flags'])
275 def test_ibss_open_fixed_bssid(dev):
276 """IBSS open (no security) and fixed BSSID"""
278 bssid="02:11:22:33:44:55"
280 dev[0].request("AP_SCAN 2")
281 add_ibss(dev[0], ssid, key_mgmt="NONE", bssid=bssid, beacon_int="150")
282 dev[0].request("REASSOCIATE")
284 dev[1].request("AP_SCAN 2")
285 add_ibss(dev[1], ssid, key_mgmt="NONE", bssid=bssid, beacon_int="200")
286 dev[1].request("REASSOCIATE")
288 bssid0 = wait_ibss_connection(dev[0])
289 bssid1 = wait_ibss_connection(dev[1])
291 raise Exception("STA0 BSSID " + bssid0 + " differs from fixed BSSID " + bssid)
293 raise Exception("STA0 BSSID " + bssid0 + " differs from fixed BSSID " + bssid)
295 dev[0].request("AP_SCAN 1")
296 dev[1].request("AP_SCAN 1")
298 def test_ibss_open_retry(dev):
299 """IBSS open (no security) with cfg80211 retry workaround"""
300 subprocess.check_call(['iw', 'dev', dev[0].ifname, 'set', 'type', 'adhoc'])
301 subprocess.check_call(['iw', 'dev', dev[0].ifname, 'ibss', 'join',
302 'ibss-test', '2412', 'HT20', 'fixed-freq',
303 '02:22:33:44:55:66'])
306 dev[0].request("AP_SCAN 2")
307 id = add_ibss(dev[0], ssid, key_mgmt="NONE", beacon_int="150",
308 bssid="02:33:44:55:66:77", scan_freq=2412)
309 #connect_ibss_cmd(dev[0], id)
310 dev[0].request("REASSOCIATE")
311 bssid0 = wait_ibss_connection(dev[0])
313 subprocess.check_call(['iw', 'dev', dev[0].ifname, 'ibss', 'leave'])
315 dev[0].request("DISCONNECT")
317 dev[0].request("AP_SCAN 1")
319 def test_ibss_rsn_tkip(dev):
320 """IBSS RSN with TKIP as the cipher"""
323 id = add_ibss_rsn_tkip(dev[0], ssid)
324 connect_ibss_cmd(dev[0], id)
325 bssid0 = wait_ibss_connection(dev[0])
327 id = add_ibss_rsn_tkip(dev[1], ssid)
328 connect_ibss_cmd(dev[1], id)
329 bssid1 = wait_ibss_connection(dev[1])
331 logger.info("STA0 BSSID " + bssid0 + " differs from STA1 BSSID " + bssid1)
332 # try to merge with a scan
334 wait_4way_handshake(dev[0], dev[1])
335 wait_4way_handshake(dev[1], dev[0])
337 def test_ibss_wep(dev):
341 id = add_ibss(dev[0], ssid, key_mgmt="NONE", wep_key0='"hello"')
342 connect_ibss_cmd(dev[0], id)
343 bssid0 = wait_ibss_connection(dev[0])
345 id = add_ibss(dev[1], ssid, key_mgmt="NONE", wep_key0='"hello"')
346 connect_ibss_cmd(dev[1], id)
347 bssid1 = wait_ibss_connection(dev[1])
349 def test_ibss_rsn_error_case(dev):
350 """IBSS RSN regression test for IBSS_RSN prior IBSS setup"""
351 if "FAIL" not in dev[0].request("IBSS_RSN 02:03:04:05:06:07"):
352 raise Exception("Unexpected IBSS_RSN result")
354 def test_ibss_5ghz(dev):
355 """IBSS on 5 GHz band"""
359 subprocess.call(['iw', 'reg', 'set', '00'])
360 dev[0].flush_scan_cache()
361 dev[1].flush_scan_cache()
363 def _test_ibss_5ghz(dev):
364 subprocess.call(['iw', 'reg', 'set', 'US'])
367 ev = dev[i].wait_event(["CTRL-EVENT-REGDOM-CHANGE"], timeout=5)
369 raise Exception("No regdom change event")
370 if "alpha2=US" in ev:
372 dev[i].dump_monitor()
375 id = add_ibss(dev[0], ssid, key_mgmt="NONE", beacon_int="150", freq=5180)
376 connect_ibss_cmd(dev[0], id, freq=5180)
377 bssid0 = wait_ibss_connection(dev[0])
379 dev[1].scan_for_bss(bssid0, freq=5180)
380 id = add_ibss(dev[1], ssid, key_mgmt="NONE", beacon_int="200", freq=5180)
381 connect_ibss_cmd(dev[1], id, freq=5180)
382 bssid1 = wait_ibss_connection(dev[1])
384 logger.info("STA0 BSSID " + bssid0 + " differs from STA1 BSSID " + bssid1)
386 dev[0].request("DISCONNECT")
387 dev[1].request("DISCONNECT")
388 dev[0].dump_monitor()
389 dev[1].dump_monitor()
391 def test_ibss_rsn_oom(dev):
392 """IBSS RSN OOM during wpa_init"""
393 with alloc_fail(dev[0], 1, "wpa_init"):
395 id = add_ibss_rsn(dev[0], ssid)
396 connect_ibss_cmd(dev[0], id)
397 bssid0 = wait_ibss_connection(dev[0])