Merge pull request #1897 from SChernykh/dev

Benchmark: added more check hashes and a progress indicator
This commit is contained in:
xmrig 2020-10-15 15:08:33 +07:00 committed by GitHub
commit f3ea3c5227
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 42 additions and 30 deletions

View file

@ -7,7 +7,7 @@ xmrig --bench=10M
xmrig --bench=1M -a rx/wow xmrig --bench=1M -a rx/wow
xmrig --bench=10M -a rx/wow xmrig --bench=10M -a rx/wow
``` ```
This will run 1 or 10 millions RandomX hashes and print the time it took. First two commands use Monero variant (2 MB per thread, best for Zen2/Zen3 CPUs), second two commands use Wownero variant (1 MB per thread, useful for Intel and 1st gen Zen/Zen+ CPUs). This will run between 1 and 10 million RandomX hashes, depending on `bench` parameter, and print the time it took. First two commands use Monero variant (2 MB per thread, best for Zen2/Zen3 CPUs), second two commands use Wownero variant (1 MB per thread, useful for Intel and 1st gen Zen/Zen+ CPUs).
Checksum of all the hashes will be also printed to check stability of your hardware: if it's green then it's correct, if it's red then there was hardware error during computation. No Internet connection is required for the benchmark. Checksum of all the hashes will be also printed to check stability of your hardware: if it's green then it's correct, if it's red then there was hardware error during computation. No Internet connection is required for the benchmark.

View file

@ -30,6 +30,7 @@
#include "backend/cpu/CpuWorker.h" #include "backend/cpu/CpuWorker.h"
#include "base/io/log/Log.h" #include "base/io/log/Log.h"
#include "base/io/log/Tags.h" #include "base/io/log/Tags.h"
#include "base/net/stratum/Pool.h"
#include "base/tools/Chrono.h" #include "base/tools/Chrono.h"
#include "base/tools/Object.h" #include "base/tools/Object.h"
#include "core/Miner.h" #include "core/Miner.h"
@ -205,33 +206,32 @@ bool xmrig::Workers<T>::tick(uint64_t)
d_ptr->hashrate->add(0, totalHashCount, Chrono::steadyMSecs()); d_ptr->hashrate->add(0, totalHashCount, Chrono::steadyMSecs());
} }
if (d_ptr->bench && (benchDone == m_workers.size())) { if (d_ptr->bench) {
Pool::benchProgress = std::min<uint32_t>(static_cast<uint32_t>((totalHashCount * 100U) / d_ptr->bench), 100U);
if (benchDone == m_workers.size()) {
const double dt = (benchDoneTime - d_ptr->startTime) / 1000.0; const double dt = (benchDoneTime - d_ptr->startTime) / 1000.0;
static uint64_t hashCheck[Algorithm::MAX][2] = {}; uint64_t checkData = 0;
hashCheck[Algorithm::RX_0][0] = 0x898B6E0431C28A6BULL;
hashCheck[Algorithm::RX_0][1] = 0xB5231262E2792B26ULL;
hashCheck[Algorithm::RX_WOW][0] = 0x0F3E5400B39EA96AULL;
hashCheck[Algorithm::RX_WOW][1] = 0x0F9E00C5A511C200ULL;
int k = -1; const Algorithm::Id algo = d_ptr->benchAlgo.id();
const uint32_t N = (d_ptr->bench / 1000000) - 1;
switch (d_ptr->bench) { if (((algo == Algorithm::RX_0) || (algo == Algorithm::RX_WOW)) && ((d_ptr->bench % 1000000) == 0) && (N < 10)) {
case 1000000: static uint64_t hashCheck[2][10] = {
k = 0; { 0x898B6E0431C28A6BULL, 0xEE9468F8B40926BCULL, 0xC2BC5D11724813C0ULL, 0x3A2C7B285B87F941ULL, 0x3B5BD2C3A16B450EULL, 0x5CD0602F20C5C7C4ULL, 0x101DE939474B6812ULL, 0x52B765A1B156C6ECULL, 0x323935102AB6B45CULL, 0xB5231262E2792B26ULL },
break; { 0x0F3E5400B39EA96AULL, 0x85944CCFA2752D1FULL, 0x64AFFCAE991811BAULL, 0x3E4D0B836D3B13BAULL, 0xEB7417D621271166ULL, 0x97FFE10C0949FFA5ULL, 0x84CAC0F8879A4BA1ULL, 0xA1B79F031DA2459FULL, 0x9B65226DA873E65DULL, 0x0F9E00C5A511C200ULL },
};
case 10000000: checkData = hashCheck[(algo == Algorithm::RX_0) ? 0 : 1][N];
k = 1;
break;
} }
const uint64_t checkData = (k >= 0) ? hashCheck[d_ptr->benchAlgo.id()][k] : 0;
const char* color = checkData ? ((benchData == checkData) ? GREEN_BOLD_S : RED_BOLD_S) : BLACK_BOLD_S; const char* color = checkData ? ((benchData == checkData) ? GREEN_BOLD_S : RED_BOLD_S) : BLACK_BOLD_S;
LOG_INFO("%s Benchmark finished in %.3f seconds, hash sum = %s%016" PRIX64 CLEAR, Tags::miner(), dt, color, benchData); LOG_INFO("%s Benchmark finished in %.3f seconds, hash sum = %s%016" PRIX64 CLEAR, Tags::miner(), dt, color, benchData);
return false; return false;
} }
}
return true; return true;
} }

View file

@ -86,6 +86,9 @@ const char *Pool::kBenchmark = "benchmark";
const char *Pool::kNicehashHost = "nicehash.com"; const char *Pool::kNicehashHost = "nicehash.com";
uint32_t Pool::benchProgress = 0;
} }
@ -136,11 +139,13 @@ xmrig::Pool::Pool(const rapidjson::Value &object) :
const char* benchSize = Json::getString(object, kBenchmark, nullptr); const char* benchSize = Json::getString(object, kBenchmark, nullptr);
if (benchSize) { if (benchSize) {
if (strcasecmp(benchSize, "1M") == 0) { std::string s;
m_benchSize = 1000000; for (int i = 1; i <= 10; ++i) {
s = std::to_string(i) + "M";
if (strcasecmp(benchSize, s.c_str()) == 0) {
m_benchSize = i * 1000000;
break;
} }
else if (strcasecmp(benchSize, "10M") == 0) {
m_benchSize = 10000000;
} }
} }

View file

@ -121,6 +121,8 @@ public:
void print() const; void print() const;
# endif # endif
static uint32_t benchProgress;
private: private:
enum Flags { enum Flags {
FLAG_ENABLED, FLAG_ENABLED,

View file

@ -304,8 +304,13 @@ public:
} }
# endif # endif
LOG_INFO("%s " WHITE_BOLD("speed") " 10s/60s/15m " CYAN_BOLD("%s") CYAN(" %s %s ") CYAN_BOLD("%s") " max " CYAN_BOLD("%s %s"), char benchProgress[8] = {};
Tags::miner(), if (Pool::benchProgress) {
sprintf(benchProgress, "%3u%% ", Pool::benchProgress);
}
LOG_INFO("%s %s" WHITE_BOLD("speed") " 10s/60s/15m " CYAN_BOLD("%s") CYAN(" %s %s ") CYAN_BOLD("%s") " max " CYAN_BOLD("%s %s"),
Tags::miner(), benchProgress,
Hashrate::format(speed[0] * scale, num, sizeof(num) / 4), Hashrate::format(speed[0] * scale, num, sizeof(num) / 4),
Hashrate::format(speed[1] * scale, num + 16, sizeof(num) / 4), Hashrate::format(speed[1] * scale, num + 16, sizeof(num) / 4),
Hashrate::format(speed[2] * scale, num + 16 * 2, sizeof(num) / 4), h, Hashrate::format(speed[2] * scale, num + 16 * 2, sizeof(num) / 4), h,

View file

@ -179,7 +179,7 @@ static inline const std::string &usage()
# endif # endif
u += " --pause-on-battery pause mine on battery power\n"; u += " --pause-on-battery pause mine on battery power\n";
u += " --stress run continuous stress test to check system stability\n"; u += " --stress run continuous stress test to check system stability\n";
u += " --bench=N run benchmark in offline mode, N can be 1M or 10M\n"; u += " --bench=N run benchmark in offline mode, N can be between 1M and 10M\n";
return u; return u;
} }