Use os_snprintf_error() more consistently in STA output generation
In theory, os_snprintf() could return a negative value and as such, os_snprintf_error() should be used in all cases where the buffer might not be large enough. Signed-off-by: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
31bbc9391e
commit
040ba112aa
1 changed files with 12 additions and 4 deletions
|
@ -348,11 +348,15 @@ static int hostapd_ctrl_iface_sta_mib(struct hostapd_data *hapd,
|
||||||
|
|
||||||
if (sta->supp_op_classes &&
|
if (sta->supp_op_classes &&
|
||||||
buflen - len > (unsigned) (17 + 2 * sta->supp_op_classes[0])) {
|
buflen - len > (unsigned) (17 + 2 * sta->supp_op_classes[0])) {
|
||||||
len += os_snprintf(buf + len, buflen - len, "supp_op_classes=");
|
res = os_snprintf(buf + len, buflen - len, "supp_op_classes=");
|
||||||
|
if (!os_snprintf_error(buflen - len, res))
|
||||||
|
len += res;
|
||||||
len += wpa_snprintf_hex(buf + len, buflen - len,
|
len += wpa_snprintf_hex(buf + len, buflen - len,
|
||||||
sta->supp_op_classes + 1,
|
sta->supp_op_classes + 1,
|
||||||
sta->supp_op_classes[0]);
|
sta->supp_op_classes[0]);
|
||||||
len += os_snprintf(buf + len, buflen - len, "\n");
|
res = os_snprintf(buf + len, buflen - len, "\n");
|
||||||
|
if (!os_snprintf_error(buflen - len, res))
|
||||||
|
len += res;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sta->power_capab) {
|
if (sta->power_capab) {
|
||||||
|
@ -386,11 +390,15 @@ static int hostapd_ctrl_iface_sta_mib(struct hostapd_data *hapd,
|
||||||
|
|
||||||
if (sta->ext_capability &&
|
if (sta->ext_capability &&
|
||||||
buflen - len > (unsigned) (11 + 2 * sta->ext_capability[0])) {
|
buflen - len > (unsigned) (11 + 2 * sta->ext_capability[0])) {
|
||||||
len += os_snprintf(buf + len, buflen - len, "ext_capab=");
|
res = os_snprintf(buf + len, buflen - len, "ext_capab=");
|
||||||
|
if (!os_snprintf_error(buflen - len, res))
|
||||||
|
len += res;
|
||||||
len += wpa_snprintf_hex(buf + len, buflen - len,
|
len += wpa_snprintf_hex(buf + len, buflen - len,
|
||||||
sta->ext_capability + 1,
|
sta->ext_capability + 1,
|
||||||
sta->ext_capability[0]);
|
sta->ext_capability[0]);
|
||||||
len += os_snprintf(buf + len, buflen - len, "\n");
|
res = os_snprintf(buf + len, buflen - len, "\n");
|
||||||
|
if (!os_snprintf_error(buflen - len, res))
|
||||||
|
len += res;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sta->flags & WLAN_STA_WDS && sta->ifname_wds) {
|
if (sta->flags & WLAN_STA_WDS && sta->ifname_wds) {
|
||||||
|
|
Loading…
Reference in a new issue