|
@@ -100,7 +100,7 @@ static int wired_multicast_membership(int sock, int ifindex,
|
|
if (setsockopt(sock, SOL_PACKET,
|
|
if (setsockopt(sock, SOL_PACKET,
|
|
add ? PACKET_ADD_MEMBERSHIP : PACKET_DROP_MEMBERSHIP,
|
|
add ? PACKET_ADD_MEMBERSHIP : PACKET_DROP_MEMBERSHIP,
|
|
&mreq, sizeof(mreq)) < 0) {
|
|
&mreq, sizeof(mreq)) < 0) {
|
|
- perror("setsockopt");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "setsockopt: %s", strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
return 0;
|
|
return 0;
|
|
@@ -158,7 +158,7 @@ static void handle_read(int sock, void *eloop_ctx, void *sock_ctx)
|
|
|
|
|
|
len = recv(sock, buf, sizeof(buf), 0);
|
|
len = recv(sock, buf, sizeof(buf), 0);
|
|
if (len < 0) {
|
|
if (len < 0) {
|
|
- perror("recv");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "recv: %s", strerror(errno));
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -176,7 +176,7 @@ static void handle_dhcp(int sock, void *eloop_ctx, void *sock_ctx)
|
|
|
|
|
|
len = recv(sock, buf, sizeof(buf), 0);
|
|
len = recv(sock, buf, sizeof(buf), 0);
|
|
if (len < 0) {
|
|
if (len < 0) {
|
|
- perror("recv");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "recv: %s", strerror(errno));
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -209,19 +209,21 @@ static int wired_init_sockets(struct wpa_driver_wired_data *drv, u8 *own_addr)
|
|
|
|
|
|
drv->sock = socket(PF_PACKET, SOCK_RAW, htons(ETH_P_PAE));
|
|
drv->sock = socket(PF_PACKET, SOCK_RAW, htons(ETH_P_PAE));
|
|
if (drv->sock < 0) {
|
|
if (drv->sock < 0) {
|
|
- perror("socket[PF_PACKET,SOCK_RAW]");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "socket[PF_PACKET,SOCK_RAW]: %s",
|
|
|
|
+ strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
if (eloop_register_read_sock(drv->sock, handle_read, drv->ctx, NULL)) {
|
|
if (eloop_register_read_sock(drv->sock, handle_read, drv->ctx, NULL)) {
|
|
- printf("Could not register read socket\n");
|
|
|
|
|
|
+ wpa_printf(MSG_INFO, "Could not register read socket");
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
os_memset(&ifr, 0, sizeof(ifr));
|
|
os_memset(&ifr, 0, sizeof(ifr));
|
|
os_strlcpy(ifr.ifr_name, drv->ifname, sizeof(ifr.ifr_name));
|
|
os_strlcpy(ifr.ifr_name, drv->ifname, sizeof(ifr.ifr_name));
|
|
if (ioctl(drv->sock, SIOCGIFINDEX, &ifr) != 0) {
|
|
if (ioctl(drv->sock, SIOCGIFINDEX, &ifr) != 0) {
|
|
- perror("ioctl(SIOCGIFINDEX)");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "ioctl(SIOCGIFINDEX): %s",
|
|
|
|
+ strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -232,7 +234,7 @@ static int wired_init_sockets(struct wpa_driver_wired_data *drv, u8 *own_addr)
|
|
addr.sll_ifindex);
|
|
addr.sll_ifindex);
|
|
|
|
|
|
if (bind(drv->sock, (struct sockaddr *) &addr, sizeof(addr)) < 0) {
|
|
if (bind(drv->sock, (struct sockaddr *) &addr, sizeof(addr)) < 0) {
|
|
- perror("bind");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "bind: %s", strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -247,26 +249,28 @@ static int wired_init_sockets(struct wpa_driver_wired_data *drv, u8 *own_addr)
|
|
os_memset(&ifr, 0, sizeof(ifr));
|
|
os_memset(&ifr, 0, sizeof(ifr));
|
|
os_strlcpy(ifr.ifr_name, drv->ifname, sizeof(ifr.ifr_name));
|
|
os_strlcpy(ifr.ifr_name, drv->ifname, sizeof(ifr.ifr_name));
|
|
if (ioctl(drv->sock, SIOCGIFHWADDR, &ifr) != 0) {
|
|
if (ioctl(drv->sock, SIOCGIFHWADDR, &ifr) != 0) {
|
|
- perror("ioctl(SIOCGIFHWADDR)");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "ioctl(SIOCGIFHWADDR): %s",
|
|
|
|
+ strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
if (ifr.ifr_hwaddr.sa_family != ARPHRD_ETHER) {
|
|
if (ifr.ifr_hwaddr.sa_family != ARPHRD_ETHER) {
|
|
- printf("Invalid HW-addr family 0x%04x\n",
|
|
|
|
- ifr.ifr_hwaddr.sa_family);
|
|
|
|
|
|
+ wpa_printf(MSG_INFO, "Invalid HW-addr family 0x%04x",
|
|
|
|
+ ifr.ifr_hwaddr.sa_family);
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
os_memcpy(own_addr, ifr.ifr_hwaddr.sa_data, ETH_ALEN);
|
|
os_memcpy(own_addr, ifr.ifr_hwaddr.sa_data, ETH_ALEN);
|
|
|
|
|
|
/* setup dhcp listen socket for sta detection */
|
|
/* setup dhcp listen socket for sta detection */
|
|
if ((drv->dhcp_sock = socket(PF_INET, SOCK_DGRAM, IPPROTO_UDP)) < 0) {
|
|
if ((drv->dhcp_sock = socket(PF_INET, SOCK_DGRAM, IPPROTO_UDP)) < 0) {
|
|
- perror("socket call failed for dhcp");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "socket call failed for dhcp: %s",
|
|
|
|
+ strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
if (eloop_register_read_sock(drv->dhcp_sock, handle_dhcp, drv->ctx,
|
|
if (eloop_register_read_sock(drv->dhcp_sock, handle_dhcp, drv->ctx,
|
|
NULL)) {
|
|
NULL)) {
|
|
- printf("Could not register read socket\n");
|
|
|
|
|
|
+ wpa_printf(MSG_INFO, "Could not register read socket");
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -277,12 +281,14 @@ static int wired_init_sockets(struct wpa_driver_wired_data *drv, u8 *own_addr)
|
|
|
|
|
|
if (setsockopt(drv->dhcp_sock, SOL_SOCKET, SO_REUSEADDR, (char *) &n,
|
|
if (setsockopt(drv->dhcp_sock, SOL_SOCKET, SO_REUSEADDR, (char *) &n,
|
|
sizeof(n)) == -1) {
|
|
sizeof(n)) == -1) {
|
|
- perror("setsockopt[SOL_SOCKET,SO_REUSEADDR]");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "setsockopt[SOL_SOCKET,SO_REUSEADDR]: %s",
|
|
|
|
+ strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
if (setsockopt(drv->dhcp_sock, SOL_SOCKET, SO_BROADCAST, (char *) &n,
|
|
if (setsockopt(drv->dhcp_sock, SOL_SOCKET, SO_BROADCAST, (char *) &n,
|
|
sizeof(n)) == -1) {
|
|
sizeof(n)) == -1) {
|
|
- perror("setsockopt[SOL_SOCKET,SO_BROADCAST]");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "setsockopt[SOL_SOCKET,SO_BROADCAST]: %s",
|
|
|
|
+ strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -290,13 +296,15 @@ static int wired_init_sockets(struct wpa_driver_wired_data *drv, u8 *own_addr)
|
|
os_strlcpy(ifr.ifr_ifrn.ifrn_name, drv->ifname, IFNAMSIZ);
|
|
os_strlcpy(ifr.ifr_ifrn.ifrn_name, drv->ifname, IFNAMSIZ);
|
|
if (setsockopt(drv->dhcp_sock, SOL_SOCKET, SO_BINDTODEVICE,
|
|
if (setsockopt(drv->dhcp_sock, SOL_SOCKET, SO_BINDTODEVICE,
|
|
(char *) &ifr, sizeof(ifr)) < 0) {
|
|
(char *) &ifr, sizeof(ifr)) < 0) {
|
|
- perror("setsockopt[SOL_SOCKET,SO_BINDTODEVICE]");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR,
|
|
|
|
+ "setsockopt[SOL_SOCKET,SO_BINDTODEVICE]: %s",
|
|
|
|
+ strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
if (bind(drv->dhcp_sock, (struct sockaddr *) &addr2,
|
|
if (bind(drv->dhcp_sock, (struct sockaddr *) &addr2,
|
|
sizeof(struct sockaddr)) == -1) {
|
|
sizeof(struct sockaddr)) == -1) {
|
|
- perror("bind");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "bind: %s", strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -320,8 +328,9 @@ static int wired_send_eapol(void *priv, const u8 *addr,
|
|
len = sizeof(*hdr) + data_len;
|
|
len = sizeof(*hdr) + data_len;
|
|
hdr = os_zalloc(len);
|
|
hdr = os_zalloc(len);
|
|
if (hdr == NULL) {
|
|
if (hdr == NULL) {
|
|
- printf("malloc() failed for wired_send_eapol(len=%lu)\n",
|
|
|
|
- (unsigned long) len);
|
|
|
|
|
|
+ wpa_printf(MSG_INFO,
|
|
|
|
+ "malloc() failed for wired_send_eapol(len=%lu)",
|
|
|
|
+ (unsigned long) len);
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -337,9 +346,9 @@ static int wired_send_eapol(void *priv, const u8 *addr,
|
|
os_free(hdr);
|
|
os_free(hdr);
|
|
|
|
|
|
if (res < 0) {
|
|
if (res < 0) {
|
|
- perror("wired_send_eapol: send");
|
|
|
|
- printf("wired_send_eapol - packet len: %lu - failed\n",
|
|
|
|
- (unsigned long) len);
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR,
|
|
|
|
+ "wired_send_eapol - packet len: %lu - failed: send: %s",
|
|
|
|
+ (unsigned long) len, strerror(errno));
|
|
}
|
|
}
|
|
|
|
|
|
return res;
|
|
return res;
|
|
@@ -353,7 +362,8 @@ static void * wired_driver_hapd_init(struct hostapd_data *hapd,
|
|
|
|
|
|
drv = os_zalloc(sizeof(struct wpa_driver_wired_data));
|
|
drv = os_zalloc(sizeof(struct wpa_driver_wired_data));
|
|
if (drv == NULL) {
|
|
if (drv == NULL) {
|
|
- printf("Could not allocate memory for wired driver data\n");
|
|
|
|
|
|
+ wpa_printf(MSG_INFO,
|
|
|
|
+ "Could not allocate memory for wired driver data");
|
|
return NULL;
|
|
return NULL;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -418,14 +428,15 @@ static int wpa_driver_wired_get_ifflags(const char *ifname, int *flags)
|
|
|
|
|
|
s = socket(PF_INET, SOCK_DGRAM, 0);
|
|
s = socket(PF_INET, SOCK_DGRAM, 0);
|
|
if (s < 0) {
|
|
if (s < 0) {
|
|
- perror("socket");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "socket: %s", strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
os_memset(&ifr, 0, sizeof(ifr));
|
|
os_memset(&ifr, 0, sizeof(ifr));
|
|
os_strlcpy(ifr.ifr_name, ifname, IFNAMSIZ);
|
|
os_strlcpy(ifr.ifr_name, ifname, IFNAMSIZ);
|
|
if (ioctl(s, SIOCGIFFLAGS, (caddr_t) &ifr) < 0) {
|
|
if (ioctl(s, SIOCGIFFLAGS, (caddr_t) &ifr) < 0) {
|
|
- perror("ioctl[SIOCGIFFLAGS]");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "ioctl[SIOCGIFFLAGS]: %s",
|
|
|
|
+ strerror(errno));
|
|
close(s);
|
|
close(s);
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
@@ -442,7 +453,7 @@ static int wpa_driver_wired_set_ifflags(const char *ifname, int flags)
|
|
|
|
|
|
s = socket(PF_INET, SOCK_DGRAM, 0);
|
|
s = socket(PF_INET, SOCK_DGRAM, 0);
|
|
if (s < 0) {
|
|
if (s < 0) {
|
|
- perror("socket");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "socket: %s", strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -450,7 +461,8 @@ static int wpa_driver_wired_set_ifflags(const char *ifname, int flags)
|
|
os_strlcpy(ifr.ifr_name, ifname, IFNAMSIZ);
|
|
os_strlcpy(ifr.ifr_name, ifname, IFNAMSIZ);
|
|
ifr.ifr_flags = flags & 0xffff;
|
|
ifr.ifr_flags = flags & 0xffff;
|
|
if (ioctl(s, SIOCSIFFLAGS, (caddr_t) &ifr) < 0) {
|
|
if (ioctl(s, SIOCSIFFLAGS, (caddr_t) &ifr) < 0) {
|
|
- perror("ioctl[SIOCSIFFLAGS]");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "ioctl[SIOCSIFFLAGS]: %s",
|
|
|
|
+ strerror(errno));
|
|
close(s);
|
|
close(s);
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
@@ -467,14 +479,15 @@ static int wpa_driver_wired_get_ifstatus(const char *ifname, int *status)
|
|
|
|
|
|
s = socket(PF_INET, SOCK_DGRAM, 0);
|
|
s = socket(PF_INET, SOCK_DGRAM, 0);
|
|
if (s < 0) {
|
|
if (s < 0) {
|
|
- perror("socket");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "socket: %s", strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
os_memset(&ifmr, 0, sizeof(ifmr));
|
|
os_memset(&ifmr, 0, sizeof(ifmr));
|
|
os_strlcpy(ifmr.ifm_name, ifname, IFNAMSIZ);
|
|
os_strlcpy(ifmr.ifm_name, ifname, IFNAMSIZ);
|
|
if (ioctl(s, SIOCGIFMEDIA, (caddr_t) &ifmr) < 0) {
|
|
if (ioctl(s, SIOCGIFMEDIA, (caddr_t) &ifmr) < 0) {
|
|
- perror("ioctl[SIOCGIFMEDIA]");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "ioctl[SIOCGIFMEDIA]: %s",
|
|
|
|
+ strerror(errno));
|
|
close(s);
|
|
close(s);
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
@@ -498,7 +511,7 @@ static int wpa_driver_wired_multi(const char *ifname, const u8 *addr, int add)
|
|
|
|
|
|
s = socket(PF_INET, SOCK_DGRAM, 0);
|
|
s = socket(PF_INET, SOCK_DGRAM, 0);
|
|
if (s < 0) {
|
|
if (s < 0) {
|
|
- perror("socket");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "socket: %s", strerror(errno));
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -532,7 +545,8 @@ static int wpa_driver_wired_multi(const char *ifname, const u8 *addr, int add)
|
|
#endif /* defined(__NetBSD__) || defined(__OpenBSD__) || defined(__APPLE__) */
|
|
#endif /* defined(__NetBSD__) || defined(__OpenBSD__) || defined(__APPLE__) */
|
|
|
|
|
|
if (ioctl(s, add ? SIOCADDMULTI : SIOCDELMULTI, (caddr_t) &ifr) < 0) {
|
|
if (ioctl(s, add ? SIOCADDMULTI : SIOCDELMULTI, (caddr_t) &ifr) < 0) {
|
|
- perror("ioctl[SIOC{ADD/DEL}MULTI]");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "ioctl[SIOC{ADD/DEL}MULTI]: %s",
|
|
|
|
+ strerror(errno));
|
|
close(s);
|
|
close(s);
|
|
return -1;
|
|
return -1;
|
|
}
|
|
}
|
|
@@ -555,7 +569,7 @@ static void * wpa_driver_wired_init(void *ctx, const char *ifname)
|
|
#ifdef __linux__
|
|
#ifdef __linux__
|
|
drv->pf_sock = socket(PF_PACKET, SOCK_DGRAM, 0);
|
|
drv->pf_sock = socket(PF_PACKET, SOCK_DGRAM, 0);
|
|
if (drv->pf_sock < 0)
|
|
if (drv->pf_sock < 0)
|
|
- perror("socket(PF_PACKET)");
|
|
|
|
|
|
+ wpa_printf(MSG_ERROR, "socket(PF_PACKET): %s", strerror(errno));
|
|
#else /* __linux__ */
|
|
#else /* __linux__ */
|
|
drv->pf_sock = -1;
|
|
drv->pf_sock = -1;
|
|
#endif /* __linux__ */
|
|
#endif /* __linux__ */
|