summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDmitry Shmidt <dimitrysh@google.com>2011-09-27 17:20:11 -0700
committerDmitry Shmidt <dimitrysh@google.com>2011-09-27 17:35:20 -0700
commit45bf8a6f0bbf148ca5a1a626ab1c5c38a0855e13 (patch)
treec2de4d63a8b63260c4cce7be8b420b11482152f3
parent62f7e7a017f59e7432672890d2fe8a7b3002fad0 (diff)
downloadhardware_libhardware_legacy-45bf8a6f0bbf148ca5a1a626ab1c5c38a0855e13.zip
hardware_libhardware_legacy-45bf8a6f0bbf148ca5a1a626ab1c5c38a0855e13.tar.gz
hardware_libhardware_legacy-45bf8a6f0bbf148ca5a1a626ab1c5c38a0855e13.tar.bz2
wifi: Change pipe to socket pair in termination of monitor thread code
Change-Id: Id08c211102dabccff3e7d5a1373507f8d63ec70d Signed-off-by: Dmitry Shmidt <dimitrysh@google.com>
-rw-r--r--wifi/wifi.c45
1 files changed, 25 insertions, 20 deletions
diff --git a/wifi/wifi.c b/wifi/wifi.c
index 903065c..5a61eb2 100644
--- a/wifi/wifi.c
+++ b/wifi/wifi.c
@@ -19,6 +19,8 @@
#include <errno.h>
#include <string.h>
#include <dirent.h>
+#include <sys/socket.h>
+#include <poll.h>
#include "hardware_legacy/wifi.h"
#include "libwpa_client/wpa_ctrl.h"
@@ -36,8 +38,8 @@
static struct wpa_ctrl *ctrl_conn;
static struct wpa_ctrl *monitor_conn;
-/* pipe used to exit from a blocking read */
-static int exit_pipe[2] = {-1, -1};
+/* socket pair used to exit from a blocking read */
+static int exit_sockets[2] = { -1, -1 };
extern int do_dhcp();
extern int ifc_init();
@@ -613,7 +615,7 @@ int wifi_connect_to_supplicant()
return -1;
}
- if (pipe(exit_pipe) == -1) {
+ if (socketpair(AF_UNIX, SOCK_STREAM, 0, exit_sockets) == -1) {
wpa_ctrl_close(monitor_conn);
wpa_ctrl_close(ctrl_conn);
ctrl_conn = monitor_conn = NULL;
@@ -635,7 +637,7 @@ int wifi_send_command(struct wpa_ctrl *ctrl, const char *cmd, char *reply, size_
if (ret == -2) {
LOGD("'%s' command timed out.\n", cmd);
/* unblocks the monitor receive socket for termination */
- write(exit_pipe[1], "T", 1);
+ write(exit_sockets[0], "T", 1);
return -2;
} else if (ret < 0 || strncmp(reply, "FAIL", 4) == 0) {
return -1;
@@ -650,19 +652,22 @@ int wifi_ctrl_recv(struct wpa_ctrl *ctrl, char *reply, size_t *reply_len)
{
int res;
int ctrlfd = wpa_ctrl_get_fd(ctrl);
- int high = (ctrlfd > exit_pipe[0]) ? ctrlfd : exit_pipe[0];
- fd_set rfds;
-
- FD_ZERO(&rfds);
- FD_SET(ctrlfd, &rfds);
- FD_SET(exit_pipe[0], &rfds);
- res = select(high + 1, &rfds, NULL, NULL, NULL);
- if (res < 0)
+ struct pollfd rfds[2];
+
+ memset(rfds, 0, 2 * sizeof(struct pollfd));
+ rfds[0].fd = ctrlfd;
+ rfds[0].events |= POLLIN;
+ rfds[1].fd = exit_sockets[1];
+ rfds[1].events |= POLLIN;
+ res = poll(rfds, 2, -1);
+ if (res < 0) {
+ LOGE("Error poll = %d", res);
return res;
- if (FD_ISSET(ctrlfd, &rfds)) {
+ }
+ if (rfds[0].revents & POLLIN) {
return wpa_ctrl_recv(ctrl, reply, reply_len);
} else {
- LOGD("Received on exit pipe, terminate");
+ LOGD("Received on exit socket, terminate");
return -1;
}
return 0;
@@ -734,14 +739,14 @@ void wifi_close_supplicant_connection()
monitor_conn = NULL;
}
- if (exit_pipe[0] >= 0) {
- close(exit_pipe[0]);
- exit_pipe[0] = -1;
+ if (exit_sockets[0] >= 0) {
+ close(exit_sockets[0]);
+ exit_sockets[0] = -1;
}
- if (exit_pipe[1] >= 0) {
- close(exit_pipe[1]);
- exit_pipe[1] = -1;
+ if (exit_sockets[1] >= 0) {
+ close(exit_sockets[1]);
+ exit_sockets[1] = -1;
}
while (count-- > 0) {