/* 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 . */ #ifndef XMRIG_RX_DATASET_H #define XMRIG_RX_DATASET_H #include "crypto/common/Algorithm.h" #include "crypto/randomx/configuration.h" #include "base/tools/Object.h" struct randomx_dataset; namespace xmrig { class Buffer; class RxCache; class RxDataset { public: XMRIG_DISABLE_COPY_MOVE_DEFAULT(RxDataset) RxDataset(bool hugePages, bool cache); RxDataset(RxCache *cache); ~RxDataset(); inline bool isHugePages() const { return m_flags & 1; } inline randomx_dataset *get() const { return m_dataset; } inline RxCache *cache() const { return m_cache; } inline void setCache(RxCache *cache) { m_cache = cache; } bool init(const Buffer &seed, uint32_t numThreads); size_t size(bool cache = true) const; std::pair hugePages(bool cache = true) const; void *raw() const; void setRaw(const void *raw); static inline constexpr size_t maxSize() { return RANDOMX_DATASET_MAX_SIZE; } private: void allocate(bool hugePages); int m_flags = 0; randomx_dataset *m_dataset = nullptr; RxCache *m_cache = nullptr; }; } /* namespace xmrig */ #endif /* XMRIG_RX_DATASET_H */