/* XMRig * Copyright 2010 Jeff Garzik * Copyright 2012-2014 pooler * Copyright 2014 Lucas Jones * Copyright 2014-2016 Wolf9466 * Copyright 2016 Jay D Dee * Copyright 2016-2017 XMRig * * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include "Console.h" #include "workers/Handle.h" #include "workers/SingleWorker.h" #include "workers/Workers.h" Job Workers::m_job; pthread_rwlock_t Workers::m_rwlock; std::atomic Workers::m_paused; std::atomic Workers::m_sequence; std::vector Workers::m_workers; uv_async_t Workers::m_async; Job Workers::job() { pthread_rwlock_rdlock(&m_rwlock); Job job = m_job; pthread_rwlock_unlock(&m_rwlock); return std::move(job); } void Workers::setJob(const Job &job) { pthread_rwlock_wrlock(&m_rwlock); m_job = job; pthread_rwlock_unlock(&m_rwlock); m_sequence++; m_paused = 0; } void Workers::start(int threads, int64_t affinity, bool nicehash) { LOG_NOTICE("start %d", pthread_self()); m_sequence = 0; m_paused = 1; uv_async_init(uv_default_loop(), &m_async, Workers::onResult); for (int i = 0; i < threads; ++i) { Handle *handle = new Handle(i, affinity, nicehash); m_workers.push_back(handle); handle->start(Workers::onReady); } } void Workers::submit() { uv_async_send(&m_async); } void *Workers::onReady(void *arg) { auto handle = static_cast(arg); IWorker *worker = new SingleWorker(handle); worker->start(); return nullptr; } void Workers::onResult(uv_async_t *handle) { }