mirror of
https://github.com/xmrig/xmrig.git
synced 2025-01-10 21:04:37 +00:00
Added option "mode" (or --randomx-mode) for RandomX.
This commit is contained in:
parent
ca9a3063d8
commit
64fb4f265b
20 changed files with 129 additions and 27 deletions
|
@ -63,6 +63,7 @@ CPU backend:
|
||||||
--asm=ASM ASM optimizations, possible values: auto, none, intel, ryzen, bulldozer
|
--asm=ASM ASM optimizations, possible values: auto, none, intel, ryzen, bulldozer
|
||||||
--randomx-init=N threads count to initialize RandomX dataset
|
--randomx-init=N threads count to initialize RandomX dataset
|
||||||
--randomx-no-numa disable NUMA support for RandomX
|
--randomx-no-numa disable NUMA support for RandomX
|
||||||
|
--randomx-mode=MODE RandomX mode: auto, fast, light
|
||||||
|
|
||||||
API:
|
API:
|
||||||
--api-worker-id=ID custom worker-id for API
|
--api-worker-id=ID custom worker-id for API
|
||||||
|
|
|
@ -24,6 +24,9 @@
|
||||||
#define XMRIG_IRXSTORAGE_H
|
#define XMRIG_IRXSTORAGE_H
|
||||||
|
|
||||||
|
|
||||||
|
#include "crypto/rx/RxConfig.h"
|
||||||
|
|
||||||
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
|
@ -43,7 +46,7 @@ public:
|
||||||
|
|
||||||
virtual RxDataset *dataset(const Job &job, uint32_t nodeId) const = 0;
|
virtual RxDataset *dataset(const Job &job, uint32_t nodeId) const = 0;
|
||||||
virtual std::pair<uint32_t, uint32_t> hugePages() const = 0;
|
virtual std::pair<uint32_t, uint32_t> hugePages() const = 0;
|
||||||
virtual void init(const RxSeed &seed, uint32_t threads, bool hugePages) = 0;
|
virtual void init(const RxSeed &seed, uint32_t threads, bool hugePages, RxConfig::Mode mode) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -89,6 +89,7 @@ public:
|
||||||
AssemblyKey = 1015,
|
AssemblyKey = 1015,
|
||||||
RandomXInitKey = 1022,
|
RandomXInitKey = 1022,
|
||||||
RandomXNumaKey = 1023,
|
RandomXNumaKey = 1023,
|
||||||
|
RandomXModeKey = 1029,
|
||||||
CPUMaxThreadsKey = 1026,
|
CPUMaxThreadsKey = 1026,
|
||||||
MemoryPoolKey = 1027,
|
MemoryPoolKey = 1027,
|
||||||
|
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
"colors": true,
|
"colors": true,
|
||||||
"randomx": {
|
"randomx": {
|
||||||
"init": -1,
|
"init": -1,
|
||||||
|
"mode": "auto",
|
||||||
"numa": true
|
"numa": true
|
||||||
},
|
},
|
||||||
"cpu": {
|
"cpu": {
|
||||||
|
|
|
@ -160,6 +160,9 @@ void xmrig::ConfigTransform::transform(rapidjson::Document &doc, int key, const
|
||||||
|
|
||||||
case IConfig::RandomXNumaKey: /* --randomx-no-numa */
|
case IConfig::RandomXNumaKey: /* --randomx-no-numa */
|
||||||
return set(doc, kRandomX, "numa", false);
|
return set(doc, kRandomX, "numa", false);
|
||||||
|
|
||||||
|
case IConfig::RandomXModeKey: /* --randomx-mode */
|
||||||
|
return set(doc, kRandomX, "mode", arg);
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
# ifdef XMRIG_FEATURE_OPENCL
|
# ifdef XMRIG_FEATURE_OPENCL
|
||||||
|
|
|
@ -96,6 +96,7 @@ static const option options[] = {
|
||||||
# ifdef XMRIG_ALGO_RANDOMX
|
# ifdef XMRIG_ALGO_RANDOMX
|
||||||
{ "randomx-init", 1, nullptr, IConfig::RandomXInitKey },
|
{ "randomx-init", 1, nullptr, IConfig::RandomXInitKey },
|
||||||
{ "randomx-no-numa", 0, nullptr, IConfig::RandomXNumaKey },
|
{ "randomx-no-numa", 0, nullptr, IConfig::RandomXNumaKey },
|
||||||
|
{ "randomx-mode", 1, nullptr, IConfig::RandomXModeKey },
|
||||||
# endif
|
# endif
|
||||||
# ifdef XMRIG_FEATURE_OPENCL
|
# ifdef XMRIG_FEATURE_OPENCL
|
||||||
{ "opencl", 0, nullptr, IConfig::OclKey },
|
{ "opencl", 0, nullptr, IConfig::OclKey },
|
||||||
|
|
|
@ -86,6 +86,7 @@ static inline const std::string &usage()
|
||||||
# ifdef XMRIG_ALGO_RANDOMX
|
# ifdef XMRIG_ALGO_RANDOMX
|
||||||
u += " --randomx-init=N threads count to initialize RandomX dataset\n";
|
u += " --randomx-init=N threads count to initialize RandomX dataset\n";
|
||||||
u += " --randomx-no-numa disable NUMA support for RandomX\n";
|
u += " --randomx-no-numa disable NUMA support for RandomX\n";
|
||||||
|
u += " --randomx-mode=MODE RandomX mode: auto, fast, light\n";
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
# ifdef XMRIG_FEATURE_HTTP
|
# ifdef XMRIG_FEATURE_HTTP
|
||||||
|
|
|
@ -70,7 +70,7 @@ bool xmrig::Rx::init(const Job &job, const RxConfig &config, bool hugePages)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
d_ptr->queue.enqueue(job, config.nodeset(), config.threads(), hugePages);
|
d_ptr->queue.enqueue(job, config.nodeset(), config.threads(), hugePages, config.mode());
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -69,11 +69,11 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
inline void createDataset(bool hugePages)
|
inline void createDataset(bool hugePages, RxConfig::Mode mode)
|
||||||
{
|
{
|
||||||
const uint64_t ts = Chrono::steadyMSecs();
|
const uint64_t ts = Chrono::steadyMSecs();
|
||||||
|
|
||||||
m_dataset = new RxDataset(hugePages, true);
|
m_dataset = new RxDataset(hugePages, true, mode);
|
||||||
printAllocStatus(ts);
|
printAllocStatus(ts);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -150,19 +150,19 @@ xmrig::RxDataset *xmrig::RxBasicStorage::dataset(const Job &job, uint32_t) const
|
||||||
std::pair<uint32_t, uint32_t> xmrig::RxBasicStorage::hugePages() const
|
std::pair<uint32_t, uint32_t> xmrig::RxBasicStorage::hugePages() const
|
||||||
{
|
{
|
||||||
if (!d_ptr->dataset()) {
|
if (!d_ptr->dataset()) {
|
||||||
return { 0u, 0u };
|
return { 0U, 0U };
|
||||||
}
|
}
|
||||||
|
|
||||||
return d_ptr->dataset()->hugePages();
|
return d_ptr->dataset()->hugePages();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void xmrig::RxBasicStorage::init(const RxSeed &seed, uint32_t threads, bool hugePages)
|
void xmrig::RxBasicStorage::init(const RxSeed &seed, uint32_t threads, bool hugePages, RxConfig::Mode mode)
|
||||||
{
|
{
|
||||||
d_ptr->setSeed(seed);
|
d_ptr->setSeed(seed);
|
||||||
|
|
||||||
if (!d_ptr->dataset()) {
|
if (!d_ptr->dataset()) {
|
||||||
d_ptr->createDataset(hugePages);
|
d_ptr->createDataset(hugePages, mode);
|
||||||
}
|
}
|
||||||
|
|
||||||
d_ptr->initDataset(threads);
|
d_ptr->initDataset(threads);
|
||||||
|
|
|
@ -50,7 +50,7 @@ public:
|
||||||
protected:
|
protected:
|
||||||
RxDataset *dataset(const Job &job, uint32_t nodeId) const override;
|
RxDataset *dataset(const Job &job, uint32_t nodeId) const override;
|
||||||
std::pair<uint32_t, uint32_t> hugePages() const override;
|
std::pair<uint32_t, uint32_t> hugePages() const override;
|
||||||
void init(const RxSeed &seed, uint32_t threads, bool hugePages) override;
|
void init(const RxSeed &seed, uint32_t threads, bool hugePages, RxConfig::Mode mode) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
RxBasicStoragePrivate *d_ptr;
|
RxBasicStoragePrivate *d_ptr;
|
||||||
|
|
|
@ -25,9 +25,54 @@
|
||||||
|
|
||||||
#include "crypto/rx/RxConfig.h"
|
#include "crypto/rx/RxConfig.h"
|
||||||
#include "backend/cpu/Cpu.h"
|
#include "backend/cpu/Cpu.h"
|
||||||
|
#include "rapidjson/document.h"
|
||||||
|
|
||||||
|
|
||||||
|
#include <array>
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
# define strcasecmp _stricmp
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
namespace xmrig {
|
||||||
|
|
||||||
|
|
||||||
|
static const std::array<const char *, RxConfig::ModeMax> modeNames = { "auto", "fast", "light" };
|
||||||
|
|
||||||
|
|
||||||
|
} // namespace xmrig
|
||||||
|
|
||||||
|
|
||||||
|
const char *xmrig::RxConfig::modeName() const
|
||||||
|
{
|
||||||
|
return modeNames[m_mode];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
uint32_t xmrig::RxConfig::threads() const
|
uint32_t xmrig::RxConfig::threads() const
|
||||||
{
|
{
|
||||||
return m_threads < 1 ? static_cast<uint32_t>(Cpu::info()->threads()) : static_cast<uint32_t>(m_threads);
|
return m_threads < 1 ? static_cast<uint32_t>(Cpu::info()->threads()) : static_cast<uint32_t>(m_threads);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
xmrig::RxConfig::Mode xmrig::RxConfig::readMode(const rapidjson::Value &value) const
|
||||||
|
{
|
||||||
|
if (value.IsUint()) {
|
||||||
|
return static_cast<Mode>(std::min(value.GetUint(), ModeMax - 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (value.IsString()) {
|
||||||
|
auto mode = value.GetString();
|
||||||
|
|
||||||
|
for (size_t i = 0; i < modeNames.size(); i++) {
|
||||||
|
if (strcasecmp(mode, modeNames[i]) == 0) {
|
||||||
|
return static_cast<Mode>(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return LightMode;
|
||||||
|
}
|
||||||
|
|
|
@ -38,6 +38,13 @@ namespace xmrig {
|
||||||
class RxConfig
|
class RxConfig
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
enum Mode : uint32_t {
|
||||||
|
AutoMode,
|
||||||
|
FastMode,
|
||||||
|
LightMode,
|
||||||
|
ModeMax
|
||||||
|
};
|
||||||
|
|
||||||
bool read(const rapidjson::Value &value);
|
bool read(const rapidjson::Value &value);
|
||||||
rapidjson::Value toJSON(rapidjson::Document &doc) const;
|
rapidjson::Value toJSON(rapidjson::Document &doc) const;
|
||||||
|
|
||||||
|
@ -47,11 +54,17 @@ public:
|
||||||
inline std::vector<uint32_t> nodeset() const { return std::vector<uint32_t>(); }
|
inline std::vector<uint32_t> nodeset() const { return std::vector<uint32_t>(); }
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
|
const char *modeName() const;
|
||||||
uint32_t threads() const;
|
uint32_t threads() const;
|
||||||
|
|
||||||
|
inline Mode mode() const { return m_mode; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
Mode readMode(const rapidjson::Value &value) const;
|
||||||
|
|
||||||
bool m_numa = true;
|
bool m_numa = true;
|
||||||
int m_threads = -1;
|
int m_threads = -1;
|
||||||
|
Mode m_mode = AutoMode;
|
||||||
|
|
||||||
# ifdef XMRIG_FEATURE_HWLOC
|
# ifdef XMRIG_FEATURE_HWLOC
|
||||||
std::vector<uint32_t> m_nodeset;
|
std::vector<uint32_t> m_nodeset;
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
namespace xmrig {
|
namespace xmrig {
|
||||||
|
|
||||||
static const char *kInit = "init";
|
static const char *kInit = "init";
|
||||||
|
static const char *kMode = "mode";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,6 +43,7 @@ rapidjson::Value xmrig::RxConfig::toJSON(rapidjson::Document &doc) const
|
||||||
|
|
||||||
Value obj(kObjectType);
|
Value obj(kObjectType);
|
||||||
obj.AddMember(StringRef(kInit), m_threads, allocator);
|
obj.AddMember(StringRef(kInit), m_threads, allocator);
|
||||||
|
obj.AddMember(StringRef(kMode), StringRef(modeName()), allocator);
|
||||||
|
|
||||||
return obj;
|
return obj;
|
||||||
}
|
}
|
||||||
|
@ -51,6 +53,7 @@ bool xmrig::RxConfig::read(const rapidjson::Value &value)
|
||||||
{
|
{
|
||||||
if (value.IsObject()) {
|
if (value.IsObject()) {
|
||||||
m_threads = Json::getInt(value, kInit, m_threads);
|
m_threads = Json::getInt(value, kInit, m_threads);
|
||||||
|
m_mode = readMode(Json::getValue(value, kMode));
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,6 +33,7 @@
|
||||||
namespace xmrig {
|
namespace xmrig {
|
||||||
|
|
||||||
static const char *kInit = "init";
|
static const char *kInit = "init";
|
||||||
|
static const char *kMode = "mode";
|
||||||
static const char *kNUMA = "numa";
|
static const char *kNUMA = "numa";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -46,6 +47,7 @@ rapidjson::Value xmrig::RxConfig::toJSON(rapidjson::Document &doc) const
|
||||||
Value obj(kObjectType);
|
Value obj(kObjectType);
|
||||||
|
|
||||||
obj.AddMember(StringRef(kInit), m_threads, allocator);
|
obj.AddMember(StringRef(kInit), m_threads, allocator);
|
||||||
|
obj.AddMember(StringRef(kMode), StringRef(modeName()), allocator);
|
||||||
|
|
||||||
if (!m_nodeset.empty()) {
|
if (!m_nodeset.empty()) {
|
||||||
Value numa(kArrayType);
|
Value numa(kArrayType);
|
||||||
|
@ -68,6 +70,13 @@ bool xmrig::RxConfig::read(const rapidjson::Value &value)
|
||||||
{
|
{
|
||||||
if (value.IsObject()) {
|
if (value.IsObject()) {
|
||||||
m_threads = Json::getInt(value, kInit, m_threads);
|
m_threads = Json::getInt(value, kInit, m_threads);
|
||||||
|
m_mode = readMode(Json::getValue(value, kMode));
|
||||||
|
|
||||||
|
if (m_mode == LightMode) {
|
||||||
|
m_numa = false;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
const auto &numa = Json::getValue(value, kNUMA);
|
const auto &numa = Json::getValue(value, kNUMA);
|
||||||
if (numa.IsArray()) {
|
if (numa.IsArray()) {
|
||||||
|
|
|
@ -26,6 +26,8 @@
|
||||||
|
|
||||||
|
|
||||||
#include "crypto/rx/RxDataset.h"
|
#include "crypto/rx/RxDataset.h"
|
||||||
|
#include "backend/common/Tags.h"
|
||||||
|
#include "base/io/log/Log.h"
|
||||||
#include "crypto/common/VirtualMemory.h"
|
#include "crypto/common/VirtualMemory.h"
|
||||||
#include "crypto/randomx/randomx.h"
|
#include "crypto/randomx/randomx.h"
|
||||||
#include "crypto/rx/RxAlgo.h"
|
#include "crypto/rx/RxAlgo.h"
|
||||||
|
@ -33,12 +35,14 @@
|
||||||
|
|
||||||
|
|
||||||
#include <thread>
|
#include <thread>
|
||||||
|
#include <uv.h>
|
||||||
|
|
||||||
|
|
||||||
static_assert(RANDOMX_FLAG_LARGE_PAGES == 1, "RANDOMX_FLAG_LARGE_PAGES flag mismatch");
|
static_assert(RANDOMX_FLAG_LARGE_PAGES == 1, "RANDOMX_FLAG_LARGE_PAGES flag mismatch");
|
||||||
|
|
||||||
|
|
||||||
xmrig::RxDataset::RxDataset(bool hugePages, bool cache)
|
xmrig::RxDataset::RxDataset(bool hugePages, bool cache, RxConfig::Mode mode) :
|
||||||
|
m_mode(mode)
|
||||||
{
|
{
|
||||||
allocate(hugePages);
|
allocate(hugePages);
|
||||||
|
|
||||||
|
@ -118,7 +122,7 @@ size_t xmrig::RxDataset::size(bool cache) const
|
||||||
|
|
||||||
std::pair<uint32_t, uint32_t> xmrig::RxDataset::hugePages(bool cache) const
|
std::pair<uint32_t, uint32_t> xmrig::RxDataset::hugePages(bool cache) const
|
||||||
{
|
{
|
||||||
constexpr size_t twoMiB = 2u * 1024u * 1024u;
|
constexpr size_t twoMiB = 2U * 1024U * 1024U;
|
||||||
constexpr size_t cacheSize = VirtualMemory::align(RxCache::maxSize(), twoMiB) / twoMiB;
|
constexpr size_t cacheSize = VirtualMemory::align(RxCache::maxSize(), twoMiB) / twoMiB;
|
||||||
size_t total = VirtualMemory::align(maxSize(), twoMiB) / twoMiB;
|
size_t total = VirtualMemory::align(maxSize(), twoMiB) / twoMiB;
|
||||||
|
|
||||||
|
@ -157,6 +161,18 @@ void xmrig::RxDataset::setRaw(const void *raw)
|
||||||
|
|
||||||
void xmrig::RxDataset::allocate(bool hugePages)
|
void xmrig::RxDataset::allocate(bool hugePages)
|
||||||
{
|
{
|
||||||
|
if (m_mode == RxConfig::LightMode) {
|
||||||
|
LOG_ERR(CLEAR "%s" RED_BOLD_S "fast RandomX mode disabled by config", rx_tag());
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (m_mode == RxConfig::AutoMode && uv_get_total_memory() < (maxSize() + RxCache::maxSize())) {
|
||||||
|
LOG_ERR(CLEAR "%s" RED_BOLD_S "not enough memory for RandomX dataset", rx_tag());
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (hugePages) {
|
if (hugePages) {
|
||||||
m_flags = RANDOMX_FLAG_LARGE_PAGES;
|
m_flags = RANDOMX_FLAG_LARGE_PAGES;
|
||||||
m_dataset = randomx_alloc_dataset(static_cast<randomx_flags>(m_flags));
|
m_dataset = randomx_alloc_dataset(static_cast<randomx_flags>(m_flags));
|
||||||
|
|
|
@ -28,9 +28,10 @@
|
||||||
#define XMRIG_RX_DATASET_H
|
#define XMRIG_RX_DATASET_H
|
||||||
|
|
||||||
|
|
||||||
|
#include "base/tools/Object.h"
|
||||||
#include "crypto/common/Algorithm.h"
|
#include "crypto/common/Algorithm.h"
|
||||||
#include "crypto/randomx/configuration.h"
|
#include "crypto/randomx/configuration.h"
|
||||||
#include "base/tools/Object.h"
|
#include "crypto/rx/RxConfig.h"
|
||||||
|
|
||||||
|
|
||||||
struct randomx_dataset;
|
struct randomx_dataset;
|
||||||
|
@ -49,7 +50,7 @@ class RxDataset
|
||||||
public:
|
public:
|
||||||
XMRIG_DISABLE_COPY_MOVE_DEFAULT(RxDataset)
|
XMRIG_DISABLE_COPY_MOVE_DEFAULT(RxDataset)
|
||||||
|
|
||||||
RxDataset(bool hugePages, bool cache);
|
RxDataset(bool hugePages, bool cache, RxConfig::Mode mode);
|
||||||
RxDataset(RxCache *cache);
|
RxDataset(RxCache *cache);
|
||||||
~RxDataset();
|
~RxDataset();
|
||||||
|
|
||||||
|
@ -69,6 +70,7 @@ public:
|
||||||
private:
|
private:
|
||||||
void allocate(bool hugePages);
|
void allocate(bool hugePages);
|
||||||
|
|
||||||
|
const RxConfig::Mode m_mode = RxConfig::FastMode;
|
||||||
int m_flags = 0;
|
int m_flags = 0;
|
||||||
randomx_dataset *m_dataset = nullptr;
|
randomx_dataset *m_dataset = nullptr;
|
||||||
RxCache *m_cache = nullptr;
|
RxCache *m_cache = nullptr;
|
||||||
|
|
|
@ -198,7 +198,7 @@ private:
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto dataset = new RxDataset(hugePages, false);
|
auto dataset = new RxDataset(hugePages, false, RxConfig::FastMode);
|
||||||
if (!dataset->get()) {
|
if (!dataset->get()) {
|
||||||
printSkipped(nodeId, "failed to allocate dataset");
|
printSkipped(nodeId, "failed to allocate dataset");
|
||||||
|
|
||||||
|
@ -339,14 +339,14 @@ xmrig::RxDataset *xmrig::RxNUMAStorage::dataset(const Job &job, uint32_t nodeId)
|
||||||
std::pair<uint32_t, uint32_t> xmrig::RxNUMAStorage::hugePages() const
|
std::pair<uint32_t, uint32_t> xmrig::RxNUMAStorage::hugePages() const
|
||||||
{
|
{
|
||||||
if (!d_ptr->isAllocated()) {
|
if (!d_ptr->isAllocated()) {
|
||||||
return { 0u, 0u };
|
return { 0U, 0U };
|
||||||
}
|
}
|
||||||
|
|
||||||
return d_ptr->hugePages();
|
return d_ptr->hugePages();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void xmrig::RxNUMAStorage::init(const RxSeed &seed, uint32_t threads, bool hugePages)
|
void xmrig::RxNUMAStorage::init(const RxSeed &seed, uint32_t threads, bool hugePages, RxConfig::Mode)
|
||||||
{
|
{
|
||||||
d_ptr->setSeed(seed);
|
d_ptr->setSeed(seed);
|
||||||
|
|
||||||
|
|
|
@ -53,7 +53,7 @@ public:
|
||||||
protected:
|
protected:
|
||||||
RxDataset *dataset(const Job &job, uint32_t nodeId) const override;
|
RxDataset *dataset(const Job &job, uint32_t nodeId) const override;
|
||||||
std::pair<uint32_t, uint32_t> hugePages() const override;
|
std::pair<uint32_t, uint32_t> hugePages() const override;
|
||||||
void init(const RxSeed &seed, uint32_t threads, bool hugePages) override;
|
void init(const RxSeed &seed, uint32_t threads, bool hugePages, RxConfig::Mode mode) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
RxNUMAStoragePrivate *d_ptr;
|
RxNUMAStoragePrivate *d_ptr;
|
||||||
|
|
|
@ -90,11 +90,11 @@ std::pair<uint32_t, uint32_t> xmrig::RxQueue::hugePages()
|
||||||
{
|
{
|
||||||
std::lock_guard<std::mutex> lock(m_mutex);
|
std::lock_guard<std::mutex> lock(m_mutex);
|
||||||
|
|
||||||
return m_storage && m_state == STATE_IDLE ? m_storage->hugePages() : std::pair<uint32_t, uint32_t>(0u, 0u);
|
return m_storage && m_state == STATE_IDLE ? m_storage->hugePages() : std::pair<uint32_t, uint32_t>(0U, 0U);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void xmrig::RxQueue::enqueue(const RxSeed &seed, const std::vector<uint32_t> &nodeset, uint32_t threads, bool hugePages)
|
void xmrig::RxQueue::enqueue(const RxSeed &seed, const std::vector<uint32_t> &nodeset, uint32_t threads, bool hugePages, RxConfig::Mode mode)
|
||||||
{
|
{
|
||||||
std::unique_lock<std::mutex> lock(m_mutex);
|
std::unique_lock<std::mutex> lock(m_mutex);
|
||||||
|
|
||||||
|
@ -114,7 +114,7 @@ void xmrig::RxQueue::enqueue(const RxSeed &seed, const std::vector<uint32_t> &no
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_queue.emplace_back(seed, nodeset, threads, hugePages);
|
m_queue.emplace_back(seed, nodeset, threads, hugePages, mode);
|
||||||
m_seed = seed;
|
m_seed = seed;
|
||||||
m_state = STATE_PENDING;
|
m_state = STATE_PENDING;
|
||||||
|
|
||||||
|
@ -156,7 +156,7 @@ void xmrig::RxQueue::backgroundInit()
|
||||||
Buffer::toHex(item.seed.data().data(), 8).data()
|
Buffer::toHex(item.seed.data().data(), 8).data()
|
||||||
);
|
);
|
||||||
|
|
||||||
m_storage->init(item.seed, item.threads, item.hugePages);
|
m_storage->init(item.seed, item.threads, item.hugePages, item.mode);
|
||||||
|
|
||||||
lock = std::unique_lock<std::mutex>(m_mutex);
|
lock = std::unique_lock<std::mutex>(m_mutex);
|
||||||
|
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
|
|
||||||
|
|
||||||
#include "base/tools/Object.h"
|
#include "base/tools/Object.h"
|
||||||
|
#include "crypto/rx/RxConfig.h"
|
||||||
#include "crypto/rx/RxSeed.h"
|
#include "crypto/rx/RxSeed.h"
|
||||||
|
|
||||||
|
|
||||||
|
@ -52,14 +53,16 @@ class RxDataset;
|
||||||
class RxQueueItem
|
class RxQueueItem
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
RxQueueItem(const RxSeed &seed, const std::vector<uint32_t> &nodeset, uint32_t threads, bool hugePages) :
|
RxQueueItem(const RxSeed &seed, const std::vector<uint32_t> &nodeset, uint32_t threads, bool hugePages, RxConfig::Mode mode) :
|
||||||
hugePages(hugePages),
|
hugePages(hugePages),
|
||||||
|
mode(mode),
|
||||||
seed(seed),
|
seed(seed),
|
||||||
nodeset(nodeset),
|
nodeset(nodeset),
|
||||||
threads(threads)
|
threads(threads)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
const bool hugePages;
|
const bool hugePages;
|
||||||
|
const RxConfig::Mode mode;
|
||||||
const RxSeed seed;
|
const RxSeed seed;
|
||||||
const std::vector<uint32_t> nodeset;
|
const std::vector<uint32_t> nodeset;
|
||||||
const uint32_t threads;
|
const uint32_t threads;
|
||||||
|
@ -77,7 +80,7 @@ public:
|
||||||
bool isReady(const Job &job);
|
bool isReady(const Job &job);
|
||||||
RxDataset *dataset(const Job &job, uint32_t nodeId);
|
RxDataset *dataset(const Job &job, uint32_t nodeId);
|
||||||
std::pair<uint32_t, uint32_t> hugePages();
|
std::pair<uint32_t, uint32_t> hugePages();
|
||||||
void enqueue(const RxSeed &seed, const std::vector<uint32_t> &nodeset, uint32_t threads, bool hugePages);
|
void enqueue(const RxSeed &seed, const std::vector<uint32_t> &nodeset, uint32_t threads, bool hugePages, RxConfig::Mode mode);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
enum State {
|
enum State {
|
||||||
|
|
Loading…
Reference in a new issue