multipool: fix some params like time-limit

This commit is contained in:
Tanguy Pruvot 2015-05-29 15:33:04 +02:00
parent ebe95aac2f
commit c2f319fa86

View File

@ -177,7 +177,7 @@ static bool opt_background = false;
bool opt_quiet = false; bool opt_quiet = false;
static int opt_retries = -1; static int opt_retries = -1;
static int opt_fail_pause = 30; static int opt_fail_pause = 30;
static int opt_time_limit = 0; static int opt_time_limit = -1;
static time_t firstwork_time = 0; static time_t firstwork_time = 0;
int opt_timeout = 60; // curl int opt_timeout = 60; // curl
static int opt_scantime = 10; static int opt_scantime = 10;
@ -1677,11 +1677,11 @@ static void *miner_thread(void *userdata)
max64 = max(1, scan_time + g_work_time - time(NULL)); max64 = max(1, scan_time + g_work_time - time(NULL));
/* time limit */ /* time limit */
if (opt_time_limit && firstwork_time) { if (opt_time_limit > 0 && firstwork_time) {
int passed = (int)(time(NULL) - firstwork_time); int passed = (int)(time(NULL) - firstwork_time);
int remain = (int)(opt_time_limit - passed); int remain = (int)(opt_time_limit - passed);
if (remain < 0) { if (remain < 0) {
if (num_pools > 1 && pools[cur_pooln].time_limit) { if (num_pools > 1 && pools[cur_pooln].time_limit > 0) {
if (!pool_is_switching) { if (!pool_is_switching) {
if (!opt_quiet) if (!opt_quiet)
applog(LOG_INFO, "Pool mining timeout of %ds reached, rotate...", opt_time_limit); applog(LOG_INFO, "Pool mining timeout of %ds reached, rotate...", opt_time_limit);
@ -2366,21 +2366,27 @@ void pool_set_creds(int pooln)
{ {
struct pool_infos *p = &pools[pooln]; struct pool_infos *p = &pools[pooln];
p->id = pooln;
// default flags not 0
p->allow_mininginfo = allow_mininginfo;
p->allow_gbt = allow_gbt;
p->check_dups = check_dups;
snprintf(p->url, sizeof(p->url), "%s", rpc_url); snprintf(p->url, sizeof(p->url), "%s", rpc_url);
snprintf(p->short_url, sizeof(p->short_url), "%s", short_url); snprintf(p->short_url, sizeof(p->short_url), "%s", short_url);
snprintf(p->user, sizeof(p->user), "%s", rpc_user); snprintf(p->user, sizeof(p->user), "%s", rpc_user);
snprintf(p->pass, sizeof(p->pass), "%s", rpc_pass); snprintf(p->pass, sizeof(p->pass), "%s", rpc_pass);
// init pools options with cmdline ones (if set before -c) if (!(p->status & POOL_ST_DEFINED)) {
p->max_diff = opt_max_diff; p->id = pooln;
p->max_rate = opt_max_rate; p->status |= POOL_ST_DEFINED;
p->scantime = opt_scantime; // init pool options as "unset"
// until cmdline is not fully parsed...
p->max_diff = -1.;
p->max_rate = -1.;
p->scantime = -1;
p->time_limit = -1;
p->allow_mininginfo = allow_mininginfo;
p->allow_gbt = allow_gbt;
p->check_dups = check_dups;
p->status |= POOL_ST_DEFINED;
}
if (strlen(rpc_url)) { if (strlen(rpc_url)) {
if (!strncasecmp(rpc_url, "stratum", 7)) if (!strncasecmp(rpc_url, "stratum", 7))
@ -2389,7 +2395,19 @@ void pool_set_creds(int pooln)
p->type = POOL_GETWORK; // todo: or longpoll p->type = POOL_GETWORK; // todo: or longpoll
p->status |= POOL_ST_VALID; p->status |= POOL_ST_VALID;
} }
p->status |= POOL_ST_DEFINED; }
// fill the unset pools options with cmdline ones
void pool_init_defaults()
{
struct pool_infos *p;
for (int i=0; i<num_pools; i++) {
p = &pools[i];
if (p->max_diff <= -1.) p->max_diff = opt_max_diff;
if (p->max_rate <= -1.) p->max_rate = opt_max_rate;
if (p->scantime == -1) p->scantime = opt_scantime;
if (p->time_limit == -1) p->time_limit = opt_time_limit;
}
} }
// attributes only set by a json pools config // attributes only set by a json pools config
@ -2463,12 +2481,8 @@ bool pool_switch(int pooln)
short_url = p->short_url; // just a pointer, no alloc short_url = p->short_url; // just a pointer, no alloc
opt_scantime = p->scantime; opt_scantime = p->scantime;
opt_max_diff = p->max_diff;
if (p->max_diff > -1.) opt_max_rate = p->max_rate;
opt_max_diff = p->max_diff;
if (p->max_rate > -1.)
opt_max_rate = p->max_rate;
opt_time_limit = p->time_limit; opt_time_limit = p->time_limit;
want_stratum = have_stratum = (p->type & POOL_STRATUM) != 0; want_stratum = have_stratum = (p->type & POOL_STRATUM) != 0;
@ -3334,9 +3348,13 @@ int main(int argc, char *argv[])
} }
} }
if (!opt_benchmark && !strlen(rpc_url)) { if (!strlen(rpc_url)) {
fprintf(stderr, "%s: no URL supplied\n", argv[0]); if (!opt_benchmark) {
show_usage_and_exit(1); fprintf(stderr, "%s: no URL supplied\n", argv[0]);
show_usage_and_exit(1);
}
// ensure a pool is set with default params...
pool_set_creds(0);
} }
/* init stratum data.. */ /* init stratum data.. */
@ -3347,6 +3365,9 @@ int main(int argc, char *argv[])
pthread_mutex_init(&stats_lock, NULL); pthread_mutex_init(&stats_lock, NULL);
pthread_mutex_init(&g_work_lock, NULL); pthread_mutex_init(&g_work_lock, NULL);
// ensure default params are set
pool_init_defaults();
if (opt_debug) if (opt_debug)
pool_dump_infos(); pool_dump_infos();
cur_pooln = pool_get_first_valid(0); cur_pooln = pool_get_first_valid(0);