exit on repeated duplicate shares (to enhance)

create a new function proper_exit() to do common stuff on exit...
This commit is contained in:
Tanguy Pruvot 2014-09-01 18:49:23 +02:00
parent 530732458a
commit 1f99aae0ff
2 changed files with 29 additions and 19 deletions

View File

@ -209,7 +209,7 @@ static struct stratum_ctx stratum;
pthread_mutex_t applog_lock;
static pthread_mutex_t stats_lock;
static uint8_t duplicate_shares = 0;
static unsigned long accepted_count = 0L;
static unsigned long rejected_count = 0L;
static double *thr_hashrates;
@ -349,6 +349,13 @@ static struct work g_work;
static time_t g_work_time;
static pthread_mutex_t g_work_lock;
void proper_exit(int reason)
{
cuda_devicereset();
exit(reason);
}
static bool jobj_binary(const json_t *obj, const char *key,
void *buf, size_t buflen)
{
@ -423,8 +430,17 @@ static void share_result(int result, const char *reason)
(result ? CL_GRN "yay!!!" : CL_RED "booooo")
: (result ? "(yay!!!)" : "(booooo)"));
if (reason)
if (reason) {
if (!strcmp(reason, "Duplicate share")) {
duplicate_shares++;
if (duplicate_shares > 3) {
// exit from app (until auto restart)
applog(LOG_WARNING, "Auto exit to prevent stratum bans: %s", reason);
proper_exit(1);
}
}
applog(LOG_WARNING, "reject reason: %s", reason);
}
}
static bool submit_upstream_work(CURL *curl, struct work *work)
@ -1253,7 +1269,7 @@ static void show_version_and_exit(void)
PTW32_VERSION_STRING,
#endif
curl_version());
exit(0);
proper_exit(0);
}
static void show_usage_and_exit(int status)
@ -1262,7 +1278,7 @@ static void show_usage_and_exit(int status)
fprintf(stderr, "Try `" PROGRAM_NAME " --help' for more information.\n");
else
printf(usage);
exit(status);
proper_exit(status);
}
static void parse_arg (int key, char *arg)
@ -1297,7 +1313,7 @@ static void parse_arg (int key, char *arg)
#endif
if (!json_is_object(opt_config)) {
applog(LOG_ERR, "JSON decode of %s failed", arg);
exit(1);
proper_exit(1);
}
break;
}
@ -1440,7 +1456,7 @@ static void parse_arg (int key, char *arg)
break;
case 1006:
print_hash_tests();
exit(0);
proper_exit(0);
break;
case 1003:
want_longpoll = false;
@ -1462,7 +1478,7 @@ static void parse_arg (int key, char *arg)
device_map[opt_n_threads++] = atoi(pch);
else {
applog(LOG_ERR, "Non-existant CUDA device #%d specified in -d option", atoi(pch));
exit(1);
proper_exit(1);
}
} else {
int device = cuda_finddevice(pch);
@ -1470,7 +1486,7 @@ static void parse_arg (int key, char *arg)
device_map[opt_n_threads++] = device;
else {
applog(LOG_ERR, "Non-existant CUDA device '%s' specified in -d option", pch);
exit(1);
proper_exit(1);
}
}
pch = strtok (NULL, ",");
@ -1572,13 +1588,11 @@ static void signal_handler(int sig)
case SIGINT:
signal(sig, SIG_IGN);
applog(LOG_INFO, "SIGINT received, exiting");
cuda_devicereset();
exit(0);
proper_exit(0);
break;
case SIGTERM:
applog(LOG_INFO, "SIGTERM received, exiting");
cuda_devicereset();
exit(0);
proper_exit(0);
break;
}
}
@ -1588,13 +1602,11 @@ BOOL WINAPI ConsoleHandler(DWORD dwType)
switch (dwType) {
case CTRL_C_EVENT:
applog(LOG_INFO, "CTRL_C_EVENT received, exiting");
cuda_devicereset();
exit(0);
proper_exit(0);
break;
case CTRL_BREAK_EVENT:
applog(LOG_INFO, "CTRL_BREAK_EVENT received, exiting");
cuda_devicereset();
exit(0);
proper_exit(0);
break;
default:
return false;
@ -1785,8 +1797,5 @@ int main(int argc, char *argv[])
applog(LOG_INFO, "workio thread dead, exiting.");
// nvprof requires this
cuda_devicereset();
return 0;
}

View File

@ -396,6 +396,7 @@ extern void *tq_pop(struct thread_q *tq, const struct timespec *abstime);
extern void tq_freeze(struct thread_q *tq);
extern void tq_thaw(struct thread_q *tq);
void proper_exit(int reason);
void applog_hash(unsigned char *hash);