Commit ebb99e5a8d83a7cc7bcc9b3eb0feb97f3765157c

Con Kolivas 2013-02-15T16:05:21

Unlock the sshare_lock in submit_work_thread when all references to work and sshare are complete.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
diff --git a/cgminer.c b/cgminer.c
index 1192072..37c46bb 100644
--- a/cgminer.c
+++ b/cgminer.c
@@ -3160,13 +3160,12 @@ static void *submit_work_thread(void *userdata)
 		/* Give the stratum share a unique id */
 		sshare->id = swork_id++;
 		HASH_ADD_INT(stratum_shares, id, sshare);
-		mutex_unlock(&sshare_lock);
-
 		nonce = *((uint32_t *)(work->data + 76));
 		noncehex = bin2hex((const unsigned char *)&nonce, 4);
 		memset(s, 0, 1024);
 		sprintf(s, "{\"params\": [\"%s\", \"%s\", \"%s\", \"%s\", \"%s\"], \"id\": %d, \"method\": \"mining.submit\"}",
 			pool->rpc_user, work->job_id, work->nonce2, work->ntime, noncehex, sshare->id);
+		mutex_unlock(&sshare_lock);
 		free(noncehex);
 
 		applog(LOG_INFO, "Submitting share %08lx to pool %d", (unsigned long)(hash32[6]), pool->pool_no);