1
0
mirror of https://github.com/GOSTSec/sgminer synced 2025-01-22 20:44:19 +00:00

Make the initialisation of the stratum thread more robust allowing the watchpool thread safe access to it after the stratum thread is started.

This commit is contained in:
ckolivas 2013-03-08 15:18:10 +11:00
parent b45a07032a
commit e746ed6412
2 changed files with 12 additions and 15 deletions

View File

@ -4988,22 +4988,19 @@ static bool pool_active(struct pool *pool, bool pinging)
retry_stratum:
if (pool->has_stratum) {
/* We create the stratum thread for each pool just after
* successful authorisation. Once the auth flag has been set
* successful authorisation. Once the init 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;
if (!auth_stratum(pool))
return false;
/* Only set stratum_auth once to prevent multiple threads
* being started */
if (pool_tset(pool, &pool->stratum_auth))
return true;
pool->idle = false;
init_stratum_thread(pool);
return true;
bool init = pool_tset(pool, &pool->stratum_init);
if (!init) {
bool ret = initiate_stratum(pool) && auth_stratum(pool);
pool->idle = ret;
init_stratum_thread(pool);
return ret;
}
return pool->stratum_active;
}
curl = curl_easy_init();

View File

@ -997,7 +997,7 @@ struct pool {
char *sessionid;
bool has_stratum;
bool stratum_active;
bool stratum_auth;
bool stratum_init;
bool stratum_notify;
struct stratum_work swork;
pthread_t stratum_thread;