Skip to content

Commit

Permalink
stratum: prevent a booo when receiving a new block
Browse files Browse the repository at this point in the history
seems to works in solo mode too...

note: anime wallet to check, different problem without reject-reason
  • Loading branch information
tpruvot committed Nov 17, 2014
1 parent d062f93 commit f5e7745
Showing 1 changed file with 16 additions and 9 deletions.
25 changes: 16 additions & 9 deletions ccminer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -554,14 +554,23 @@ static bool submit_upstream_work(CURL *curl, struct work *work)
json_t *val, *res, *reason;
char s[345];
int i;
bool stale_work;
bool rc = false;

/* pass if the previous hash is not the current previous hash */
pthread_mutex_lock(&g_work_lock);
if (memcmp(work->data + 1, g_work.data + 1, 32)) {
if (strlen(work->job_id + 8)) {
/* stale if not the current job id */
stale_work = strcmp(work->job_id + 8, g_work.job_id + 8);
} else {
applog_hash((uchar*)&work->data);
/* fallback if not job id (compare hash) */
stale_work = memcmp(&work->data[1], &g_work.data[1], 32);
}

if (stale_work) {
pthread_mutex_unlock(&g_work_lock);
if (opt_debug)
applog(LOG_DEBUG, "stale work detected, discarding");
applog(LOG_WARNING, "stale work detected, discarding");
return true;
}
calc_diff(work, 0);
Expand Down Expand Up @@ -1465,7 +1474,7 @@ static void *longpoll_thread(void *userdata)
if (work_decode(json_object_get(val, "result"), &g_work)) {
if (opt_debug)
applog(LOG_BLUE, "LONGPOLL pushed new work");
time(&g_work_time);
g_work_time = time(NULL);
restart_threads();
}
pthread_mutex_unlock(&g_work_lock);
Expand All @@ -1474,11 +1483,9 @@ static void *longpoll_thread(void *userdata)
pthread_mutex_lock(&g_work_lock);
g_work_time -= LP_SCANTIME;
pthread_mutex_unlock(&g_work_lock);
if (err == CURLE_OPERATION_TIMEDOUT) {
restart_threads();
} else {
restart_threads();
if (err != CURLE_OPERATION_TIMEDOUT) {
have_longpoll = false;
restart_threads();
free(hdr_path);
free(lp_url);
lp_url = NULL;
Expand Down Expand Up @@ -1572,7 +1579,7 @@ static void *stratum_thread(void *userdata)
(!g_work_time || strncmp(stratum.job.job_id, g_work.job_id + 8, 120))) {
pthread_mutex_lock(&g_work_lock);
stratum_gen_work(&stratum, &g_work);
time(&g_work_time);
g_work_time = time(NULL);
if (stratum.job.clean) {
if (!opt_quiet)
applog(LOG_BLUE, "%s %s block %d", short_url, algo_names[opt_algo],
Expand Down

0 comments on commit f5e7745

Please sign in to comment.