1
0
mirror of https://github.com/GOSTSec/sgminer synced 2025-01-25 22:14:36 +00:00

Set the latest network access time on share submission for --net-delay even if we're not delaying that submission for further network access.

This commit is contained in:
Con Kolivas 2012-01-30 17:58:22 +11:00
parent 4b994b011b
commit bdec295fee

35
util.c
View File

@ -336,6 +336,9 @@ json_t *json_rpc_call(CURL *curl, const char *url,
curl_easy_setopt(curl, CURLOPT_URL, url); curl_easy_setopt(curl, CURLOPT_URL, url);
curl_easy_setopt(curl, CURLOPT_ENCODING, ""); curl_easy_setopt(curl, CURLOPT_ENCODING, "");
curl_easy_setopt(curl, CURLOPT_FAILONERROR, 1); curl_easy_setopt(curl, CURLOPT_FAILONERROR, 1);
/* Shares are staggered already and delays in submission can be costly
* so do not delay them */
if (!opt_delaynet || share) if (!opt_delaynet || share)
curl_easy_setopt(curl, CURLOPT_TCP_NODELAY, 1); curl_easy_setopt(curl, CURLOPT_TCP_NODELAY, 1);
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, all_data_cb); curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, all_data_cb);
@ -380,25 +383,29 @@ json_t *json_rpc_call(CURL *curl, const char *url,
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers); curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers);
if (opt_delaynet && !share) { if (opt_delaynet) {
long long now_msecs, last_msecs; /* Don't delay share submission, but still track the nettime */
struct timeval now, last; if (!share) {
long long now_msecs, last_msecs;
struct timeval now, last;
gettimeofday(&now, NULL); gettimeofday(&now, NULL);
last_nettime(&last); last_nettime(&last);
now_msecs = (long long)now.tv_sec * 1000; now_msecs = (long long)now.tv_sec * 1000;
now_msecs += now.tv_usec / 1000; now_msecs += now.tv_usec / 1000;
last_msecs = (long long)last.tv_sec * 1000; last_msecs = (long long)last.tv_sec * 1000;
last_msecs += last.tv_usec / 1000; last_msecs += last.tv_usec / 1000;
if (now_msecs > last_msecs && now_msecs - last_msecs < 250) { if (now_msecs > last_msecs && now_msecs - last_msecs < 250) {
struct timespec rgtp; struct timespec rgtp;
rgtp.tv_sec = 0; rgtp.tv_sec = 0;
rgtp.tv_nsec = (250 - (now_msecs - last_msecs)) * 1000000; rgtp.tv_nsec = (250 - (now_msecs - last_msecs)) * 1000000;
nanosleep(&rgtp, NULL); nanosleep(&rgtp, NULL);
}
} }
set_nettime(); set_nettime();
} }
rc = curl_easy_perform(curl); rc = curl_easy_perform(curl);
if (rc) { if (rc) {
applog(LOG_INFO, "HTTP request failed: %s", curl_err_str); applog(LOG_INFO, "HTTP request failed: %s", curl_err_str);