diff --git a/src/core/Miner.cpp b/src/core/Miner.cpp index f4edfa975..d92e99152 100644 --- a/src/core/Miner.cpp +++ b/src/core/Miner.cpp @@ -134,8 +134,6 @@ public: Nonce::pause(true); } - active = true; - if (reset) { Nonce::reset(job.index()); } @@ -146,7 +144,7 @@ public: Nonce::touch(); - if (enabled) { + if (active && enabled) { Nonce::pause(false); } @@ -536,6 +534,8 @@ void xmrig::Miner::setJob(const Job &job, bool donate) mutex.unlock(); + d_ptr->active = true; + if (ready) { d_ptr->handleJobChange(); } diff --git a/src/crypto/common/Nonce.cpp b/src/crypto/common/Nonce.cpp index 81cc80e43..bd23e54c1 100644 --- a/src/crypto/common/Nonce.cpp +++ b/src/crypto/common/Nonce.cpp @@ -28,28 +28,14 @@ namespace xmrig { - -std::atomic Nonce::m_paused; -std::atomic Nonce::m_sequence[Nonce::MAX]; +std::atomic Nonce::m_paused = {true}; +std::atomic Nonce::m_sequence[Nonce::MAX] = { {1}, {1}, {1} }; std::atomic Nonce::m_nonces[2] = { {0}, {0} }; -static Nonce nonce; - - } // namespace xmrig -xmrig::Nonce::Nonce() -{ - m_paused = true; - - for (auto &i : m_sequence) { - i = 1; - } -} - - bool xmrig::Nonce::next(uint8_t index, uint32_t *nonce, uint32_t reserveCount, uint64_t mask) { mask &= 0x7FFFFFFFFFFFFFFFULL; diff --git a/src/crypto/common/Nonce.h b/src/crypto/common/Nonce.h index 05c842987..7c0e6d49a 100644 --- a/src/crypto/common/Nonce.h +++ b/src/crypto/common/Nonce.h @@ -43,8 +43,6 @@ public: }; - Nonce(); - static inline bool isOutdated(Backend backend, uint64_t sequence) { return m_sequence[backend].load(std::memory_order_relaxed) != sequence; } static inline bool isPaused() { return m_paused.load(std::memory_order_relaxed); } static inline uint64_t sequence(Backend backend) { return m_sequence[backend].load(std::memory_order_relaxed); }