Browse Source

Merge commit 'dd1a0d6' into update_avalon_20130524

Luke Dashjr 13 years ago
parent
commit
d0ed3cbe03
1 changed files with 5 additions and 7 deletions
  1. 5 7
      driver-avalon.c

+ 5 - 7
driver-avalon.c

@@ -680,7 +680,7 @@ static void avalon_free_work_array(struct thr_info *thr)
 {
 	struct cgpu_info *avalon;
 	struct work **works;
-	int i, j, mc, wa;
+	int i, j, mc;
 
 	avalon = thr->cgpu;
 	avalon->queued = 0;
@@ -688,11 +688,10 @@ static void avalon_free_work_array(struct thr_info *thr)
 		return;
 	works = avalon->works;
 	mc = avalon_infos[avalon->device_id]->miner_count;
-	wa = avalon->work_array + 1;
-	if (wa > 3)
-		wa = 0;
+	if (++avalon->work_array > 3)
+		avalon->work_array = 0;
 
-	for (i = wa * mc, j = 0; j < mc; i++, j++) {
+	for (i = avalon->work_array * mc, j = 0; j < mc; i++, j++) {
 		if (likely(works[i])) {
 			work_completed(avalon, works[i]);
 			works[i] = NULL;
@@ -856,6 +855,7 @@ static int64_t avalon_scanhash(struct thr_info *thr)
 		}
 		if (ret == AVA_SEND_BUFFER_EMPTY && (i + 1 == end_count)) {
 			first_try = 1;
+			avalon_free_work_array(thr);
 			return 0xffffffff;
 		}
 
@@ -937,8 +937,6 @@ static int64_t avalon_scanhash(struct thr_info *thr)
 	}
 
 	avalon_free_work_array(thr);
-	if (++avalon->work_array > 3)
-		avalon->work_array = 0;
 
 	record_temp_fan(info, &ar, &(avalon->temp));
 	applog(LOG_INFO,