From 0e1d0b370f6d1728386fec64ea02ce01bf715e18 Mon Sep 17 00:00:00 2001 From: Helmut Schaa Date: Wed, 23 Oct 2013 00:15:57 +0300 Subject: [PATCH] hostapd: Don't get stuck after failed ACS If ACS fails we still need to call hostapd_setup_interface_complete. Otherwise hostapd will just hang doing nothing anymore. However, pass an error to hostapd_setup_interface_complete to allow a graceful fail. Signed-hostap: Helmut Schaa --- src/ap/hw_features.c | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/src/ap/hw_features.c b/src/ap/hw_features.c index 9e5becc3d..ce62b83b3 100644 --- a/src/ap/hw_features.c +++ b/src/ap/hw_features.c @@ -760,7 +760,7 @@ static void hostapd_notify_bad_chans(struct hostapd_iface *iface) int hostapd_acs_completed(struct hostapd_iface *iface) { - int ret; + int ret = -1; switch (hostapd_check_chans(iface)) { case HOSTAPD_CHAN_VALID: @@ -768,23 +768,25 @@ int hostapd_acs_completed(struct hostapd_iface *iface) case HOSTAPD_CHAN_ACS: wpa_printf(MSG_ERROR, "ACS error - reported complete, but no result available"); hostapd_notify_bad_chans(iface); - return -1; + goto out; case HOSTAPD_CHAN_INVALID: default: wpa_printf(MSG_ERROR, "ACS picked unusable channels"); hostapd_notify_bad_chans(iface); - return -1; + goto out; } ret = hostapd_check_ht_capab(iface); if (ret < 0) - return -1; + goto out; if (ret == 1) { wpa_printf(MSG_DEBUG, "Interface initialization will be completed in a callback"); return 0; } - return hostapd_setup_interface_complete(iface, 0); + ret = 0; +out: + return hostapd_setup_interface_complete(iface, ret); }