From 94d700159d010176a57640d6f59476aaf43875fc Mon Sep 17 00:00:00 2001 From: Nikias Bassen Date: Sat, 20 Jun 2009 04:29:23 +0200 Subject: hopefully fixed race condition on connection setup --- src/main.c | 22 ++++++++++++++++++++++ src/usbmux.c | 13 +++++++++++++ src/usbmux.h | 2 ++ 3 files changed, 37 insertions(+) (limited to 'src') diff --git a/src/main.c b/src/main.c index 1a62f17..8e27d8f 100644 --- a/src/main.c +++ b/src/main.c @@ -719,6 +719,7 @@ static void *usbmuxd_client_init_thread(void *arg) logmsg(LOG_NOTICE, "%s[%x]: No attached iPhone/iPod devices found.", __func__, THREAD); + usbmuxd_send_result(cdata->socket, s_req->header.tag, -ENODEV); goto leave; } @@ -846,6 +847,27 @@ static void *usbmuxd_client_init_thread(void *arg) } pthread_mutex_unlock(&cur_dev->mutex); + // wait for the initial handshake (SYN->SYN+ACK->ACKto complete + struct timespec ts; + ts.tv_sec = 0; + ts.tv_nsec = 100000000; + + i = 0; + printf("waiting for handshake to complete...\n"); + while (i < 10000) { + if (usbmux_is_connected(cdata->muxclient)) { + printf("handshake done\n"); + break; + } + nanosleep(&ts, NULL); + i+=100; + } + if (!usbmux_is_connected(cdata->muxclient)) { + printf("handshake failed\n"); + usbmuxd_send_result(cdata->socket, c_req->header.tag, -ENOTCONN); + goto leave; + } + // start connection handler thread cdata->handler_dead = 0; cdata->tag = c_req->header.tag; diff --git a/src/usbmux.c b/src/usbmux.c index 87cdede..927928e 100644 --- a/src/usbmux.c +++ b/src/usbmux.c @@ -100,6 +100,8 @@ struct usbmux_client_int { int error; int cleanup; + + int connected; }; @@ -734,6 +736,7 @@ int usbmux_new_client(usbmux_device_t device, uint16_t src_port, add_connection(new_connection); new_connection->error = 0; new_connection->cleanup = 0; + new_connection->connected = 0; hton_header(new_connection->header); log_debug_msg("%s: send_to_device (%d --> %d)\n", __func__, ntohs(new_connection->header->sport), @@ -931,6 +934,8 @@ uint32_t append_receive_buffer(usbmux_client_t client, char *packet) sizeof(usbmux_tcp_header)) <= 0) { log_debug_msg("%s: error when pushing to usb...\n", __func__); + } else { + client->connected = 1; } // need to revert some of the fields back to host notation. ntoh_header(client->header); @@ -1253,3 +1258,11 @@ int usbmux_recv_timeout(usbmux_client_t client, char *data, return 0; } + +int usbmux_is_connected(usbmux_client_t client) +{ + if (!client) { + return 0; + } + return client->connected; +} diff --git a/src/usbmux.h b/src/usbmux.h index 2bcdb15..155316a 100644 --- a/src/usbmux.h +++ b/src/usbmux.h @@ -48,4 +48,6 @@ int usbmux_pullbulk(usbmux_device_t device); int usbmux_get_error(usbmux_client_t client); +int usbmux_is_connected(usbmux_client_t client); + #endif -- cgit v1.1-32-gdbae