Check os_snprintf() result more consistently - automatic 3

This converts os_snprintf() result validation cases to use
os_snprintf_error() where the comparison was 'res > size' instead of
'res >= size - 1'. These changes were done automatically with spatch
using the following semantic patch:

@@
identifier E1;
expression E2,E3,E4,E5,E6;
statement S1;
@@

(
  E1 = os_snprintf(E2, E3, ...);
|
  int E1 = os_snprintf(E2, E3, ...);
|
  if (E5)
	E1 = os_snprintf(E2, E3, ...);
  else
	E1 = os_snprintf(E2, E3, ...);
|
  if (E5)
	E1 = os_snprintf(E2, E3, ...);
  else if (E6)
	E1 = os_snprintf(E2, E3, ...);
  else
	E1 = 0;
|
  if (E5) {
	...
	E1 = os_snprintf(E2, E3, ...);
  } else {
	...
	return -1;
  }
|
  if (E5) {
	...
	E1 = os_snprintf(E2, E3, ...);
  } else if (E6) {
	...
	E1 = os_snprintf(E2, E3, ...);
  } else {
	...
	return -1;
  }
|
  if (E5) {
	...
	E1 = os_snprintf(E2, E3, ...);
  } else {
	...
	E1 = os_snprintf(E2, E3, ...);
  }
)
? os_free(E4);
- if (E1 < 0 || (size_t) E1 >= E3 - 1)
+ if (os_snprintf_error(E3, E1))
(
  S1
|
{ ... }
)

Signed-off-by: Jouni Malinen <j@w1.fi>
This commit is contained in:
Jouni Malinen 2014-12-08 11:22:52 +02:00
parent 7bdd8981f7
commit eeab4f2fda
2 changed files with 14 additions and 14 deletions

View file

@ -393,7 +393,7 @@ static int hostapd_cli_cmd_wps_check_pin(struct wpa_ctrl *ctrl, int argc,
else else
res = os_snprintf(cmd, sizeof(cmd), "WPS_CHECK_PIN %s", res = os_snprintf(cmd, sizeof(cmd), "WPS_CHECK_PIN %s",
argv[0]); argv[0]);
if (res < 0 || (size_t) res >= sizeof(cmd) - 1) { if (os_snprintf_error(sizeof(cmd), res)) {
printf("Too long WPS_CHECK_PIN command.\n"); printf("Too long WPS_CHECK_PIN command.\n");
return -1; return -1;
} }
@ -456,7 +456,7 @@ static int hostapd_cli_cmd_wps_nfc_config_token(struct wpa_ctrl *ctrl,
res = os_snprintf(cmd, sizeof(cmd), "WPS_NFC_CONFIG_TOKEN %s", res = os_snprintf(cmd, sizeof(cmd), "WPS_NFC_CONFIG_TOKEN %s",
argv[0]); argv[0]);
if (res < 0 || (size_t) res >= sizeof(cmd) - 1) { if (os_snprintf_error(sizeof(cmd), res)) {
printf("Too long WPS_NFC_CONFIG_TOKEN command.\n"); printf("Too long WPS_NFC_CONFIG_TOKEN command.\n");
return -1; return -1;
} }
@ -477,7 +477,7 @@ static int hostapd_cli_cmd_wps_nfc_token(struct wpa_ctrl *ctrl,
} }
res = os_snprintf(cmd, sizeof(cmd), "WPS_NFC_TOKEN %s", argv[0]); res = os_snprintf(cmd, sizeof(cmd), "WPS_NFC_TOKEN %s", argv[0]);
if (res < 0 || (size_t) res >= sizeof(cmd) - 1) { if (os_snprintf_error(sizeof(cmd), res)) {
printf("Too long WPS_NFC_TOKEN command.\n"); printf("Too long WPS_NFC_TOKEN command.\n");
return -1; return -1;
} }
@ -499,7 +499,7 @@ static int hostapd_cli_cmd_nfc_get_handover_sel(struct wpa_ctrl *ctrl,
res = os_snprintf(cmd, sizeof(cmd), "NFC_GET_HANDOVER_SEL %s %s", res = os_snprintf(cmd, sizeof(cmd), "NFC_GET_HANDOVER_SEL %s %s",
argv[0], argv[1]); argv[0], argv[1]);
if (res < 0 || (size_t) res >= sizeof(cmd) - 1) { if (os_snprintf_error(sizeof(cmd), res)) {
printf("Too long NFC_GET_HANDOVER_SEL command.\n"); printf("Too long NFC_GET_HANDOVER_SEL command.\n");
return -1; return -1;
} }
@ -641,7 +641,7 @@ static int hostapd_cli_cmd_bss_tm_req(struct wpa_ctrl *ctrl, int argc,
for (i = 1; i < argc; i++) { for (i = 1; i < argc; i++) {
tmp = &buf[total]; tmp = &buf[total];
res = os_snprintf(tmp, sizeof(buf) - total, " %s", argv[i]); res = os_snprintf(tmp, sizeof(buf) - total, " %s", argv[i]);
if (res < 0 || (size_t) res >= sizeof(buf) - total - 1) if (os_snprintf_error(sizeof(buf) - total, res))
return -1; return -1;
total += res; total += res;
} }
@ -893,7 +893,7 @@ static int hostapd_cli_cmd_set(struct wpa_ctrl *ctrl, int argc, char *argv[])
} }
res = os_snprintf(cmd, sizeof(cmd), "SET %s %s", argv[0], argv[1]); res = os_snprintf(cmd, sizeof(cmd), "SET %s %s", argv[0], argv[1]);
if (res < 0 || (size_t) res >= sizeof(cmd) - 1) { if (os_snprintf_error(sizeof(cmd), res)) {
printf("Too long SET command.\n"); printf("Too long SET command.\n");
return -1; return -1;
} }
@ -913,7 +913,7 @@ static int hostapd_cli_cmd_get(struct wpa_ctrl *ctrl, int argc, char *argv[])
} }
res = os_snprintf(cmd, sizeof(cmd), "GET %s", argv[0]); res = os_snprintf(cmd, sizeof(cmd), "GET %s", argv[0]);
if (res < 0 || (size_t) res >= sizeof(cmd) - 1) { if (os_snprintf_error(sizeof(cmd), res)) {
printf("Too long GET command.\n"); printf("Too long GET command.\n");
return -1; return -1;
} }
@ -941,7 +941,7 @@ static int hostapd_cli_cmd_chan_switch(struct wpa_ctrl *ctrl,
res = os_snprintf(cmd, sizeof(cmd), "CHAN_SWITCH %s %s", res = os_snprintf(cmd, sizeof(cmd), "CHAN_SWITCH %s %s",
argv[0], argv[1]); argv[0], argv[1]);
if (res < 0 || (size_t) res >= sizeof(cmd) - 1) { if (os_snprintf_error(sizeof(cmd), res)) {
printf("Too long CHAN_SWITCH command.\n"); printf("Too long CHAN_SWITCH command.\n");
return -1; return -1;
} }
@ -950,7 +950,7 @@ static int hostapd_cli_cmd_chan_switch(struct wpa_ctrl *ctrl,
for (i = 2; i < argc; i++) { for (i = 2; i < argc; i++) {
tmp = cmd + total; tmp = cmd + total;
res = os_snprintf(tmp, sizeof(cmd) - total, " %s", argv[i]); res = os_snprintf(tmp, sizeof(cmd) - total, " %s", argv[i]);
if (res < 0 || (size_t) res >= sizeof(cmd) - total - 1) { if (os_snprintf_error(sizeof(cmd) - total, res)) {
printf("Too long CHAN_SWITCH command.\n"); printf("Too long CHAN_SWITCH command.\n");
return -1; return -1;
} }
@ -994,7 +994,7 @@ static int hostapd_cli_cmd_vendor(struct wpa_ctrl *ctrl, int argc, char *argv[])
res = os_snprintf(cmd, sizeof(cmd), "VENDOR %s %s %s", argv[0], argv[1], res = os_snprintf(cmd, sizeof(cmd), "VENDOR %s %s %s", argv[0], argv[1],
argc == 3 ? argv[2] : ""); argc == 3 ? argv[2] : "");
if (res < 0 || (size_t) res >= sizeof(cmd) - 1) { if (os_snprintf_error(sizeof(cmd), res)) {
printf("Too long VENDOR command.\n"); printf("Too long VENDOR command.\n");
return -1; return -1;
} }

View file

@ -584,7 +584,7 @@ static int wpa_cli_cmd_set(struct wpa_ctrl *ctrl, int argc, char *argv[])
if (argc == 1) { if (argc == 1) {
res = os_snprintf(cmd, sizeof(cmd), "SET %s ", argv[0]); res = os_snprintf(cmd, sizeof(cmd), "SET %s ", argv[0]);
if (res < 0 || (size_t) res >= sizeof(cmd) - 1) { if (os_snprintf_error(sizeof(cmd), res)) {
printf("Too long SET command.\n"); printf("Too long SET command.\n");
return -1; return -1;
} }
@ -733,7 +733,7 @@ static int wpa_cli_cmd_bss_flush(struct wpa_ctrl *ctrl, int argc, char *argv[])
res = os_snprintf(cmd, sizeof(cmd), "BSS_FLUSH 0"); res = os_snprintf(cmd, sizeof(cmd), "BSS_FLUSH 0");
else else
res = os_snprintf(cmd, sizeof(cmd), "BSS_FLUSH %s", argv[0]); res = os_snprintf(cmd, sizeof(cmd), "BSS_FLUSH %s", argv[0]);
if (res < 0 || (size_t) res >= sizeof(cmd) - 1) { if (os_snprintf_error(sizeof(cmd), res)) {
printf("Too long BSS_FLUSH command.\n"); printf("Too long BSS_FLUSH command.\n");
return -1; return -1;
} }
@ -908,7 +908,7 @@ static int wpa_cli_cmd_wps_reg(struct wpa_ctrl *ctrl, int argc, char *argv[])
return -1; return -1;
} }
if (res < 0 || (size_t) res >= sizeof(cmd) - 1) { if (os_snprintf_error(sizeof(cmd), res)) {
printf("Too long WPS_REG command.\n"); printf("Too long WPS_REG command.\n");
return -1; return -1;
} }
@ -1033,7 +1033,7 @@ static int wpa_cli_cmd_wps_er_config(struct wpa_ctrl *ctrl, int argc,
return -1; return -1;
} }
if (res < 0 || (size_t) res >= sizeof(cmd) - 1) { if (os_snprintf_error(sizeof(cmd), res)) {
printf("Too long WPS_ER_CONFIG command.\n"); printf("Too long WPS_ER_CONFIG command.\n");
return -1; return -1;
} }