Commit 6f905932af54ee04c42827974b193ba3d696bf46

Con Kolivas 2011-07-27T08:32:25

Only free the thread structures if the thread still exists.

diff --git a/main.c b/main.c
index f759af5..a84550b 100644
--- a/main.c
+++ b/main.c
@@ -3149,15 +3149,16 @@ static void *reinit_gpu(void *userdata)
 		thr = &thr_info[thr_id];
 		thr->rolling = thr->cgpu->rolling = 0;
 		tq_freeze(thr->q);
-		if (!pthread_cancel(*thr->pth))
+		if (!pthread_cancel(*thr->pth)) {
 			pthread_join(*thr->pth, NULL);
-		free(thr->q);
+			free(thr->q);
+			free(clStates[thr_id]);
+		}
+
 		thr->q = tq_new();
 		if (!thr->q)
 			quit(1, "Failed to tq_new in reinit_gputhread");
 
-		free(clStates[thr_id]);
-
 		applog(LOG_INFO, "Reinit GPU thread %d", thr_id);
 		clStates[thr_id] = initCl(gpu, name, sizeof(name));
 		if (!clStates[thr_id]) {