Fix RandomX startup logic

Ensure that both RandomX caches initialize before stratum and p2p servers start.
This commit is contained in:
SChernykh 2021-08-25 18:31:42 +02:00
parent 276cc5f0fd
commit 0009eba307
3 changed files with 3 additions and 36 deletions

View file

@ -393,7 +393,8 @@ void p2pool::download_block_headers(uint64_t current_height)
ChainMain block;
if (parse_block_header(data, size, block)) {
if (height == prev_seed_height) {
m_hasher->set_old_seed_async(block.id);
// Do it synchronously to make sure stratum and p2p don't start before it's finished
m_hasher->set_old_seed(block.id);
}
}
else {

View file

@ -147,39 +147,6 @@ void RandomX_Hasher::set_seed_async(const hash& seed)
);
}
void RandomX_Hasher::set_old_seed_async(const hash& seed)
{
struct Work
{
p2pool* pool;
RandomX_Hasher* hasher;
hash seed;
uv_work_t req;
};
Work* work = new Work{};
work->pool = m_pool;
work->hasher = this;
work->seed = seed;
work->req.data = work;
uv_queue_work(uv_default_loop_checked(), &work->req,
[](uv_work_t* req)
{
bkg_jobs_tracker.start("RandomX_Hasher::set_old_seed_async");
Work* work = reinterpret_cast<Work*>(req->data);
if (!work->pool->stopped()) {
work->hasher->set_old_seed(work->seed);
}
},
[](uv_work_t* req, int)
{
delete reinterpret_cast<Work*>(req->data);
bkg_jobs_tracker.stop("RandomX_Hasher::set_old_seed_async");
}
);
}
void RandomX_Hasher::set_seed(const hash& seed)
{
if (m_stopped.load()) {

View file

@ -34,13 +34,12 @@ public:
~RandomX_Hasher();
void set_seed_async(const hash& seed);
void set_old_seed_async(const hash& seed);
void set_old_seed(const hash& seed);
bool calculate(const void* data, size_t size, const hash& seed, hash& result);
private:
void set_seed(const hash& seed);
void set_old_seed(const hash& seed);
struct ThreadSafeVM
{