mirror of
https://github.com/xmrig/xmrig.git
synced 2025-01-25 20:16:05 +00:00
Workaround for unsupported intensity option + warning.
This commit is contained in:
parent
370be64f30
commit
9660dfc7b3
3 changed files with 60 additions and 27 deletions
|
@ -43,7 +43,7 @@ class Threads
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
inline bool has(const char *profile) const { return m_profiles.count(profile) > 0; }
|
inline bool has(const char *profile) const { return m_profiles.count(profile) > 0; }
|
||||||
inline bool isDisabled(const Algorithm &algo) const { return m_disabled.count(algo) > 0 || algo == Algorithm::RX_0; }
|
inline bool isDisabled(const Algorithm &algo) const { return m_disabled.count(algo) > 0; }
|
||||||
inline bool isExist(const Algorithm &algo) const { return isDisabled(algo) || m_aliases.count(algo) > 0 || has(algo.shortName()); }
|
inline bool isExist(const Algorithm &algo) const { return isDisabled(algo) || m_aliases.count(algo) > 0 || has(algo.shortName()); }
|
||||||
inline const std::vector<T> &get(const Algorithm &algo, bool strict = false) const { return get(profileName(algo, strict)); }
|
inline const std::vector<T> &get(const Algorithm &algo, bool strict = false) const { return get(profileName(algo, strict)); }
|
||||||
inline void disable(const Algorithm &algo) { m_disabled.insert(algo); }
|
inline void disable(const Algorithm &algo) { m_disabled.insert(algo); }
|
||||||
|
|
|
@ -137,52 +137,84 @@ void xmrig::Workers<T>::tick(uint64_t)
|
||||||
|
|
||||||
|
|
||||||
template<class T>
|
template<class T>
|
||||||
void xmrig::Workers<T>::onReady(void *)
|
xmrig::IWorker *xmrig::Workers<T>::create(Thread<CpuLaunchData> *)
|
||||||
{
|
{
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
template<class T>
|
||||||
|
void xmrig::Workers<T>::onReady(void *arg)
|
||||||
|
{
|
||||||
|
Thread<T> *handle = static_cast<Thread<T>* >(arg);
|
||||||
|
|
||||||
|
IWorker *worker = create(handle);
|
||||||
|
if (!worker || !worker->selfTest()) {
|
||||||
|
LOG_ERR("thread %zu error: \"hash self-test failed\".", worker->id());
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
handle->setWorker(worker);
|
||||||
|
handle->backend()->start(worker);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
namespace xmrig {
|
namespace xmrig {
|
||||||
|
|
||||||
|
|
||||||
template<>
|
#if defined (XMRIG_ALGO_RANDOMX) || defined (XMRIG_ALGO_CN_GPU)
|
||||||
void xmrig::Workers<CpuLaunchData>::onReady(void *arg)
|
static void printIntensityWarning(Thread<CpuLaunchData> *handle)
|
||||||
{
|
{
|
||||||
auto handle = static_cast<Thread<CpuLaunchData>* >(arg);
|
LOG_WARN("CPU thread %zu warning: \"intensity %d not supported for %s algorithm\".", handle->index(), handle->config().intensity, handle->config().algorithm.shortName());
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
IWorker *worker = nullptr;
|
|
||||||
|
|
||||||
switch (handle->config().intensity) {
|
template<>
|
||||||
|
xmrig::IWorker *xmrig::Workers<CpuLaunchData>::create(Thread<CpuLaunchData> *handle)
|
||||||
|
{
|
||||||
|
const int intensity = handle->config().intensity;
|
||||||
|
|
||||||
|
# if defined (XMRIG_ALGO_RANDOMX) || defined (XMRIG_ALGO_CN_GPU)
|
||||||
|
if (intensity > 1) {
|
||||||
|
# ifdef XMRIG_ALGO_RANDOMX
|
||||||
|
if (handle->config().algorithm.family() == Algorithm::RANDOM_X) {
|
||||||
|
printIntensityWarning(handle);
|
||||||
|
|
||||||
|
return new CpuWorker<1>(handle->index(), handle->config());
|
||||||
|
}
|
||||||
|
# endif
|
||||||
|
|
||||||
|
# ifdef XMRIG_ALGO_CN_GPU
|
||||||
|
if (handle->config().algorithm == Algorithm::CN_GPU) {
|
||||||
|
printIntensityWarning(handle);
|
||||||
|
|
||||||
|
return new CpuWorker<1>(handle->index(), handle->config());
|
||||||
|
}
|
||||||
|
# endif
|
||||||
|
}
|
||||||
|
# endif
|
||||||
|
|
||||||
|
|
||||||
|
switch (intensity) {
|
||||||
case 1:
|
case 1:
|
||||||
worker = new CpuWorker<1>(handle->index(), handle->config());
|
return new CpuWorker<1>(handle->index(), handle->config());
|
||||||
break;
|
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
worker = new CpuWorker<2>(handle->index(), handle->config());
|
return new CpuWorker<2>(handle->index(), handle->config());
|
||||||
break;
|
|
||||||
|
|
||||||
case 3:
|
case 3:
|
||||||
worker = new CpuWorker<3>(handle->index(), handle->config());
|
return new CpuWorker<3>(handle->index(), handle->config());
|
||||||
break;
|
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
worker = new CpuWorker<4>(handle->index(), handle->config());
|
return new CpuWorker<4>(handle->index(), handle->config());
|
||||||
break;
|
|
||||||
|
|
||||||
case 5:
|
case 5:
|
||||||
worker = new CpuWorker<5>(handle->index(), handle->config());
|
return new CpuWorker<5>(handle->index(), handle->config());
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
handle->setWorker(worker);
|
return nullptr;
|
||||||
|
|
||||||
if (!worker->selfTest()) {
|
|
||||||
LOG_ERR("thread %zu error: \"hash self-test failed\".", handle->worker()->id());
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
handle->backend()->start(worker);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -52,6 +52,7 @@ public:
|
||||||
void tick(uint64_t ticks);
|
void tick(uint64_t ticks);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
static IWorker *create(Thread<CpuLaunchData> *handle);
|
||||||
static void onReady(void *arg);
|
static void onReady(void *arg);
|
||||||
|
|
||||||
std::vector<Thread<T> *> m_workers;
|
std::vector<Thread<T> *> m_workers;
|
||||||
|
@ -60,7 +61,7 @@ private:
|
||||||
|
|
||||||
|
|
||||||
template<>
|
template<>
|
||||||
void Workers<CpuLaunchData>::onReady(void *arg);
|
IWorker *Workers<CpuLaunchData>::create(Thread<CpuLaunchData> *handle);
|
||||||
|
|
||||||
|
|
||||||
extern template class Workers<CpuLaunchData>;
|
extern template class Workers<CpuLaunchData>;
|
||||||
|
|
Loading…
Reference in a new issue