mirror of
https://github.com/GOSTSec/sgminer
synced 2025-01-25 22:14:36 +00:00
Update the status window only from the watchdog thread, do not rewrite the top status messages and only refresh once all the status window is complete, clearing the window each time to avoid corruption.
This commit is contained in:
parent
93935eb707
commit
fc454e888b
24
main.c
24
main.c
@ -1688,7 +1688,7 @@ static void text_print_status(int thr_id)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Must be called with curses mutex lock held and curses_active */
|
/* Must be called with curses mutex lock held and curses_active */
|
||||||
static void curses_print_status(int thr_id)
|
static void curses_print_status(void)
|
||||||
{
|
{
|
||||||
struct pool *pool = current_pool();
|
struct pool *pool = current_pool();
|
||||||
|
|
||||||
@ -1716,7 +1716,12 @@ static void curses_print_status(int thr_id)
|
|||||||
mvwhline(statuswin, logstart - 1, 0, '-', 80);
|
mvwhline(statuswin, logstart - 1, 0, '-', 80);
|
||||||
mvwprintw(statuswin, gpucursor - 1, 1, "[P]ool management %s[S]ettings [D]isplay options [Q]uit",
|
mvwprintw(statuswin, gpucursor - 1, 1, "[P]ool management %s[S]ettings [D]isplay options [Q]uit",
|
||||||
opt_g_threads ? "[G]PU management " : "");
|
opt_g_threads ? "[G]PU management " : "");
|
||||||
|
/* The window will be updated once we're done with all the devices */
|
||||||
|
wnoutrefresh(statuswin);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void curses_print_devstatus(int thr_id)
|
||||||
|
{
|
||||||
if (thr_id >= 0 && thr_id < gpu_threads) {
|
if (thr_id >= 0 && thr_id < gpu_threads) {
|
||||||
int gpu = dev_from_id(thr_id);
|
int gpu = dev_from_id(thr_id);
|
||||||
struct cgpu_info *cgpu = &gpus[gpu];
|
struct cgpu_info *cgpu = &gpus[gpu];
|
||||||
@ -1755,15 +1760,12 @@ static void curses_print_status(int thr_id)
|
|||||||
cgpu->efficiency, cgpu->utility);
|
cgpu->efficiency, cgpu->utility);
|
||||||
wclrtoeol(statuswin);
|
wclrtoeol(statuswin);
|
||||||
}
|
}
|
||||||
wrefresh(statuswin);
|
wnoutrefresh(statuswin);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void print_status(int thr_id)
|
static void print_status(int thr_id)
|
||||||
{
|
{
|
||||||
if (curses_active_locked()) {
|
if (!curses_active)
|
||||||
curses_print_status(thr_id);
|
|
||||||
unlock_curses();
|
|
||||||
} else
|
|
||||||
text_print_status(thr_id);
|
text_print_status(thr_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4484,12 +4486,12 @@ static void *watchdog_thread(void *userdata)
|
|||||||
hashmeter(-1, &zero_tv, 0);
|
hashmeter(-1, &zero_tv, 0);
|
||||||
|
|
||||||
if (curses_active_locked()) {
|
if (curses_active_locked()) {
|
||||||
|
change_logwinsize();
|
||||||
|
curses_print_status();
|
||||||
for (i = 0; i < mining_threads; i++)
|
for (i = 0; i < mining_threads; i++)
|
||||||
curses_print_status(i);
|
curses_print_devstatus(i);
|
||||||
if (!change_logwinsize()) {
|
clearok(statuswin, true);
|
||||||
redrawwin(statuswin);
|
doupdate();
|
||||||
redrawwin(logwin);
|
|
||||||
}
|
|
||||||
unlock_curses();
|
unlock_curses();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user