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:
parent
b45a07032a
commit
e746ed6412
25
cgminer.c
25
cgminer.c
@ -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();
|
||||
|
Loading…
x
Reference in New Issue
Block a user