Commit 52b86b513798a44d15c4dad21f1ad9380f12aec0

Con Kolivas 2012-11-18T16:38:24

Update work block on the longpoll work item before calling restart threads to ensure all work but the longpoll work item gets discarded when we call discard_stale from restart_threads.

diff --git a/cgminer.c b/cgminer.c
index 07d99ee..6129301 100644
--- a/cgminer.c
+++ b/cgminer.c
@@ -3579,7 +3579,7 @@ static bool test_work_current(struct work *work)
 		if (unlikely(new_blocks == 1))
 			goto out_free;
 
-		work_block++;
+		work->work_block = ++work_block;
 
 		if (!work->stratum) {
 			if (work->longpoll) {
@@ -3592,10 +3592,10 @@ static bool test_work_current(struct work *work)
 		}
 		restart_threads();
 	} else if (work->longpoll) {
+		work->work_block = ++work_block;
 		if (work->pool == current_pool()) {
 			applog(LOG_NOTICE, "%sLONGPOLL from pool %d requested work restart",
 			       work->gbt ? "GBT " : "", work->pool->pool_no);
-			work_block++;
 			restart_threads();
 		}
 	}