aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWitold Sowa <witold.sowa@gmail.com>2009-09-13 22:21:52 +0300
committerJouni Malinen <j@w1.fi>2009-09-13 22:21:52 +0300
commit3e53b314f5ec02fed61ecd6f4146d23c82c3a147 (patch)
treea490b1333bf77238c1f6fdf5b0fca7bd3e86ba1a
parent86b89452f6dd0540cc122daca4da415529c0c181 (diff)
downloadexternal_wpa_supplicant_8_ti-3e53b314f5ec02fed61ecd6f4146d23c82c3a147.zip
external_wpa_supplicant_8_ti-3e53b314f5ec02fed61ecd6f4146d23c82c3a147.tar.gz
external_wpa_supplicant_8_ti-3e53b314f5ec02fed61ecd6f4146d23c82c3a147.tar.bz2
Share same freeing and error checking code in get_scan_results
Convert wpa_supplicant_get_scan_results_old() to use the same return style with the other get_scan_results options and clean up the code by sharing the same scan result freeing and error checking code for all the options.
-rw-r--r--wpa_supplicant/wpa_supplicant.c47
1 files changed, 18 insertions, 29 deletions
diff --git a/wpa_supplicant/wpa_supplicant.c b/wpa_supplicant/wpa_supplicant.c
index fd2e321..df1d182 100644
--- a/wpa_supplicant/wpa_supplicant.c
+++ b/wpa_supplicant/wpa_supplicant.c
@@ -1545,7 +1545,8 @@ int wpa_supplicant_set_debug_params(struct wpa_global *global, int debug_level,
}
-static int wpa_supplicant_get_scan_results_old(struct wpa_supplicant *wpa_s)
+static struct wpa_scan_results * wpa_supplicant_get_scan_results_old(
+ struct wpa_supplicant *wpa_s)
{
#define SCAN_AP_LIMIT 128
struct wpa_scan_result *results;
@@ -1556,7 +1557,7 @@ static int wpa_supplicant_get_scan_results_old(struct wpa_supplicant *wpa_s)
if (results == NULL) {
wpa_printf(MSG_WARNING, "Failed to allocate memory for scan "
"results");
- return -1;
+ return NULL;
}
num = wpa_drv_get_scan_results(wpa_s, results, SCAN_AP_LIMIT);
@@ -1564,7 +1565,7 @@ static int wpa_supplicant_get_scan_results_old(struct wpa_supplicant *wpa_s)
if (num < 0) {
wpa_printf(MSG_DEBUG, "Failed to get scan results");
os_free(results);
- return -1;
+ return NULL;
}
if (num > SCAN_AP_LIMIT) {
wpa_printf(MSG_INFO, "Not enough room for all APs (%d < %d)",
@@ -1572,20 +1573,17 @@ static int wpa_supplicant_get_scan_results_old(struct wpa_supplicant *wpa_s)
num = SCAN_AP_LIMIT;
}
- wpa_scan_results_free(wpa_s->scan_res);
- wpa_s->scan_res = NULL;
-
/* Convert old scan result data structure to the new one */
res = os_zalloc(sizeof(*res));
if (res == NULL) {
os_free(results);
- return -1;
+ return NULL;
}
res->res = os_zalloc(num * sizeof(struct wpa_scan_res *));
if (res->res == NULL) {
os_free(results);
os_free(res);
- return -1;
+ return NULL;
}
for (i = 0; i < num; i++) {
@@ -1647,9 +1645,8 @@ static int wpa_supplicant_get_scan_results_old(struct wpa_supplicant *wpa_s)
}
os_free(results);
- wpa_s->scan_res = res;
- return 0;
+ return res;
}
@@ -1665,28 +1662,20 @@ int wpa_supplicant_get_scan_results(struct wpa_supplicant *wpa_s)
{
int ret;
- if (wpa_s->drv_flags & WPA_DRIVER_FLAGS_USER_SPACE_MLME) {
- wpa_scan_results_free(wpa_s->scan_res);
+ wpa_scan_results_free(wpa_s->scan_res);
+ if (wpa_s->drv_flags & WPA_DRIVER_FLAGS_USER_SPACE_MLME)
wpa_s->scan_res = ieee80211_sta_get_scan_results(wpa_s);
- if (wpa_s->scan_res == NULL) {
- wpa_printf(MSG_DEBUG, "Failed to get scan results");
- ret = -1;
- } else
- ret = 0;
- } else if (wpa_s->driver->get_scan_results2 == NULL)
- ret = wpa_supplicant_get_scan_results_old(wpa_s);
- else {
- wpa_scan_results_free(wpa_s->scan_res);
+ else if (wpa_s->driver->get_scan_results2 == NULL)
+ wpa_s->scan_res = wpa_supplicant_get_scan_results_old(wpa_s);
+ else
wpa_s->scan_res = wpa_drv_get_scan_results2(wpa_s);
- if (wpa_s->scan_res == NULL) {
- wpa_printf(MSG_DEBUG, "Failed to get scan results");
- ret = -1;
- } else
- ret = 0;
- }
-
- if (wpa_s->scan_res)
+ if (wpa_s->scan_res == NULL) {
+ wpa_printf(MSG_DEBUG, "Failed to get scan results");
+ ret = -1;
+ } else {
+ ret = 0;
wpa_scan_sort_results(wpa_s->scan_res);
+ }
return ret;
}