fix windows crasH/instability

This commit is contained in:
Cyrix126 2024-05-20 13:00:19 +02:00
parent 6b5afd26fa
commit 19b2eca16d
3 changed files with 28 additions and 14 deletions

View file

@ -395,7 +395,9 @@ impl Helper {
#[inline(never)] #[inline(never)]
// The P2Pool watchdog. Spawns 1 OS thread for reading a PTY (STDOUT+STDERR), and combines the [Child] with a PTY so STDIN actually works. // The P2Pool watchdog. Spawns 1 OS thread for reading a PTY (STDOUT+STDERR), and combines the [Child] with a PTY so STDIN actually works.
#[allow(clippy::too_many_arguments)] #[allow(clippy::too_many_arguments)]
fn spawn_p2pool_watchdog( #[allow(clippy::await_holding_lock)]
#[tokio::main]
async fn spawn_p2pool_watchdog(
process: Arc<Mutex<Process>>, process: Arc<Mutex<Process>>,
gui_api: Arc<Mutex<PubP2poolApi>>, gui_api: Arc<Mutex<PubP2poolApi>>,
pub_api: Arc<Mutex<PubP2poolApi>>, pub_api: Arc<Mutex<PubP2poolApi>>,
@ -444,7 +446,7 @@ impl Helper {
let output_pub = Arc::clone(&lock!(process).output_pub); let output_pub = Arc::clone(&lock!(process).output_pub);
let gupax_p2pool_api = Arc::clone(&gupax_p2pool_api); let gupax_p2pool_api = Arc::clone(&gupax_p2pool_api);
let p2pool_api_c = Arc::clone(&gui_api); let p2pool_api_c = Arc::clone(&gui_api);
thread::spawn(move || { tokio::spawn(async move {
Self::read_pty_p2pool( Self::read_pty_p2pool(
output_parse, output_parse,
output_pub, output_pub,
@ -726,7 +728,7 @@ impl Helper {
lock!(gui_api).tick, lock!(gui_api).tick,
sleep sleep
); );
sleep!(sleep); tokio::time::sleep(Duration::from_millis(sleep)).await;
} else { } else {
debug!( debug!(
"P2Pool Watchdog | END OF LOOP - Tick: [{}/60] Not sleeping!", "P2Pool Watchdog | END OF LOOP - Tick: [{}/60] Not sleeping!",

View file

@ -456,6 +456,20 @@ impl Helper {
lock!(gui_api).node.clone_from(&lock!(img_xmrig).url); lock!(gui_api).node.clone_from(&lock!(img_xmrig).url);
// 5. Loop as watchdog // 5. Loop as watchdog
info!("XMRig | Entering watchdog mode... woof!"); info!("XMRig | Entering watchdog mode... woof!");
// needs xmrig to be in belownormal priority or else Gupaxx will be in trouble if it does not have enough cpu time.
#[cfg(target_os = "windows")]
std::process::Command::new("cmd")
.args(["/c", "/q", "wmic"])
.args([
"process",
"where",
"name='xmrig.exe'",
"CALL",
"setpriority",
"below normal",
])
.spawn()
.expect("failure to execute command wmic");
loop { loop {
// Set timer // Set timer
let now = Instant::now(); let now = Instant::now();
@ -633,7 +647,7 @@ impl Helper {
"XMRig Watchdog | END OF LOOP - Sleeping for [{}]ms...", "XMRig Watchdog | END OF LOOP - Sleeping for [{}]ms...",
sleep sleep
); );
sleep!(sleep); tokio::time::sleep(Duration::from_millis(sleep)).await;
} else { } else {
debug!("XMRig Watchdog | END OF LOOP - Not sleeping!"); debug!("XMRig Watchdog | END OF LOOP - Not sleeping!");
} }

View file

@ -114,7 +114,8 @@ impl Helper {
info!("XvB | spawn watchdog"); info!("XvB | spawn watchdog");
thread::spawn(enc!((state_xvb, state_p2pool, state_xmrig) move || { thread::spawn(enc!((state_xvb, state_p2pool, state_xmrig) move || {
Self::spawn_xvb_watchdog( // thread priority, else there are issue on windows but it is also good for other OS
Self::spawn_xvb_watchdog(
&gui_api, &gui_api,
&pub_api, &pub_api,
&process, &process,
@ -218,18 +219,15 @@ impl Helper {
info!("XvB Watchdog | Signal has stopped the loop"); info!("XvB Watchdog | Signal has stopped the loop");
break; break;
} }
let handle_algo_c = lock!(handle_algo); // let handle_algo_c = lock!(handle_algo);
let is_algo_started_once = handle_algo_c.is_some(); let is_algo_started_once = lock!(handle_algo).is_some();
let is_algo_finished = handle_algo_c let is_algo_finished = lock!(handle_algo)
.as_ref() .as_ref()
.is_some_and(|algo| algo.is_finished()); .is_some_and(|algo| algo.is_finished());
let handle_request_c = lock!(handle_request); let is_request_finished = lock!(handle_request)
let is_request_finished = handle_request_c
.as_ref() .as_ref()
.is_some_and(|request: &JoinHandle<()>| request.is_finished()) .is_some_and(|request: &JoinHandle<()>| request.is_finished())
|| handle_request_c.is_none(); || lock!(handle_request).is_none();
drop(handle_algo_c);
drop(handle_request_c);
// Send an HTTP API request only if one minute is passed since the last request or if first loop or if algorithm need to retry or if request is finished and algo is finished or almost finished (only public and private stats). We make sure public and private stats are refreshed before doing another run of the algo. // Send an HTTP API request only if one minute is passed since the last request or if first loop or if algorithm need to retry or if request is finished and algo is finished or almost finished (only public and private stats). We make sure public and private stats are refreshed before doing another run of the algo.
// We make sure algo or request are not rerun when they are not over. // We make sure algo or request are not rerun when they are not over.
// in the case of quick refresh before new run of algo, make sure it doesn't happen multiple times. // in the case of quick refresh before new run of algo, make sure it doesn't happen multiple times.
@ -353,7 +351,7 @@ impl Helper {
if elapsed < 999 { if elapsed < 999 {
let sleep = (999 - elapsed) as u64; let sleep = (999 - elapsed) as u64;
debug!("XvB Watchdog | END OF LOOP - Sleeping for [{}]s...", sleep); debug!("XvB Watchdog | END OF LOOP - Sleeping for [{}]s...", sleep);
std::thread::sleep(std::time::Duration::from_millis(sleep)) tokio::time::sleep(Duration::from_millis(sleep)).await;
} else { } else {
debug!("XMRig Watchdog | END OF LOOP - Not sleeping!"); debug!("XMRig Watchdog | END OF LOOP - Not sleeping!");
} }