diff options
author | Jouni Malinen <j@w1.fi> | 2012-02-19 14:24:45 +0200 |
---|---|---|
committer | Jouni Malinen <j@w1.fi> | 2012-02-19 14:24:45 +0200 |
commit | d8e59feab244f109862c15fb8029e96d998c92a5 (patch) | |
tree | 94055eb3dc9a1b585687b10dc60dce01565b50d4 | |
parent | 974c56ac24f6a421afebf226a4c642ef480fcead (diff) | |
download | external_wpa_supplicant_8_ti-d8e59feab244f109862c15fb8029e96d998c92a5.zip external_wpa_supplicant_8_ti-d8e59feab244f109862c15fb8029e96d998c92a5.tar.gz external_wpa_supplicant_8_ti-d8e59feab244f109862c15fb8029e96d998c92a5.tar.bz2 |
Interworking: Fix SIM/USIM NAI construction
Commit 9914c96febff964374a863bbd6986ade13a2215a moved sizeof(nai) to a
helper function and broke the determination of maximum buffer length.
Fix this by moving the sizeof() to the functions that define the buffer.
Signed-hostap: Jouni Malinen <j@w1.fi>
-rw-r--r-- | wpa_supplicant/interworking.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/wpa_supplicant/interworking.c b/wpa_supplicant/interworking.c index 3dbdc06..be0e784 100644 --- a/wpa_supplicant/interworking.c +++ b/wpa_supplicant/interworking.c @@ -507,7 +507,8 @@ static int plmn_id_match(struct wpabuf *anqp, const char *imsi) } -static int build_root_nai(char *nai, const char *imsi, char prefix) +static int build_root_nai(char *nai, size_t nai_len, const char *imsi, + char prefix) { const char *sep, *msin; char *end, *pos; @@ -534,7 +535,7 @@ static int build_root_nai(char *nai, const char *imsi, char prefix) msin_len = os_strlen(msin); pos = nai; - end = pos + sizeof(nai); + end = nai + nai_len; if (prefix) *pos++ = prefix; os_memcpy(pos, imsi, plmn_len); @@ -561,7 +562,7 @@ static int build_root_nai(char *nai, const char *imsi, char prefix) static int set_root_nai(struct wpa_ssid *ssid, const char *imsi, char prefix) { char nai[100]; - if (build_root_nai(nai, imsi, prefix) < 0) + if (build_root_nai(nai, sizeof(nai), imsi, prefix) < 0) return -1; return wpa_config_set_quoted(ssid, "identity", nai); } @@ -949,7 +950,7 @@ static int interworking_home_sp(struct wpa_supplicant *wpa_s, for (cred = wpa_s->conf->cred; cred; cred = cred->next) { #ifdef INTERWORKING_3GPP if (cred->imsi && - build_root_nai(nai, cred->imsi, 0) == 0) { + build_root_nai(nai, sizeof(nai), cred->imsi, 0) == 0) { realm = os_strchr(nai, '@'); if (realm) realm++; |