mirror of
https://github.com/vanhoefm/fragattacks.git
synced 2025-01-18 02:44:03 -05:00
tests: Fix OOM eloop_register_sock() test cases with new gcc
gcc 4.8 vs 5.2 seem to compile eloop_register_sock() differently. With 5.2, that function name does not show up in the backtrace since eloop_sock_table_add_sock() is used without a separate function call. This broke the memory allocation failure checking in this test case. Fix this by matching against the eloop_sock_table_add_sock() function which shows up in the backtrace for both gcc versions. Signed-off-by: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
d36ae37679
commit
9b35afd6ac
@ -217,7 +217,7 @@ def test_ap_open_out_of_memory(dev, apdev):
|
|||||||
hapd_out_of_mem(hapd, apdev[1], i, "=wpa_driver_nl80211_drv_init")
|
hapd_out_of_mem(hapd, apdev[1], i, "=wpa_driver_nl80211_drv_init")
|
||||||
|
|
||||||
# eloop_register_read_sock() call from i802_init()
|
# eloop_register_read_sock() call from i802_init()
|
||||||
hapd_out_of_mem(hapd, apdev[1], 1, "eloop_sock_table_add_sock;eloop_register_sock;?eloop_register_read_sock;=i802_init")
|
hapd_out_of_mem(hapd, apdev[1], 1, "eloop_sock_table_add_sock;?eloop_register_sock;?eloop_register_read_sock;=i802_init")
|
||||||
|
|
||||||
# verify that a new interface can still be added when memory allocation does
|
# verify that a new interface can still be added when memory allocation does
|
||||||
# not fail
|
# not fail
|
||||||
|
@ -3736,7 +3736,7 @@ def _test_ap_wps_er_init_oom(dev, apdev):
|
|||||||
with alloc_fail(dev[0], 2, "http_server_init"):
|
with alloc_fail(dev[0], 2, "http_server_init"):
|
||||||
if "FAIL" not in dev[0].request("WPS_ER_START ifname=lo"):
|
if "FAIL" not in dev[0].request("WPS_ER_START ifname=lo"):
|
||||||
raise Exception("WPS_ER_START succeeded during OOM")
|
raise Exception("WPS_ER_START succeeded during OOM")
|
||||||
with alloc_fail(dev[0], 1, "eloop_register_sock;wps_er_ssdp_init"):
|
with alloc_fail(dev[0], 1, "eloop_sock_table_add_sock;?eloop_register_sock;wps_er_ssdp_init"):
|
||||||
if "FAIL" not in dev[0].request("WPS_ER_START ifname=lo"):
|
if "FAIL" not in dev[0].request("WPS_ER_START ifname=lo"):
|
||||||
raise Exception("WPS_ER_START succeeded during OOM")
|
raise Exception("WPS_ER_START succeeded during OOM")
|
||||||
with fail_test(dev[0], 1, "os_get_random;wps_er_init"):
|
with fail_test(dev[0], 1, "os_get_random;wps_er_init"):
|
||||||
@ -4382,7 +4382,7 @@ RGV2aWNlIEEQSQAGADcqAAEg
|
|||||||
logger.info("OOM in HTTP server")
|
logger.info("OOM in HTTP server")
|
||||||
for func in [ "http_request_init", "httpread_create",
|
for func in [ "http_request_init", "httpread_create",
|
||||||
"eloop_register_timeout;httpread_create",
|
"eloop_register_timeout;httpread_create",
|
||||||
"eloop_register_sock;httpread_create",
|
"eloop_sock_table_add_sock;?eloop_register_sock;httpread_create",
|
||||||
"httpread_hdr_analyze" ]:
|
"httpread_hdr_analyze" ]:
|
||||||
with alloc_fail(dev[0], 1, func):
|
with alloc_fail(dev[0], 1, func):
|
||||||
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM,
|
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM,
|
||||||
@ -4552,7 +4552,7 @@ def _test_ap_wps_er_http_proto_subscribe_oom(dev, apdev):
|
|||||||
tests = [ (1, "http_client_url_parse"),
|
tests = [ (1, "http_client_url_parse"),
|
||||||
(1, "wpabuf_alloc;wps_er_subscribe"),
|
(1, "wpabuf_alloc;wps_er_subscribe"),
|
||||||
(1, "http_client_addr"),
|
(1, "http_client_addr"),
|
||||||
(1, "eloop_register_sock;http_client_addr"),
|
(1, "eloop_sock_table_add_sock;?eloop_register_sock;http_client_addr"),
|
||||||
(1, "eloop_register_timeout;http_client_addr") ]
|
(1, "eloop_register_timeout;http_client_addr") ]
|
||||||
for count,func in tests:
|
for count,func in tests:
|
||||||
with alloc_fail(dev[0], count, func):
|
with alloc_fail(dev[0], count, func):
|
||||||
|
Loading…
Reference in New Issue
Block a user