Fix DETACH command debug prints to avoid use of freed memory

In case a control interface socket is detached because of sendmsg()
failing for the socket, function call to detach the socket uses a
pointer to the socket information in the structure to be freed. Reorder
code to print socket info before freeing the data to avoid use of freed
memory in case debug prints are enabled.

Signed-hostap: Jouni Malinen <j@w1.fi>
This commit is contained in:
Jouni Malinen 2013-08-24 23:31:06 +03:00
parent d011246f79
commit a235aca316
2 changed files with 5 additions and 5 deletions

View File

@ -80,14 +80,14 @@ static int wpa_supplicant_ctrl_iface_detach(struct ctrl_iface_priv *priv,
while (dst) { while (dst) {
if (from->sin_addr.s_addr == dst->addr.sin_addr.s_addr && if (from->sin_addr.s_addr == dst->addr.sin_addr.s_addr &&
from->sin_port == dst->addr.sin_port) { from->sin_port == dst->addr.sin_port) {
wpa_printf(MSG_DEBUG, "CTRL_IFACE monitor detached "
"%s:%d", inet_ntoa(from->sin_addr),
ntohs(from->sin_port));
if (prev == NULL) if (prev == NULL)
priv->ctrl_dst = dst->next; priv->ctrl_dst = dst->next;
else else
prev->next = dst->next; prev->next = dst->next;
os_free(dst); os_free(dst);
wpa_printf(MSG_DEBUG, "CTRL_IFACE monitor detached "
"%s:%d", inet_ntoa(from->sin_addr),
ntohs(from->sin_port));
return 0; return 0;
} }
prev = dst; prev = dst;

View File

@ -94,12 +94,12 @@ static int wpa_supplicant_ctrl_iface_detach(struct dl_list *ctrl_dst,
os_memcmp(from->sun_path, dst->addr.sun_path, os_memcmp(from->sun_path, dst->addr.sun_path,
fromlen - offsetof(struct sockaddr_un, sun_path)) fromlen - offsetof(struct sockaddr_un, sun_path))
== 0) { == 0) {
dl_list_del(&dst->list);
os_free(dst);
wpa_hexdump(MSG_DEBUG, "CTRL_IFACE monitor detached", wpa_hexdump(MSG_DEBUG, "CTRL_IFACE monitor detached",
(u8 *) from->sun_path, (u8 *) from->sun_path,
fromlen - fromlen -
offsetof(struct sockaddr_un, sun_path)); offsetof(struct sockaddr_un, sun_path));
dl_list_del(&dst->list);
os_free(dst);
return 0; return 0;
} }
} }