mirror of
https://github.com/GOSTSec/sgminer
synced 2025-01-11 07:17:58 +00:00
Make sure to retry only once with noresume support for stratum.
This commit is contained in:
parent
f4892a43a2
commit
0be6e9e76c
5
util.c
5
util.c
@ -1481,8 +1481,8 @@ out:
|
|||||||
bool initiate_stratum(struct pool *pool)
|
bool initiate_stratum(struct pool *pool)
|
||||||
{
|
{
|
||||||
char s[RBUFSIZE], *sret = NULL, *nonce1, *sessionid;
|
char s[RBUFSIZE], *sret = NULL, *nonce1, *sessionid;
|
||||||
|
bool ret = false, recvd = false, noresume = false;
|
||||||
json_t *val = NULL, *res_val, *err_val;
|
json_t *val = NULL, *res_val, *err_val;
|
||||||
bool ret = false, recvd = false;
|
|
||||||
json_error_t err;
|
json_error_t err;
|
||||||
int n2size;
|
int n2size;
|
||||||
|
|
||||||
@ -1582,7 +1582,7 @@ out:
|
|||||||
pool->pool_no, pool->nonce1, pool->n2size);
|
pool->pool_no, pool->nonce1, pool->n2size);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (recvd) {
|
if (recvd && !noresume) {
|
||||||
/* Reset the sessionid used for stratum resuming in case the pool
|
/* Reset the sessionid used for stratum resuming in case the pool
|
||||||
* does not support it, or does not know how to respond to the
|
* does not support it, or does not know how to respond to the
|
||||||
* presence of the sessionid parameter. */
|
* presence of the sessionid parameter. */
|
||||||
@ -1592,6 +1592,7 @@ out:
|
|||||||
pool->sessionid = pool->nonce1 = NULL;
|
pool->sessionid = pool->nonce1 = NULL;
|
||||||
mutex_unlock(&pool->pool_lock);
|
mutex_unlock(&pool->pool_lock);
|
||||||
applog(LOG_DEBUG, "Failed to resume stratum, trying afresh");
|
applog(LOG_DEBUG, "Failed to resume stratum, trying afresh");
|
||||||
|
noresume = true;
|
||||||
goto resend;
|
goto resend;
|
||||||
}
|
}
|
||||||
applog(LOG_DEBUG, "Initiate stratum failed");
|
applog(LOG_DEBUG, "Initiate stratum failed");
|
||||||
|
Loading…
Reference in New Issue
Block a user