/* XMRig * Copyright 2010 Jeff Garzik * Copyright 2012-2014 pooler * Copyright 2014 Lucas Jones * Copyright 2014-2016 Wolf9466 * Copyright 2016 Jay D Dee * Copyright 2017-2019 XMR-Stak , * Copyright 2018 Lee Clagett * Copyright 2018-2019 tevador * Copyright 2018-2019 SChernykh * Copyright 2016-2019 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 "crypto/randomx/randomx.h" #include "crypto/rx/RxAlgo.h" xmrig::Algorithm::Id xmrig::RxAlgo::apply(Algorithm::Id algorithm) { randomx_apply_config(*base(algorithm)); return algorithm; } const RandomX_ConfigurationBase *xmrig::RxAlgo::base(Algorithm::Id algorithm) { switch (algorithm) { case Algorithm::RX_WOW: return &RandomX_WowneroConfig; case Algorithm::RX_LOKI: return &RandomX_LokiConfig; case Algorithm::RX_ARQ: return &RandomX_ArqmaConfig; case Algorithm::RX_SFX: return &RandomX_SafexConfig; default: break; } return &RandomX_MoneroConfig; } uint32_t xmrig::RxAlgo::version(Algorithm::Id algorithm) { return algorithm == Algorithm::RX_WOW ? 103 : 104; } uint32_t xmrig::RxAlgo::programCount(Algorithm::Id algorithm) { return base(algorithm)->ProgramCount; } uint32_t xmrig::RxAlgo::programIterations(Algorithm::Id algorithm) { return base(algorithm)->ProgramIterations; } uint32_t xmrig::RxAlgo::programSize(Algorithm::Id algorithm) { return base(algorithm)->ProgramSize; }