From d479f94e4b7c967c16d5098d78b41737863ee896 Mon Sep 17 00:00:00 2001 From: lorban Date: Fri, 12 Jul 2024 11:28:29 +0200 Subject: [PATCH 1/2] jdc fallback to solo-mining fixed the fallback to solo-mining in the case that the upstream sends a `SubmitShareError` on a valid share AND there are no other available upstreams in the JDC config. --- benches/Cargo.lock | 6 +++--- roles/jd-client/src/lib/downstream.rs | 26 ++++++++++++++++++-------- 2 files changed, 21 insertions(+), 11 deletions(-) diff --git a/benches/Cargo.lock b/benches/Cargo.lock index 946b7c02b8..3964748381 100644 --- a/benches/Cargo.lock +++ b/benches/Cargo.lock @@ -373,7 +373,7 @@ dependencies = [ [[package]] name = "buffer_sv2" -version = "1.0.0" +version = "1.1.0" dependencies = [ "aes-gcm", ] @@ -497,7 +497,7 @@ checksum = "98cc8fbded0c607b7ba9dd60cd98df59af97e84d24e49c8557331cfc26d301ce" [[package]] name = "codec_sv2" -version = "1.1.0" +version = "1.2.0" dependencies = [ "binary_sv2", "buffer_sv2", @@ -1564,7 +1564,7 @@ checksum = "81cdd64d312baedb58e21336b31bc043b77e01cc99033ce76ef539f78e965ebc" [[package]] name = "sv1_api" -version = "1.0.0" +version = "1.0.1" dependencies = [ "binary_sv2", "bitcoin_hashes 0.3.2", diff --git a/roles/jd-client/src/lib/downstream.rs b/roles/jd-client/src/lib/downstream.rs index 5b26cef2f7..92e5a874a7 100644 --- a/roles/jd-client/src/lib/downstream.rs +++ b/roles/jd-client/src/lib/downstream.rs @@ -47,7 +47,7 @@ pub struct DownstreamMiningNode { miner_coinbase_output: Vec, // used to retreive the job id of the share that we send upstream last_template_id: u64, - jd: Option>>, + pub jd: Option>>, } #[allow(clippy::large_enum_variant)] @@ -376,12 +376,13 @@ impl DownstreamMiningNode { let to_send = to_send.into_values(); for message in to_send { let message = if let Mining::NewExtendedMiningJob(job) = message { - let jd = self_mutex.safe_lock(|s| s.jd.clone()).unwrap().unwrap(); - jd.safe_lock(|jd| jd.coinbase_tx_prefix = job.coinbase_tx_prefix.clone()) - .unwrap(); - jd.safe_lock(|jd| jd.coinbase_tx_suffix = job.coinbase_tx_suffix.clone()) + if let Some(jd) = self_mutex.safe_lock(|s| s.jd.clone()).unwrap() { + jd.safe_lock(|jd| { + jd.coinbase_tx_prefix = job.coinbase_tx_prefix.clone(); + jd.coinbase_tx_suffix = job.coinbase_tx_suffix.clone(); + }) .unwrap(); - + } Mining::NewExtendedMiningJob(job) } else { message @@ -514,7 +515,7 @@ impl fn handle_update_channel( &mut self, - _: UpdateChannel, + m: UpdateChannel, ) -> Result, Error> { if !self.status.is_solo_miner() { // Safe unwrap alreay checked if it cointains upstream with is_solo_miner @@ -522,7 +523,16 @@ impl self.status.get_upstream().unwrap(), )) } else { - todo!() + let maximum_target = + roles_logic_sv2::utils::hash_rate_to_target(m.nominal_hash_rate.into(), 10.0)?; + self.status + .get_channel() + .update_target_for_channel(m.channel_id, maximum_target.clone().into()); + let set_target = SetTarget { + channel_id: m.channel_id, + maximum_target, + }; + Ok(SendTo::Respond(Mining::SetTarget(set_target))) } } From cd493ee2b9291d42fad9565f55d3c409ecabb57d Mon Sep 17 00:00:00 2001 From: GitGab19 Date: Fri, 16 Aug 2024 23:43:39 +0200 Subject: [PATCH 2/2] take first coinbase output before encoding - solo mining fmt --- roles/jd-client/src/lib/template_receiver/mod.rs | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/roles/jd-client/src/lib/template_receiver/mod.rs b/roles/jd-client/src/lib/template_receiver/mod.rs index f418318a88..cfc1eec0a1 100644 --- a/roles/jd-client/src/lib/template_receiver/mod.rs +++ b/roles/jd-client/src/lib/template_receiver/mod.rs @@ -57,9 +57,16 @@ impl TemplateRx { test_only_do_not_send_solution_to_tp: bool, ) { let mut encoded_outputs = vec![]; - miner_coinbase_outputs - .consensus_encode(&mut encoded_outputs) - .expect("Invalid coinbase output in config"); + // jd is set to None in initialize_jd_as_solo_miner (in this case we need to take the first output as done by JDS) + if jd.is_none() { + miner_coinbase_outputs[0] + .consensus_encode(&mut encoded_outputs) + .expect("Invalid coinbase output in config"); + } else { + miner_coinbase_outputs + .consensus_encode(&mut encoded_outputs) + .expect("Invalid coinbase output in config"); + } let stream = tokio::net::TcpStream::connect(address).await.unwrap(); let initiator = match authority_public_key {