/* XMRig * Copyright 2018-2020 MoneroOcean , * * 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 . */ #pragma once #include #include #include "net/interfaces/IJobResultListener.h" #include "base/crypto/Algorithm.h" #include "rapidjson/fwd.h" #include namespace xmrig { class Controller; class Miner; class Job; class MoBenchmark : public IJobResultListener { enum BenchAlgo : int { FLEX_KCN, // "flex" Flex GHOSTRIDER_RTM, // "ghostrider" GhostRider CN_R, // "cn/r" CryptoNightR (Monero's variant 4). CN_LITE_1, // "cn-lite/1" CryptoNight-Lite variant 1. CN_HEAVY_XHV, // "cn-heavy/xhv" CryptoNight-Heavy (modified, Haven Protocol only). CN_PICO_0, // "cn-pico" CryptoNight-Pico. CN_CCX, // "cn/ccx" Conceal (CCX). CN_GPU, // "cn/gpu" CryptoNight-GPU (Ryo). AR2_CHUKWA_V2, // "argon2/chukwav2" Argon2id (Chukwa v2). KAWPOW_RVN, // "kawpow/rvn" KawPow (RVN) RX_0, // "rx/0" RandomX (Monero). RX_GRAFT, // "rx/graft" RandomGraft (Graft). RX_ARQ, // "rx/arq" RandomARQ (Arqma). RX_XEQ, RX_XLA, // "panthera" Panthera (Scala2). MAX, MIN = 0, INVALID = -1, }; const Algorithm::Id ba2a[BenchAlgo::MAX] = { Algorithm::FLEX_KCN, Algorithm::GHOSTRIDER_RTM, Algorithm::CN_R, Algorithm::CN_LITE_1, Algorithm::CN_HEAVY_XHV, Algorithm::CN_PICO_0, Algorithm::CN_CCX, Algorithm::CN_GPU, Algorithm::AR2_CHUKWA_V2, Algorithm::KAWPOW_RVN, Algorithm::RX_0, Algorithm::RX_GRAFT, Algorithm::RX_ARQ, Algorithm::RX_XEQ, Algorithm::RX_XLA, }; Job* m_bench_job[BenchAlgo::MAX]; double m_bench_algo_perf[BenchAlgo::MAX]; Controller *m_controller; // to get access to config and network bool m_isNewBenchRun; // true if benchmark is need to be executed or was executed MoBenchmark::BenchAlgo m_bench_algo; // current perf algo we benchmark uint64_t m_hash_count; // number of hashes calculated for current perf algo uint64_t m_time_start; // time of the first resultt for current perf algo (in ms) uint64_t m_bench_start; // time of measurements start for current perf algo (in ms) after all backends are started unsigned m_enabled_backend_count; // number of active miner backends std::set m_backends_started; // id of backend started for benchmark uint64_t get_now() const; // get current time in ms double get_algo_perf(Algorithm::Id algo) const; // get algo perf based on m_bench_algo_perf void start(const MoBenchmark::BenchAlgo); // start benchmark for specified perf algo void finish(); // end of benchmarks, switch to jobs from the pool (network), fill algo_perf void onJobResult(const JobResult&) override; // onJobResult is called after each computed benchmark hash void run_next_bench_algo(BenchAlgo); // run next bench algo or finish benchmark for the last one public: MoBenchmark(); virtual ~MoBenchmark(); void set_controller(std::shared_ptr controller) { m_controller = controller.get(); } void start(); // start benchmarks bool isNewBenchRun() const { return m_isNewBenchRun; } mutable std::map algo_perf; rapidjson::Value toJSON(rapidjson::Document &doc) const; void read(const rapidjson::Value &value); }; } // namespace xmrig