From 3d9687b71f73948319931943c75d28a61af36a31 Mon Sep 17 00:00:00 2001
From: Nikias Bassen
Date: Mon, 23 Dec 2013 21:46:20 +0100
Subject: enlarge input+output buffer sizes.

---
 src/client.c | 23 ++++++++++-------------
 1 file changed, 10 insertions(+), 13 deletions(-)

diff --git a/src/client.c b/src/client.c
index fdbea25..ba6a302 100644
--- a/src/client.c
+++ b/src/client.c
@@ -41,8 +41,8 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 #include "device.h"
 #include "conf.h"
 
-#define CMD_BUF_SIZE	1024
-#define REPLY_BUF_SIZE	1024
+#define CMD_BUF_SIZE	0x10000
+#define REPLY_BUF_SIZE	0x10000
 
 enum client_state {
 	CLIENT_COMMAND,		// waiting for command
@@ -172,10 +172,14 @@ static int send_pkt(struct mux_client *client, uint32_t tag, enum usbmuxd_msgtyp
 	hdr.message = msg;
 	hdr.tag = tag;
 	usbmuxd_log(LL_DEBUG, "send_pkt fd %d tag %d msg %d payload_length %d", client->fd, tag, msg, payload_length);
-	if((client->ob_capacity - client->ob_size) < hdr.length) {
-		usbmuxd_log(LL_ERROR, "Client %d output buffer full (%d bytes) while sending message %d (%d bytes)", client->fd, client->ob_capacity, hdr.message, hdr.length);
-		client_close(client);
-		return -1;
+
+	uint32_t available = client->ob_capacity - client->ob_size;
+	/* the output buffer _should_ be large enough, but just in case */
+	if(available < hdr.length) {
+		uint32_t needed_buffer = hdr.length;
+		usbmuxd_log(LL_DEBUG, "Enlarging client %d output buffer %d -> %d", client->fd, client->ob_capacity, needed_buffer);
+		client->ob_buf = realloc(client->ob_buf, needed_buffer);
+		client->ob_capacity = needed_buffer;
 	}
 	memcpy(client->ob_buf + client->ob_size, &hdr, sizeof(hdr));
 	if(payload && payload_length)
@@ -376,13 +380,6 @@ static int start_listen(struct mux_client *client)
 	devs = malloc(sizeof(struct device_info) * count);
 	count = device_get_list(0, devs);
 
-	// going to need a larger buffer for many devices
-	uint32_t needed_buffer = count * (sizeof(struct usbmuxd_device_record) + sizeof(struct usbmuxd_header)) + REPLY_BUF_SIZE;
-	if(client->ob_capacity < needed_buffer) {
-		usbmuxd_log(LL_DEBUG, "Enlarging client %d reply buffer %d -> %d to make space for device notifications", client->fd, client->ob_capacity, needed_buffer);
-		client->ob_buf = realloc(client->ob_buf, needed_buffer);
-		client->ob_capacity = needed_buffer;
-	}
 	dev = devs;
 	for(i=0; i<count; i++) {
 		if(notify_device_add(client, dev++) < 0) {
-- 
cgit v1.1-32-gdbae