Merge branch 'dev'

This commit is contained in:
XMRig 2020-04-23 12:46:41 +07:00
commit a8e91bb888
No known key found for this signature in database
GPG key ID: 446A53638BE94409
20 changed files with 41 additions and 26 deletions

View file

@ -1,3 +1,8 @@
# v5.11.1
- [#1652](https://github.com/xmrig/xmrig/pull/1652) Up to 1% RandomX perfomance improvement on recent AMD CPUs.
- [#1306](https://github.com/xmrig/xmrig/issues/1306) Fixed possible double connection to a pool.
- [#1654](https://github.com/xmrig/xmrig/issues/1654) Fixed build with LibreSSL.
# v5.11.0 # v5.11.0
- **[#1632](https://github.com/xmrig/xmrig/pull/1632) Added AstroBWT CUDA support ([CUDA plugin](https://github.com/xmrig/xmrig-cuda) v3.0.0 or newer required).** - **[#1632](https://github.com/xmrig/xmrig/pull/1632) Added AstroBWT CUDA support ([CUDA plugin](https://github.com/xmrig/xmrig-cuda) v3.0.0 or newer required).**
- [#1605](https://github.com/xmrig/xmrig/pull/1605) Fixed AstroBWT OpenCL for NVIDIA GPUs. - [#1605](https://github.com/xmrig/xmrig/pull/1605) Fixed AstroBWT OpenCL for NVIDIA GPUs.

View file

@ -67,6 +67,7 @@ set(HEADERS_CRYPTO
src/crypto/cn/c_groestl.h src/crypto/cn/c_groestl.h
src/crypto/cn/c_jh.h src/crypto/cn/c_jh.h
src/crypto/cn/c_skein.h src/crypto/cn/c_skein.h
src/crypto/cn/CnAlgo.h
src/crypto/cn/CnCtx.h src/crypto/cn/CnCtx.h
src/crypto/cn/CnHash.h src/crypto/cn/CnHash.h
src/crypto/cn/CryptoNight_monero.h src/crypto/cn/CryptoNight_monero.h

View file

@ -25,7 +25,7 @@
#include "backend/common/Threads.h" #include "backend/common/Threads.h"
#include "backend/cpu/CpuThreads.h" #include "backend/cpu/CpuThreads.h"
#include "base/crypto/CnAlgo.h" #include "crypto/cn/CnAlgo.h"
#include "rapidjson/document.h" #include "rapidjson/document.h"

View file

@ -27,7 +27,7 @@
#include "backend/opencl/OclThreads.h" #include "backend/opencl/OclThreads.h"
#include "backend/opencl/wrappers/OclDevice.h" #include "backend/opencl/wrappers/OclDevice.h"
#include "base/crypto/Algorithm.h" #include "base/crypto/Algorithm.h"
#include "base/crypto/CnAlgo.h" #include "crypto/cn/CnAlgo.h"
#include <algorithm> #include <algorithm>

View file

@ -27,7 +27,7 @@
#include "backend/opencl/OclThreads.h" #include "backend/opencl/OclThreads.h"
#include "backend/opencl/wrappers/OclDevice.h" #include "backend/opencl/wrappers/OclDevice.h"
#include "base/crypto/Algorithm.h" #include "base/crypto/Algorithm.h"
#include "base/crypto/CnAlgo.h" #include "crypto/cn/CnAlgo.h"
#include <algorithm> #include <algorithm>

View file

@ -31,9 +31,9 @@
#include "backend/opencl/OclLaunchData.h" #include "backend/opencl/OclLaunchData.h"
#include "backend/opencl/runners/tools/OclCnR.h" #include "backend/opencl/runners/tools/OclCnR.h"
#include "backend/opencl/wrappers/OclLib.h" #include "backend/opencl/wrappers/OclLib.h"
#include "base/crypto/CnAlgo.h"
#include "base/io/log/Log.h" #include "base/io/log/Log.h"
#include "base/net/stratum/Job.h" #include "base/net/stratum/Job.h"
#include "crypto/cn/CnAlgo.h"
xmrig::OclCnRunner::OclCnRunner(size_t index, const OclLaunchData &data) : OclBaseRunner(index, data) xmrig::OclCnRunner::OclCnRunner(size_t index, const OclLaunchData &data) : OclBaseRunner(index, data)

View file

@ -31,9 +31,9 @@
#include "backend/opencl/kernels/CnBranchKernel.h" #include "backend/opencl/kernels/CnBranchKernel.h"
#include "backend/opencl/OclLaunchData.h" #include "backend/opencl/OclLaunchData.h"
#include "backend/opencl/wrappers/OclLib.h" #include "backend/opencl/wrappers/OclLib.h"
#include "base/crypto/CnAlgo.h"
#include "base/io/log/Log.h" #include "base/io/log/Log.h"
#include "base/net/stratum/Job.h" #include "base/net/stratum/Job.h"
#include "crypto/cn/CnAlgo.h"
xmrig::OclRyoRunner::OclRyoRunner(size_t index, const OclLaunchData &data) : OclBaseRunner(index, data) xmrig::OclRyoRunner::OclRyoRunner(size_t index, const OclLaunchData &data) : OclBaseRunner(index, data)

View file

@ -1,7 +1,6 @@
set(HEADERS_BASE set(HEADERS_BASE
src/base/api/interfaces/IApiListener.h src/base/api/interfaces/IApiListener.h
src/base/crypto/Algorithm.h src/base/crypto/Algorithm.h
src/base/crypto/CnAlgo.h
src/base/crypto/Coin.h src/base/crypto/Coin.h
src/base/crypto/keccak.h src/base/crypto/keccak.h
src/base/io/Console.h src/base/io/Console.h

View file

@ -79,10 +79,14 @@ static int showVersion()
printf("\nlibuv/%s\n", uv_version_string()); printf("\nlibuv/%s\n", uv_version_string());
# if defined(XMRIG_FEATURE_TLS) && defined(OPENSSL_VERSION_TEXT) # if defined(XMRIG_FEATURE_TLS)
{ {
# if defined(LIBRESSL_VERSION_TEXT)
printf("LibreSSL/%s\n", LIBRESSL_VERSION_TEXT + 9);
# elif defined(OPENSSL_VERSION_TEXT)
constexpr const char *v = OPENSSL_VERSION_TEXT + 8; constexpr const char *v = OPENSSL_VERSION_TEXT + 8;
printf("OpenSSL/%.*s\n", static_cast<int>(strchr(v, ' ') - v), v); printf("OpenSSL/%.*s\n", static_cast<int>(strchr(v, ' ') - v), v);
# endif
} }
# endif # endif

View file

@ -145,11 +145,16 @@ void xmrig::BaseConfig::printVersions()
std::string libs; std::string libs;
# if defined(XMRIG_FEATURE_TLS) && defined(OPENSSL_VERSION_TEXT) # if defined(XMRIG_FEATURE_TLS)
{ {
# if defined(LIBRESSL_VERSION_TEXT)
snprintf(buf, sizeof buf, "LibreSSL/%s ", LIBRESSL_VERSION_TEXT + 9);
libs += buf;
# elif defined(OPENSSL_VERSION_TEXT)
constexpr const char *v = OPENSSL_VERSION_TEXT + 8; constexpr const char *v = OPENSSL_VERSION_TEXT + 8;
snprintf(buf, sizeof buf, "OpenSSL/%.*s ", static_cast<int>(strchr(v, ' ') - v), v); snprintf(buf, sizeof buf, "OpenSSL/%.*s ", static_cast<int>(strchr(v, ' ') - v), v);
libs += buf; libs += buf;
# endif
} }
# endif # endif

View file

@ -293,7 +293,7 @@ void xmrig::Client::tick(uint64_t now)
} }
if (m_state == ConnectingState && m_expire && now > m_expire) { if (m_state == ConnectingState && m_expire && now > m_expire) {
return reconnect(); close();
} }
} }
@ -744,6 +744,7 @@ void xmrig::Client::parseExtensions(const rapidjson::Value &result)
} }
else if (strcmp(name, "keepalive") == 0) { else if (strcmp(name, "keepalive") == 0) {
setExtension(EXT_KEEPALIVE, true); setExtension(EXT_KEEPALIVE, true);
startTimeout();
} }
# ifdef XMRIG_FEATURE_TLS # ifdef XMRIG_FEATURE_TLS
else if (strcmp(name, "tls") == 0) { else if (strcmp(name, "tls") == 0) {
@ -974,7 +975,7 @@ void xmrig::Client::onConnect(uv_connect_t *req, int status)
LOG_ERR("[%s] connect error: \"%s\"", client->url(), uv_strerror(status)); LOG_ERR("[%s] connect error: \"%s\"", client->url(), uv_strerror(status));
} }
if (client->state() == ReconnectingState) { if (client->state() == ReconnectingState || client->state() == ClosingState) {
return; return;
} }
@ -991,7 +992,7 @@ void xmrig::Client::onConnect(uv_connect_t *req, int status)
} }
if (client->state() == ConnectedState) { if (client->state() == ConnectedState) {
LOG_ERR("[%s] already connected"); LOG_ERR("[%s] already connected", client->url());
return; return;
} }

View file

@ -156,7 +156,7 @@ bool xmrig::TlsContext::load(const TlsConfig &config)
SSL_CTX_set_options(m_ctx, SSL_OP_NO_SSLv2 | SSL_OP_NO_SSLv3); SSL_CTX_set_options(m_ctx, SSL_OP_NO_SSLv2 | SSL_OP_NO_SSLv3);
SSL_CTX_set_options(m_ctx, SSL_OP_CIPHER_SERVER_PREFERENCE); SSL_CTX_set_options(m_ctx, SSL_OP_CIPHER_SERVER_PREFERENCE);
# if OPENSSL_VERSION_NUMBER >= 0x1010100fL # if OPENSSL_VERSION_NUMBER >= 0x1010100fL && !defined(LIBRESSL_VERSION_NUMBER)
SSL_CTX_set_max_early_data(m_ctx, 0); SSL_CTX_set_max_early_data(m_ctx, 0);
# endif # endif
@ -184,7 +184,7 @@ bool xmrig::TlsContext::setCipherSuites(const char *ciphersuites)
return true; return true;
} }
# if OPENSSL_VERSION_NUMBER >= 0x1010100fL # if OPENSSL_VERSION_NUMBER >= 0x1010100fL && !defined(LIBRESSL_VERSION_NUMBER)
if (SSL_CTX_set_ciphersuites(m_ctx, ciphersuites) == 1) { if (SSL_CTX_set_ciphersuites(m_ctx, ciphersuites) == 1) {
return true; return true;
} }

View file

@ -31,7 +31,7 @@
#include <cstdint> #include <cstdint>
#include "base/crypto/CnAlgo.h" #include "crypto/cn/CnAlgo.h"
#include "crypto/common/Assembly.h" #include "crypto/common/Assembly.h"

View file

@ -28,8 +28,8 @@
#define XMRIG_CRYPTONIGHT_ARM_H #define XMRIG_CRYPTONIGHT_ARM_H
#include "base/crypto/CnAlgo.h"
#include "base/crypto/keccak.h" #include "base/crypto/keccak.h"
#include "crypto/cn/CnAlgo.h"
#include "crypto/cn/CryptoNight_monero.h" #include "crypto/cn/CryptoNight_monero.h"
#include "crypto/cn/CryptoNight.h" #include "crypto/cn/CryptoNight.h"
#include "crypto/cn/soft_aes.h" #include "crypto/cn/soft_aes.h"

View file

@ -36,8 +36,8 @@
#include "backend/cpu/Cpu.h" #include "backend/cpu/Cpu.h"
#include "base/crypto/CnAlgo.h"
#include "base/crypto/keccak.h" #include "base/crypto/keccak.h"
#include "crypto/cn/CnAlgo.h"
#include "crypto/cn/CryptoNight_monero.h" #include "crypto/cn/CryptoNight_monero.h"
#include "crypto/cn/CryptoNight.h" #include "crypto/cn/CryptoNight.h"
#include "crypto/cn/soft_aes.h" #include "crypto/cn/soft_aes.h"

View file

@ -23,7 +23,7 @@
*/ */
#include "base/crypto/CnAlgo.h" #include "crypto/cn/CnAlgo.h"
#ifdef __GNUC__ #ifdef __GNUC__

View file

@ -23,7 +23,7 @@
*/ */
#include "base/crypto/CnAlgo.h" #include "crypto/cn/CnAlgo.h"
#ifdef __GNUC__ #ifdef __GNUC__

View file

@ -1048,9 +1048,9 @@ namespace randomx {
if (vm_flags & RANDOMX_FLAG_AMD) { if (vm_flags & RANDOMX_FLAG_AMD) {
*(uint64_t*)(p + pos + 7) = 0x742024443B0CE083ULL; *(uint64_t*)(p + pos + 7) = 0x742024443B0CE083ULL;
*(uint8_t*)(p + pos + 15) = 8; *(uint64_t*)(p + pos + 15) = 0x8900EB0414AE0F0AULL;
*(uint64_t*)(p + pos + 16) = 0x202444890414AE0FULL; *(uint32_t*)(p + pos + 23) = 0x202444;
pos += 24; pos += 26;
} }
else { else {
*(uint64_t*)(p + pos + 7) = 0x0414AE0F0CE083ULL; *(uint64_t*)(p + pos + 7) = 0x0414AE0F0CE083ULL;
@ -1071,9 +1071,9 @@ namespace randomx {
if (vm_flags & RANDOMX_FLAG_AMD) { if (vm_flags & RANDOMX_FLAG_AMD) {
*(uint64_t*)(p + pos + 6) = 0x742024443B0CE083ULL; *(uint64_t*)(p + pos + 6) = 0x742024443B0CE083ULL;
*(uint8_t*)(p + pos + 14) = 8; *(uint64_t*)(p + pos + 14) = 0x8900EB0414AE0F0AULL;
*(uint64_t*)(p + pos + 15) = 0x202444890414AE0FULL; *(uint32_t*)(p + pos + 22) = 0x202444;
pos += 23; pos += 25;
} }
else { else {
*(uint64_t*)(p + pos + 6) = 0x0414AE0F0CE083ULL; *(uint64_t*)(p + pos + 6) = 0x0414AE0F0CE083ULL;

View file

@ -28,7 +28,7 @@
#define APP_ID "xmrig" #define APP_ID "xmrig"
#define APP_NAME "XMRig" #define APP_NAME "XMRig"
#define APP_DESC "XMRig miner" #define APP_DESC "XMRig miner"
#define APP_VERSION "5.11.0" #define APP_VERSION "5.11.1"
#define APP_DOMAIN "xmrig.com" #define APP_DOMAIN "xmrig.com"
#define APP_SITE "www.xmrig.com" #define APP_SITE "www.xmrig.com"
#define APP_COPYRIGHT "Copyright (C) 2016-2020 xmrig.com" #define APP_COPYRIGHT "Copyright (C) 2016-2020 xmrig.com"
@ -36,7 +36,7 @@
#define APP_VER_MAJOR 5 #define APP_VER_MAJOR 5
#define APP_VER_MINOR 11 #define APP_VER_MINOR 11
#define APP_VER_PATCH 0 #define APP_VER_PATCH 1
#ifdef _MSC_VER #ifdef _MSC_VER
# if (_MSC_VER >= 1920) # if (_MSC_VER >= 1920)