Merge pull request #2039 from SChernykh/dev

Fixed solo mining
This commit is contained in:
xmrig 2021-01-15 18:49:04 +07:00 committed by GitHub
commit fa11cb623d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 8 additions and 6 deletions

View file

@ -104,7 +104,7 @@ int64_t xmrig::DaemonClient::submit(const JobResult &result)
# ifdef XMRIG_PROXY_PROJECT # ifdef XMRIG_PROXY_PROJECT
memcpy(data + 78, result.nonce, 8); memcpy(data + 78, result.nonce, 8);
# else # else
Cvt::toHex(data + 78, 9, reinterpret_cast<const uint8_t *>(&result.nonce), 4); Cvt::toHex(data + 78, 8, reinterpret_cast<const uint8_t *>(&result.nonce), 4);
# endif # endif
using namespace rapidjson; using namespace rapidjson;
@ -227,7 +227,7 @@ bool xmrig::DaemonClient::parseJob(const rapidjson::Value &params, int *code)
m_blockhashingblob = Json::getString(params, "blockhashing_blob"); m_blockhashingblob = Json::getString(params, "blockhashing_blob");
if (m_apiVersion == API_DERO) { if (m_apiVersion == API_DERO) {
const uint64_t offset = Json::getUint64(params, "reserved_offset"); const uint64_t offset = Json::getUint64(params, "reserved_offset");
Cvt::toHex(m_blockhashingblob.data() + offset * 2, kBlobReserveSize * 2 + 1, Cvt::randomBytes(kBlobReserveSize).data(), kBlobReserveSize); Cvt::toHex(m_blockhashingblob.data() + offset * 2, kBlobReserveSize * 2, Cvt::randomBytes(kBlobReserveSize).data(), kBlobReserveSize);
} }
if (blocktemplate.isNull() || !job.setBlob(m_blockhashingblob)) { if (blocktemplate.isNull() || !job.setBlob(m_blockhashingblob)) {

View file

@ -46,7 +46,7 @@ static char *cvt_bin2hex(char *const hex, const size_t hex_maxlen, const unsigne
int b; int b;
int c; int c;
if (bin_len >= SIZE_MAX / 2 || hex_maxlen <= bin_len * 2U) { if (bin_len >= SIZE_MAX / 2 || hex_maxlen < bin_len * 2U) {
return nullptr; /* LCOV_EXCL_LINE */ return nullptr; /* LCOV_EXCL_LINE */
} }
@ -60,7 +60,10 @@ static char *cvt_bin2hex(char *const hex, const size_t hex_maxlen, const unsigne
hex[i * 2U + 1U] = (char) x; hex[i * 2U + 1U] = (char) x;
i++; i++;
} }
if (i * 2U < hex_maxlen) {
hex[i * 2U] = 0U; hex[i * 2U] = 0U;
}
return hex; return hex;
} }
@ -137,7 +140,6 @@ static int cvt_hex2bin(unsigned char *const bin, const size_t bin_maxlen, const
return ret; return ret;
} }
#define sodium_bin2hex cvt_bin2hex
#define sodium_hex2bin cvt_hex2bin #define sodium_hex2bin cvt_hex2bin
#endif #endif
@ -215,7 +217,7 @@ xmrig::Buffer xmrig::Cvt::fromHex(const char *in, size_t size)
bool xmrig::Cvt::toHex(char *hex, size_t hex_maxlen, const uint8_t *bin, size_t bin_len) bool xmrig::Cvt::toHex(char *hex, size_t hex_maxlen, const uint8_t *bin, size_t bin_len)
{ {
return sodium_bin2hex(hex, hex_maxlen, bin, bin_len) != nullptr; return cvt_bin2hex(hex, hex_maxlen, bin, bin_len) != nullptr;
} }