Browse Source

Free work before retrying in get_work_thread.

ckolivas 13 years ago
parent
commit
afb99b674b
1 changed files with 2 additions and 4 deletions
  1. 2 4
      miner.c

+ 2 - 4
miner.c

@@ -2590,8 +2590,7 @@ retry:
 	if (clone_available())
 		goto out;
 
-	if (!ret_work)
-		ret_work = make_work();
+	ret_work = make_work();
 	if (wc->thr)
 		ret_work->thr = wc->thr;
 	else
@@ -2616,6 +2615,7 @@ retry:
 			applog(LOG_DEBUG, "json_rpc_call failed on get work, retrying");
 			lagging = true;
 			dec_queued();
+			free_work(ret_work);
 			goto retry;
 		}
 
@@ -2632,8 +2632,6 @@ retry:
 	}
 
 out:
-	if (ret_work && !ret_work->queued)
-		free_work(ret_work);
 	workio_cmd_free(wc);
 	if (ce)
 		push_curl_entry(ce, pool);