mirror of
https://github.com/xmrig/xmrig.git
synced 2025-01-11 05:14:40 +00:00
Added RandomX support.
This commit is contained in:
parent
0e224abb0a
commit
7889634b40
10 changed files with 97 additions and 38 deletions
|
@ -106,6 +106,31 @@ size_t inline generate<Algorithm::CN_PICO>(Threads<CudaThreads> &threads, const
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef XMRIG_ALGO_RANDOMX
|
||||||
|
template<>
|
||||||
|
size_t inline generate<Algorithm::RANDOM_X>(Threads<CudaThreads> &threads, const std::vector<CudaDevice> &devices)
|
||||||
|
{
|
||||||
|
size_t count = 0;
|
||||||
|
|
||||||
|
auto rx = CudaThreads(devices, Algorithm::RX_0);
|
||||||
|
auto wow = CudaThreads(devices, Algorithm::RX_WOW);
|
||||||
|
auto arq = CudaThreads(devices, Algorithm::RX_ARQ);
|
||||||
|
|
||||||
|
if (!threads.isExist(Algorithm::RX_WOW) && wow != rx) {
|
||||||
|
count += threads.move("rx/wow", std::move(wow));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!threads.isExist(Algorithm::RX_ARQ) && arq != rx) {
|
||||||
|
count += threads.move("rx/arq", std::move(arq));
|
||||||
|
}
|
||||||
|
|
||||||
|
count += threads.move("rx", std::move(rx));
|
||||||
|
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
} /* namespace xmrig */
|
} /* namespace xmrig */
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -61,8 +61,7 @@ static inline uint32_t roundSize(uint32_t intensity) { return kReserveCount / in
|
||||||
xmrig::CudaWorker::CudaWorker(size_t id, const CudaLaunchData &data) :
|
xmrig::CudaWorker::CudaWorker(size_t id, const CudaLaunchData &data) :
|
||||||
Worker(id, data.thread.affinity(), -1),
|
Worker(id, data.thread.affinity(), -1),
|
||||||
m_algorithm(data.algorithm),
|
m_algorithm(data.algorithm),
|
||||||
m_miner(data.miner),
|
m_miner(data.miner)
|
||||||
m_intensity(data.thread.threads() * data.thread.blocks())
|
|
||||||
{
|
{
|
||||||
switch (m_algorithm.family()) {
|
switch (m_algorithm.family()) {
|
||||||
case Algorithm::RANDOM_X:
|
case Algorithm::RANDOM_X:
|
||||||
|
@ -133,7 +132,8 @@ void xmrig::CudaWorker::start()
|
||||||
JobResults::submit(m_job.currentJob(), foundNonce, foundCount);
|
JobResults::submit(m_job.currentJob(), foundNonce, foundCount);
|
||||||
}
|
}
|
||||||
|
|
||||||
m_job.nextRound(roundSize(m_intensity), m_intensity);
|
const size_t batch_size = intensity();
|
||||||
|
m_job.nextRound(roundSize(batch_size), batch_size);
|
||||||
|
|
||||||
storeStats();
|
storeStats();
|
||||||
std::this_thread::yield();
|
std::this_thread::yield();
|
||||||
|
@ -152,7 +152,8 @@ bool xmrig::CudaWorker::consumeJob()
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_job.add(m_miner->job(), Nonce::sequence(Nonce::CUDA), roundSize(m_intensity) * m_intensity);
|
const size_t batch_size = intensity();
|
||||||
|
m_job.add(m_miner->job(), Nonce::sequence(Nonce::CUDA), roundSize(batch_size) * batch_size);
|
||||||
|
|
||||||
return m_runner->set(m_job.currentJob(), m_job.blob());;
|
return m_runner->set(m_job.currentJob(), m_job.blob());;
|
||||||
}
|
}
|
||||||
|
@ -164,7 +165,7 @@ void xmrig::CudaWorker::storeStats()
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_count += m_intensity;
|
m_count += intensity();
|
||||||
|
|
||||||
Worker::storeStats();
|
Worker::storeStats();
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,7 +62,6 @@ private:
|
||||||
|
|
||||||
const Algorithm m_algorithm;
|
const Algorithm m_algorithm;
|
||||||
const Miner *m_miner;
|
const Miner *m_miner;
|
||||||
const uint32_t m_intensity;
|
|
||||||
ICudaRunner *m_runner = nullptr;
|
ICudaRunner *m_runner = nullptr;
|
||||||
WorkerJob<1> m_job;
|
WorkerJob<1> m_job;
|
||||||
};
|
};
|
||||||
|
|
|
@ -51,13 +51,7 @@ bool xmrig::CudaBaseRunner::init()
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!CudaLib::deviceInit(m_ctx)) {
|
return callWrapper(CudaLib::deviceInit(m_ctx));
|
||||||
printError(CudaLib::lastError(m_ctx));
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -66,13 +60,7 @@ bool xmrig::CudaBaseRunner::set(const Job &job, uint8_t *blob)
|
||||||
m_height = job.height();
|
m_height = job.height();
|
||||||
m_target = job.target();
|
m_target = job.target();
|
||||||
|
|
||||||
if (!CudaLib::setJob(m_ctx, blob, job.size(), job.algorithm())) {
|
return callWrapper(CudaLib::setJob(m_ctx, blob, job.size(), job.algorithm()));
|
||||||
printError(CudaLib::lastError(m_ctx));
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -82,9 +70,14 @@ size_t xmrig::CudaBaseRunner::intensity() const
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void xmrig::CudaBaseRunner::printError(const char *error) const
|
bool xmrig::CudaBaseRunner::callWrapper(bool result) const
|
||||||
{
|
{
|
||||||
|
if (!result) {
|
||||||
|
const char *error = CudaLib::lastError(m_ctx);
|
||||||
if (error) {
|
if (error) {
|
||||||
LOG_ERR("%s" RED_S " thread " RED_BOLD("#%zu") RED_S " failed with error " RED_BOLD("%s"), cuda_tag(), m_threadId, error);
|
LOG_ERR("%s" RED_S " thread " RED_BOLD("#%zu") RED_S " failed with error " RED_BOLD("%s"), cuda_tag(), m_threadId, error);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
|
@ -52,7 +52,7 @@ protected:
|
||||||
size_t intensity() const override;
|
size_t intensity() const override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void printError(const char *error) const;
|
bool callWrapper(bool result) const;
|
||||||
|
|
||||||
const CudaLaunchData &m_data;
|
const CudaLaunchData &m_data;
|
||||||
const size_t m_threadId;
|
const size_t m_threadId;
|
||||||
|
|
|
@ -34,11 +34,5 @@ xmrig::CudaCnRunner::CudaCnRunner(size_t index, const CudaLaunchData &data) : Cu
|
||||||
|
|
||||||
bool xmrig::CudaCnRunner::run(uint32_t startNonce, uint32_t *rescount, uint32_t *resnonce)
|
bool xmrig::CudaCnRunner::run(uint32_t startNonce, uint32_t *rescount, uint32_t *resnonce)
|
||||||
{
|
{
|
||||||
if (!CudaLib::cnHash(m_ctx, startNonce, m_height, m_target, rescount, resnonce)) {
|
return callWrapper(CudaLib::cnHash(m_ctx, startNonce, m_height, m_target, rescount, resnonce));
|
||||||
printError(CudaLib::lastError(m_ctx));
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,19 +24,42 @@
|
||||||
|
|
||||||
|
|
||||||
#include "backend/cuda/runners/CudaRxRunner.h"
|
#include "backend/cuda/runners/CudaRxRunner.h"
|
||||||
|
#include "backend/cuda/CudaLaunchData.h"
|
||||||
|
#include "backend/cuda/wrappers/CudaLib.h"
|
||||||
|
#include "base/net/stratum/Job.h"
|
||||||
|
#include "crypto/rx/Rx.h"
|
||||||
|
#include "crypto/rx/RxDataset.h"
|
||||||
|
|
||||||
|
|
||||||
xmrig::CudaRxRunner::CudaRxRunner(size_t index, const CudaLaunchData &data) : CudaBaseRunner(index, data)
|
xmrig::CudaRxRunner::CudaRxRunner(size_t index, const CudaLaunchData &data) : CudaBaseRunner(index, data)
|
||||||
{
|
{
|
||||||
|
m_intensity = m_data.thread.threads() * m_data.thread.blocks();
|
||||||
|
const size_t scratchpads_size = m_intensity * m_data.algorithm.l3();
|
||||||
|
const size_t num_scratchpads = scratchpads_size / m_data.algorithm.l3();
|
||||||
|
|
||||||
|
if (m_intensity > num_scratchpads) {
|
||||||
|
m_intensity = num_scratchpads;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
m_intensity -= m_intensity % 32;
|
||||||
xmrig::CudaRxRunner::~CudaRxRunner()
|
|
||||||
{
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool xmrig::CudaRxRunner::run(uint32_t startNonce, uint32_t *rescount, uint32_t *resnonce)
|
bool xmrig::CudaRxRunner::run(uint32_t startNonce, uint32_t *rescount, uint32_t *resnonce)
|
||||||
{
|
{
|
||||||
return false;
|
return callWrapper(CudaLib::rxHash(m_ctx, startNonce, m_target, rescount, resnonce));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool xmrig::CudaRxRunner::set(const Job &job, uint8_t *blob)
|
||||||
|
{
|
||||||
|
const bool rc = CudaBaseRunner::set(job, blob);
|
||||||
|
if (!rc || m_ready) {
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto dataset = Rx::dataset(job, 0);
|
||||||
|
m_ready = callWrapper(CudaLib::rxPrepare(m_ctx, dataset->raw(), dataset->size(false), m_intensity));
|
||||||
|
|
||||||
|
return m_ready;
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,15 +35,17 @@ namespace xmrig {
|
||||||
class CudaRxRunner : public CudaBaseRunner
|
class CudaRxRunner : public CudaBaseRunner
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
XMRIG_DISABLE_COPY_MOVE_DEFAULT(CudaRxRunner)
|
|
||||||
|
|
||||||
CudaRxRunner(size_t index, const CudaLaunchData &data);
|
CudaRxRunner(size_t index, const CudaLaunchData &data);
|
||||||
~CudaRxRunner() override;
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
inline size_t intensity() const override { return m_intensity; }
|
||||||
|
|
||||||
bool run(uint32_t startNonce, uint32_t *rescount, uint32_t *resnonce) override;
|
bool run(uint32_t startNonce, uint32_t *rescount, uint32_t *resnonce) override;
|
||||||
|
bool set(const Job &job, uint8_t *blob) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
bool m_ready = false;
|
||||||
|
size_t m_intensity = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -58,6 +58,8 @@ static const char *kInit = "init";
|
||||||
static const char *kLastError = "lastError";
|
static const char *kLastError = "lastError";
|
||||||
static const char *kPluginVersion = "pluginVersion";
|
static const char *kPluginVersion = "pluginVersion";
|
||||||
static const char *kRelease = "release";
|
static const char *kRelease = "release";
|
||||||
|
static const char *kRxHash = "rxHash";
|
||||||
|
static const char *kRxPrepare = "rxPrepare";
|
||||||
static const char *kSetJob = "setJob";
|
static const char *kSetJob = "setJob";
|
||||||
static const char *kSymbolNotFound = "symbol not found";
|
static const char *kSymbolNotFound = "symbol not found";
|
||||||
static const char *kVersion = "version";
|
static const char *kVersion = "version";
|
||||||
|
@ -76,6 +78,8 @@ using init_t = void (*)();
|
||||||
using lastError_t = const char * (*)(nvid_ctx *);
|
using lastError_t = const char * (*)(nvid_ctx *);
|
||||||
using pluginVersion_t = const char * (*)();
|
using pluginVersion_t = const char * (*)();
|
||||||
using release_t = void (*)(nvid_ctx *);
|
using release_t = void (*)(nvid_ctx *);
|
||||||
|
using rxHash_t = bool (*)(nvid_ctx *, uint32_t, uint64_t, uint32_t *, uint32_t *);
|
||||||
|
using rxPrepare_t = bool (*)(nvid_ctx *, const void *, size_t, uint32_t);
|
||||||
using setJob_t = bool (*)(nvid_ctx *, const void *, size_t, int32_t);
|
using setJob_t = bool (*)(nvid_ctx *, const void *, size_t, int32_t);
|
||||||
using version_t = uint32_t (*)(Version);
|
using version_t = uint32_t (*)(Version);
|
||||||
|
|
||||||
|
@ -93,6 +97,8 @@ static init_t pInit = nullptr;
|
||||||
static lastError_t pLastError = nullptr;
|
static lastError_t pLastError = nullptr;
|
||||||
static pluginVersion_t pPluginVersion = nullptr;
|
static pluginVersion_t pPluginVersion = nullptr;
|
||||||
static release_t pRelease = nullptr;
|
static release_t pRelease = nullptr;
|
||||||
|
static rxHash_t pRxHash = nullptr;
|
||||||
|
static rxPrepare_t pRxPrepare = nullptr;
|
||||||
static setJob_t pSetJob = nullptr;
|
static setJob_t pSetJob = nullptr;
|
||||||
static version_t pVersion = nullptr;
|
static version_t pVersion = nullptr;
|
||||||
|
|
||||||
|
@ -144,6 +150,18 @@ bool xmrig::CudaLib::deviceInit(nvid_ctx *ctx) noexcept
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool xmrig::CudaLib::rxHash(nvid_ctx *ctx, uint32_t startNonce, uint64_t target, uint32_t *rescount, uint32_t *resnonce) noexcept
|
||||||
|
{
|
||||||
|
return pRxHash(ctx, startNonce, target, rescount, resnonce);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool xmrig::CudaLib::rxPrepare(nvid_ctx *ctx, const void *dataset, size_t datasetSize, uint32_t batchSize) noexcept
|
||||||
|
{
|
||||||
|
return pRxPrepare(ctx, dataset, datasetSize, batchSize);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
bool xmrig::CudaLib::setJob(nvid_ctx *ctx, const void *data, size_t size, const Algorithm &algorithm) noexcept
|
bool xmrig::CudaLib::setJob(nvid_ctx *ctx, const void *data, size_t size, const Algorithm &algorithm) noexcept
|
||||||
{
|
{
|
||||||
return pSetJob(ctx, data, size, algorithm);
|
return pSetJob(ctx, data, size, algorithm);
|
||||||
|
@ -267,6 +285,8 @@ bool xmrig::CudaLib::load()
|
||||||
DLSYM(LastError);
|
DLSYM(LastError);
|
||||||
DLSYM(PluginVersion);
|
DLSYM(PluginVersion);
|
||||||
DLSYM(Release);
|
DLSYM(Release);
|
||||||
|
DLSYM(RxHash);
|
||||||
|
DLSYM(RxPrepare);
|
||||||
DLSYM(SetJob);
|
DLSYM(SetJob);
|
||||||
DLSYM(Version);
|
DLSYM(Version);
|
||||||
} catch (std::exception &ex) {
|
} catch (std::exception &ex) {
|
||||||
|
|
|
@ -72,6 +72,8 @@ public:
|
||||||
|
|
||||||
static bool cnHash(nvid_ctx *ctx, uint32_t startNonce, uint64_t height, uint64_t target, uint32_t *rescount, uint32_t *resnonce);
|
static bool cnHash(nvid_ctx *ctx, uint32_t startNonce, uint64_t height, uint64_t target, uint32_t *rescount, uint32_t *resnonce);
|
||||||
static bool deviceInit(nvid_ctx *ctx) noexcept;
|
static bool deviceInit(nvid_ctx *ctx) noexcept;
|
||||||
|
static bool rxHash(nvid_ctx *ctx, uint32_t startNonce, uint64_t target, uint32_t *rescount, uint32_t *resnonce) noexcept;
|
||||||
|
static bool rxPrepare(nvid_ctx *ctx, const void *dataset, size_t datasetSize, uint32_t batchSize) noexcept;
|
||||||
static bool setJob(nvid_ctx *ctx, const void *data, size_t size, const Algorithm &algorithm) noexcept;
|
static bool setJob(nvid_ctx *ctx, const void *data, size_t size, const Algorithm &algorithm) noexcept;
|
||||||
static const char *deviceName(nvid_ctx *ctx) noexcept;
|
static const char *deviceName(nvid_ctx *ctx) noexcept;
|
||||||
static const char *lastError(nvid_ctx *ctx) noexcept;
|
static const char *lastError(nvid_ctx *ctx) noexcept;
|
||||||
|
|
Loading…
Reference in a new issue