/* XMRig * Copyright (c) 2018-2020 SChernykh * Copyright (c) 2016-2020 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 . */ #ifndef XMRIG_BENCHSTATE_H #define XMRIG_BENCHSTATE_H #include #include #include namespace xmrig { class Algorithm; class IBackend; class IBenchListener; class BenchState { public: static bool isDone(); static uint32_t size(); static uint64_t referenceHash(const Algorithm &algo, uint32_t size, uint32_t threads); static uint64_t start(size_t threads, const IBackend *backend); static void destroy(); static void done(); static void init(IBenchListener *listener, uint32_t size); static void setSize(uint32_t size); inline static uint64_t data() { return m_data; } inline static void add(uint64_t value) { m_data.fetch_xor(value, std::memory_order_relaxed); } private: static std::atomic m_data; }; } // namespace xmrig #endif /* XMRIG_BENCHSTATE_H */