/* XMRig * Copyright 2018 Lee Clagett * Copyright 2018-2021 SChernykh * Copyright 2016-2021 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_CN_HASH_H #define XMRIG_CN_HASH_H #include #include #include #include "crypto/cn/CnAlgo.h" #include "crypto/common/Assembly.h" struct cryptonight_ctx; namespace xmrig { using cn_hash_fun = void (*)(const uint8_t *, size_t, uint8_t *, cryptonight_ctx **, uint64_t); using cn_mainloop_fun = void (*)(cryptonight_ctx **); class CnHash { public: enum AlgoVariant { AV_AUTO, // --av=0 Automatic mode. AV_SINGLE, // --av=1 Single hash mode AV_DOUBLE, // --av=2 Double hash mode AV_SINGLE_SOFT, // --av=3 Single hash mode (Software AES) AV_DOUBLE_SOFT, // --av=4 Double hash mode (Software AES) AV_TRIPLE, // --av=5 Triple hash mode AV_QUAD, // --av=6 Quard hash mode AV_PENTA, // --av=7 Penta hash mode AV_TRIPLE_SOFT, // --av=8 Triple hash mode (Software AES) AV_QUAD_SOFT, // --av=9 Quard hash mode (Software AES) AV_PENTA_SOFT, // --av=10 Penta hash mode (Software AES) AV_MAX }; CnHash(); static cn_hash_fun fn(const Algorithm &algorithm, AlgoVariant av, Assembly::Id assembly); private: struct cn_hash_fun_array { cn_hash_fun data[AV_MAX][Assembly::MAX]; }; std::map m_map; }; } /* namespace xmrig */ #endif /* XMRIG_CN_HASH_H */