1
0
mirror of https://github.com/GOSTSec/sgminer synced 2025-01-12 07:48:22 +00:00

Only set the stratum auth flag once and once the stratum thread is started, use that to set/unset the stratum active flag.

This commit is contained in:
Con Kolivas 2012-10-06 12:17:46 +10:00
parent 7a01578cc5
commit 0cddd1ab54

View File

@ -4152,7 +4152,7 @@ static void *stratum_thread(void *userdata)
FD_SET(pool->sock, &rd); FD_SET(pool->sock, &rd);
if (select(pool->sock + 1, &rd, NULL, NULL, NULL) < 0) { if (select(pool->sock + 1, &rd, NULL, NULL, NULL) < 0) {
pool->stratum_active = pool->stratum_auth = false; pool->stratum_active = false;
applog(LOG_WARNING, "Stratum connection to pool %d interrupted", pool->pool_no); applog(LOG_WARNING, "Stratum connection to pool %d interrupted", pool->pool_no);
pool->getfail_occasions++; pool->getfail_occasions++;
total_go++; total_go++;
@ -4231,18 +4231,19 @@ static bool pool_active(struct pool *pool, bool pinging)
/* This is the central point we activate stratum when we can */ /* This is the central point we activate stratum when we can */
retry_stratum: retry_stratum:
if (pool->has_stratum) { if (pool->has_stratum) {
if ((!pool->stratum_active || pinging) && !initiate_stratum(pool)) /* We create the stratum thread for each pool just after
* successful authorisation. Once the auth flag has been set
* we never unset it and the stratum thread is responsible for
* setting/unsetting the active flag */
if (pool->stratum_auth)
return pool->stratum_active;
if (!pool->stratum_active && !initiate_stratum(pool))
return false; return false;
if (!pool->stratum_auth) {
if (!auth_stratum(pool)) if (!auth_stratum(pool))
return false; return false;
/* We create the stratum thread for each pool just
* after successful authorisation */
init_stratum_thread(pool); init_stratum_thread(pool);
return true; return true;
} }
return true;
}
curl = curl_easy_init(); curl = curl_easy_init();
if (unlikely(!curl)) { if (unlikely(!curl)) {