mirror of
https://github.com/GOSTSec/sgminer
synced 2025-01-25 22:14:36 +00:00
Update both windows separately, but not at the same time to prevent the double refresh crash that old libncurses has.
Do the window resize check only when about to redraw the log window to minimise ncurses cpu usage.
This commit is contained in:
parent
6f905932af
commit
a48895829e
15
main.c
15
main.c
@ -832,7 +832,7 @@ static void print_status(int thr_id)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Check for window resize. Called with curses mutex locked */
|
/* Check for window resize. Called with curses mutex locked */
|
||||||
static void check_logwinsize(void)
|
static inline void check_logwinsize(void)
|
||||||
{
|
{
|
||||||
int x, y, logx, logy;
|
int x, y, logx, logy;
|
||||||
|
|
||||||
@ -849,7 +849,6 @@ static void wlog(const char *f, ...)
|
|||||||
{
|
{
|
||||||
va_list ap;
|
va_list ap;
|
||||||
|
|
||||||
check_logwinsize();
|
|
||||||
va_start(ap, f);
|
va_start(ap, f);
|
||||||
vw_printw(logwin, f, ap);
|
vw_printw(logwin, f, ap);
|
||||||
va_end(ap);
|
va_end(ap);
|
||||||
@ -862,8 +861,6 @@ static void wlogprint(const char *f, ...)
|
|||||||
|
|
||||||
pthread_mutex_lock(&curses_lock);
|
pthread_mutex_lock(&curses_lock);
|
||||||
|
|
||||||
check_logwinsize();
|
|
||||||
|
|
||||||
va_start(ap, f);
|
va_start(ap, f);
|
||||||
vw_printw(logwin, f, ap);
|
vw_printw(logwin, f, ap);
|
||||||
va_end(ap);
|
va_end(ap);
|
||||||
@ -877,7 +874,6 @@ void log_curses(const char *f, va_list ap)
|
|||||||
if (curses_active) {
|
if (curses_active) {
|
||||||
if (!opt_loginput) {
|
if (!opt_loginput) {
|
||||||
pthread_mutex_lock(&curses_lock);
|
pthread_mutex_lock(&curses_lock);
|
||||||
check_logwinsize();
|
|
||||||
vw_printw(logwin, f, ap);
|
vw_printw(logwin, f, ap);
|
||||||
wrefresh(logwin);
|
wrefresh(logwin);
|
||||||
pthread_mutex_unlock(&curses_lock);
|
pthread_mutex_unlock(&curses_lock);
|
||||||
@ -3222,6 +3218,7 @@ static void *watchdog_thread(void *userdata)
|
|||||||
const unsigned int interval = opt_log_interval / 2 ? : 1;
|
const unsigned int interval = opt_log_interval / 2 ? : 1;
|
||||||
static struct timeval rotate_tv;
|
static struct timeval rotate_tv;
|
||||||
struct timeval zero_tv;
|
struct timeval zero_tv;
|
||||||
|
bool statwin = false;
|
||||||
|
|
||||||
pthread_setcanceltype(PTHREAD_CANCEL_ASYNCHRONOUS, NULL);
|
pthread_setcanceltype(PTHREAD_CANCEL_ASYNCHRONOUS, NULL);
|
||||||
|
|
||||||
@ -3239,10 +3236,16 @@ static void *watchdog_thread(void *userdata)
|
|||||||
hashmeter(-1, &zero_tv, 0);
|
hashmeter(-1, &zero_tv, 0);
|
||||||
|
|
||||||
if (curses_active) {
|
if (curses_active) {
|
||||||
|
statwin ^= true;
|
||||||
pthread_mutex_lock(&curses_lock);
|
pthread_mutex_lock(&curses_lock);
|
||||||
for (i = 0; i < mining_threads; i++)
|
for (i = 0; i < mining_threads; i++)
|
||||||
curses_print_status(i);
|
curses_print_status(i);
|
||||||
redrawwin(mainwin);
|
if (statwin)
|
||||||
|
redrawwin(statuswin);
|
||||||
|
else {
|
||||||
|
check_logwinsize();
|
||||||
|
redrawwin(logwin);
|
||||||
|
}
|
||||||
pthread_mutex_unlock(&curses_lock);
|
pthread_mutex_unlock(&curses_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user