Commit be3224f933299d778fae708889d89040ee1b0f19

Con Kolivas 2013-05-26T01:33:32

Only loop once through avalon_parse_results, but do so after timeouts as well.

diff --git a/driver-avalon.c b/driver-avalon.c
index 69b04ef..86f8520 100644
--- a/driver-avalon.c
+++ b/driver-avalon.c
@@ -685,6 +685,9 @@ static void *avalon_get_results(void *userdata)
 		ssize_t ret;
 		fd_set rd;
 
+		if (offset >= (int)AVALON_READ_SIZE)
+			avalon_parse_results(avalon, info, thr, readbuf, &offset);
+
 		if (unlikely(offset + rsize >= AVALON_READBUF_SIZE)) {
 			/* This should never happen */
 			applog(LOG_ERR, "Avalon readbuf overflow, resetting buffer");
@@ -715,9 +718,6 @@ static void *avalon_get_results(void *userdata)
 
 		memcpy(&readbuf[offset], buf, ret);
 		offset += ret;
-
-		while (offset >= (int)AVALON_READ_SIZE)
-			avalon_parse_results(avalon, info, thr, readbuf, &offset);
 	}
 	return NULL;
 }