add RandomX support

This commit is contained in:
Jethro Grassie 2019-06-02 21:14:44 -04:00
parent 65e746bab5
commit 647971cde6
No known key found for this signature in database
GPG key ID: DE8ED755616565BB
4 changed files with 108 additions and 18 deletions

View file

@ -56,7 +56,8 @@ MONERO_LIBS = \
${MONERO_BUILD_ROOT}/src/ringct/libringct_basic.a \ ${MONERO_BUILD_ROOT}/src/ringct/libringct_basic.a \
${MONERO_BUILD_ROOT}/src/device/libdevice.a \ ${MONERO_BUILD_ROOT}/src/device/libdevice.a \
${MONERO_BUILD_ROOT}/contrib/epee/src/libepee.a \ ${MONERO_BUILD_ROOT}/contrib/epee/src/libepee.a \
${MONERO_BUILD_ROOT}/external/easylogging++/libeasylogging.a ${MONERO_BUILD_ROOT}/external/easylogging++/libeasylogging.a \
${MONERO_BUILD_ROOT}/external/randomx/librandomx.a
DIRS = src data rxi/log/src DIRS = src data rxi/log/src

View file

@ -150,6 +150,8 @@ typedef struct block_template_t
uint64_t height; uint64_t height;
char prev_hash[64]; char prev_hash[64];
uint32_t reserved_offset; uint32_t reserved_offset;
char seed_hash[64];
char next_seed_hash[64];
} block_template_t; } block_template_t;
typedef struct job_t typedef struct job_t
@ -246,6 +248,9 @@ static FILE *fd_log;
static unsigned char sec_view[32]; static unsigned char sec_view[32];
static unsigned char pub_spend[32]; static unsigned char pub_spend[32];
extern void rx_stop_mining();
extern void rx_slow_hash_free_state();
#define JSON_GET_OR_ERROR(name, parent, type, client) \ #define JSON_GET_OR_ERROR(name, parent, type, client) \
json_object *name = NULL; \ json_object *name = NULL; \
if (!json_object_object_get_ex(parent, #name, &name)) { \ if (!json_object_object_get_ex(parent, #name, &name)) { \
@ -857,12 +862,14 @@ stratum_get_proxy_job_body(char *body, const client_t *client,
"\"difficulty\":%"PRIu64",\"height\":%"PRIu64"," "\"difficulty\":%"PRIu64",\"height\":%"PRIu64","
"\"reserved_offset\":%u," "\"reserved_offset\":%u,"
"\"client_nonce_offset\":%u,\"client_pool_offset\":%u," "\"client_nonce_offset\":%u,\"client_pool_offset\":%u,"
"\"target_diff\":%"PRIu64",\"target_diff_hex\":\"%s\"}," "\"target_diff\":%"PRIu64",\"target_diff_hex\":\"%s\","
"\"seed_hash\":\"%.64s\",\"next_seed_hash\":\"%.64s\"},"
"\"status\":\"OK\"}}\n", "\"status\":\"OK\"}}\n",
json_id, client_id, block_hex, job_id, json_id, client_id, block_hex, job_id,
bt->difficulty, bt->height, bt->reserved_offset, bt->difficulty, bt->height, bt->reserved_offset,
bt->reserved_offset + 12, bt->reserved_offset + 12,
bt->reserved_offset + 8, target, target_hex); bt->reserved_offset + 8, target, target_hex,
bt->seed_hash, bt->next_seed_hash);
} }
else else
{ {
@ -873,11 +880,13 @@ stratum_get_proxy_job_body(char *body, const client_t *client,
"\"difficulty\":%"PRIu64",\"height\":%"PRIu64"," "\"difficulty\":%"PRIu64",\"height\":%"PRIu64","
"\"reserved_offset\":%u," "\"reserved_offset\":%u,"
"\"client_nonce_offset\":%u,\"client_pool_offset\":%u," "\"client_nonce_offset\":%u,\"client_pool_offset\":%u,"
"\"target_diff\":%"PRIu64",\"target_diff_hex\":\"%s\"}," "\"target_diff\":%"PRIu64",\"target_diff_hex\":\"%s\","
"\"seed_hash\":\"%.64s\",\"next_seed_hash\":\"%.64s\"},"
"\"status\":\"OK\"}}\n", client_id, block_hex, job_id, "\"status\":\"OK\"}}\n", client_id, block_hex, job_id,
bt->difficulty, bt->height, bt->difficulty, bt->height,
bt->reserved_offset, bt->reserved_offset + 12, bt->reserved_offset, bt->reserved_offset + 12,
bt->reserved_offset + 8, target, target_hex); bt->reserved_offset + 8, target, target_hex,
bt->seed_hash, bt->next_seed_hash);
} }
} }
@ -893,6 +902,14 @@ stratum_get_job_body_ss(char *body, const client_t *client, bool response)
uint64_t target = job->target; uint64_t target = job->target;
char target_hex[17] = {0}; char target_hex[17] = {0};
target_to_hex(target, &target_hex[0]); target_to_hex(target, &target_hex[0]);
char empty[] = "";
char *seed_hash = empty;
char *next_seed_hash = empty;
if (job->miner_template)
{
seed_hash = job->miner_template->seed_hash;
next_seed_hash = job->miner_template->next_seed_hash;
}
unsigned char extra_bin[8]; unsigned char extra_bin[8];
memcpy(extra_bin, &job->extra_nonce, 4); memcpy(extra_bin, &job->extra_nonce, 4);
memcpy(extra_bin+4, &instance_id, 4); memcpy(extra_bin+4, &instance_id, 4);
@ -905,10 +922,11 @@ stratum_get_job_body_ss(char *body, const client_t *client, bool response)
"\"error\":null,\"result\"" "\"error\":null,\"result\""
":{\"id\":\"%.32s\",\"job\":{" ":{\"id\":\"%.32s\",\"job\":{"
"\"job_id\":\"%.32s\",\"target\":\"%s\"," "\"job_id\":\"%.32s\",\"target\":\"%s\","
"\"extra_nonce\":\"%s\", \"pool_wallet\":\"%s\"}," "\"extra_nonce\":\"%s\", \"pool_wallet\":\"%s\","
"\"seed_hash\":\"%.64s\",\"next_seed_hash\":\"%.64s\"},"
"\"status\":\"OK\"}}\n", "\"status\":\"OK\"}}\n",
json_id, client_id, job_id, target_hex, extra_hex, json_id, client_id, job_id, target_hex, extra_hex,
config.pool_wallet); config.pool_wallet, seed_hash, next_seed_hash);
} }
else else
{ {
@ -916,8 +934,10 @@ stratum_get_job_body_ss(char *body, const client_t *client, bool response)
"\"job\",\"params\"" "\"job\",\"params\""
":{\"id\":\"%.32s\",\"job_id\":\"%.32s\"," ":{\"id\":\"%.32s\",\"job_id\":\"%.32s\","
"\"target\":\"%s\"," "\"target\":\"%s\","
"\"extra_nonce\":\"%s\", \"pool_wallet\":\"%s\"}}\n", "\"extra_nonce\":\"%s\", \"pool_wallet\":\"%s\","
client_id, job_id, target_hex, extra_hex, config.pool_wallet); "\"seed_hash\":\"%.64s\",\"next_seed_hash\":\"%.64s\"}}\n",
client_id, job_id, target_hex, extra_hex, config.pool_wallet,
seed_hash, next_seed_hash);
} }
} }
@ -934,6 +954,8 @@ stratum_get_job_body(char *body, const client_t *client, bool response)
uint64_t height = job->block_template->height; uint64_t height = job->block_template->height;
char target_hex[17] = {0}; char target_hex[17] = {0};
target_to_hex(target, &target_hex[0]); target_to_hex(target, &target_hex[0]);
char *seed_hash = job->block_template->seed_hash;
char *next_seed_hash = job->block_template->next_seed_hash;
if (response) if (response)
{ {
@ -941,9 +963,11 @@ stratum_get_job_body(char *body, const client_t *client, bool response)
"\"error\":null,\"result\"" "\"error\":null,\"result\""
":{\"id\":\"%.32s\",\"job\":{" ":{\"id\":\"%.32s\",\"job\":{"
"\"blob\":\"%s\",\"job_id\":\"%.32s\",\"target\":\"%s\"," "\"blob\":\"%s\",\"job_id\":\"%.32s\",\"target\":\"%s\","
"\"height\":%"PRIu64"}," "\"height\":%"PRIu64",\"seed_hash\":\"%.64s\","
"\"next_seed_hash\":\"%.64s\"},"
"\"status\":\"OK\"}}\n", "\"status\":\"OK\"}}\n",
json_id, client_id, blob, job_id, target_hex, height); json_id, client_id, blob, job_id, target_hex, height,
seed_hash, next_seed_hash);
} }
else else
{ {
@ -951,8 +975,10 @@ stratum_get_job_body(char *body, const client_t *client, bool response)
"\"job\",\"params\"" "\"job\",\"params\""
":{\"id\":\"%.32s\",\"blob\":\"%s\",\"job_id\":\"%.32s\"," ":{\"id\":\"%.32s\",\"blob\":\"%s\",\"job_id\":\"%.32s\","
"\"target\":\"%s\"," "\"target\":\"%s\","
"\"height\":%"PRIu64"}}\n", "\"height\":%"PRIu64",\"seed_hash\":\"%.64s\","
client_id, blob, job_id, target_hex, height); "\"next_seed_hash\":\"%.64s\"}}\n",
client_id, blob, job_id, target_hex, height,
seed_hash, next_seed_hash);
} }
} }
@ -1202,6 +1228,23 @@ response_to_block_template(json_object *result,
block_template->height = json_object_get_int64(height); block_template->height = json_object_get_int64(height);
memcpy(block_template->prev_hash, json_object_get_string(prev_hash), 64); memcpy(block_template->prev_hash, json_object_get_string(prev_hash), 64);
block_template->reserved_offset = json_object_get_int(reserved_offset); block_template->reserved_offset = json_object_get_int(reserved_offset);
unsigned int major_version = 0;
sscanf(block_template->blocktemplate_blob, "%2x", &major_version);
uint8_t pow_variant = major_version >= 7 ? major_version - 6 : 0;
log_trace("Variant: %u", pow_variant);
if (pow_variant >= 6)
{
JSON_GET_OR_WARN(seed_hash, result, json_type_string);
JSON_GET_OR_WARN(next_seed_hash, result, json_type_string);
assert(seed_hash != NULL);
assert(next_seed_hash != NULL);
memcpy(block_template->seed_hash,
json_object_get_string(seed_hash), 64);
memcpy(block_template->next_seed_hash,
json_object_get_string(next_seed_hash), 64);
}
} }
static void static void
@ -2087,6 +2130,23 @@ client_on_block_template(json_object *message, client_t *client)
memcpy(job->miner_template->prev_hash, memcpy(job->miner_template->prev_hash,
json_object_get_string(prev_hash), 64); json_object_get_string(prev_hash), 64);
unsigned int major_version = 0;
sscanf(btb, "%2x", &major_version);
uint8_t pow_variant = major_version >= 7 ? major_version - 6 : 0;
log_trace("Variant: %u", pow_variant);
if (pow_variant >= 6)
{
JSON_GET_OR_WARN(seed_hash, params, json_type_string);
JSON_GET_OR_WARN(next_seed_hash, params, json_type_string);
assert(seed_hash != NULL);
assert(next_seed_hash != NULL);
memcpy(job->miner_template->seed_hash,
json_object_get_string(seed_hash), 64);
memcpy(job->miner_template->next_seed_hash,
json_object_get_string(next_seed_hash), 64);
}
log_trace("Client set template: %s", btb); log_trace("Client set template: %s", btb);
char body[STATUS_BODY_MAX]; char body[STATUS_BODY_MAX];
stratum_get_status_body(body, client->json_id, "OK"); stratum_get_status_body(body, client->json_id, "OK");
@ -2256,9 +2316,19 @@ client_on_submit(json_object *message, client_t *client)
unsigned char result_hash[32] = {0}; unsigned char result_hash[32] = {0};
unsigned char submitted_hash[32] = {0}; unsigned char submitted_hash[32] = {0};
uint8_t major_version = (uint8_t)block[0]; uint8_t major_version = (uint8_t)block[0];
const int cn_variant = major_version >= 7 ? major_version - 6 : 0; uint8_t pow_variant = major_version >= 7 ? major_version - 6 : 0;
get_hash(hashing_blob, hashing_blob_size, if (pow_variant >= 6)
(unsigned char**)&result_hash, cn_variant, bt->height); {
unsigned char seed_hash[32];
hex_to_bin(bt->seed_hash, 64, seed_hash, 32);
get_rx_hash(hashing_blob, hashing_blob_size,
(unsigned char*)result_hash, seed_hash, bt->height);
}
else
{
get_hash(hashing_blob, hashing_blob_size,
(unsigned char*)result_hash, pow_variant, bt->height);
}
hex_to_bin(result_hex, 64, submitted_hash, 32); hex_to_bin(result_hex, 64, submitted_hash, 32);
if (memcmp(submitted_hash, result_hash, 32) != 0) if (memcmp(submitted_hash, result_hash, 32) != 0)
@ -2768,6 +2838,8 @@ cleanup(void)
database_close(); database_close();
BN_free(base_diff); BN_free(base_diff);
BN_CTX_free(bn_ctx); BN_CTX_free(bn_ctx);
rx_stop_mining();
rx_slow_hash_free_state();
pthread_mutex_destroy(&mutex_clients); pthread_mutex_destroy(&mutex_clients);
log_info("Pool shutdown successfully"); log_info("Pool shutdown successfully");
if (fd_log) if (fd_log)

View file

@ -48,6 +48,7 @@ developers.
#include "serialization/binary_utils.h" #include "serialization/binary_utils.h"
#include "ringct/rctSigs.h" #include "ringct/rctSigs.h"
#include "common/base58.h" #include "common/base58.h"
#include "common/util.h"
#include "string_tools.h" #include "string_tools.h"
#include "xmr.h" #include "xmr.h"
@ -94,12 +95,25 @@ int parse_address(const char *input, uint64_t *prefix,
} }
void get_hash(const unsigned char *input, const size_t in_size, void get_hash(const unsigned char *input, const size_t in_size,
unsigned char **output, int variant, uint64_t height) unsigned char *output, int variant, uint64_t height)
{ {
cn_slow_hash(input, in_size, cn_slow_hash(input, in_size,
reinterpret_cast<hash&>(*output), variant, height); reinterpret_cast<hash&>(*output), variant, height);
} }
void get_rx_hash(const unsigned char *input, const size_t in_size,
unsigned char *output, const unsigned char *seed_hash,
const uint64_t height)
{
static unsigned max_concurrency = 1;//tools::get_max_concurrency();
uint64_t seed_height;
if (rx_needhash(height, &seed_height))
{
rx_seedhash(seed_height, (const char*)seed_hash, max_concurrency);
}
rx_slow_hash((const char*)input, in_size, (char*)output, max_concurrency);
}
int validate_block_from_blob(const char *blob_hex, int validate_block_from_blob(const char *blob_hex,
const unsigned char *sec_view, const unsigned char *sec_view,
const unsigned char *pub_spend) const unsigned char *pub_spend)

View file

@ -55,7 +55,10 @@ int get_hashing_blob(const unsigned char *input, const size_t in_size,
int parse_address(const char *input, uint64_t *prefix, int parse_address(const char *input, uint64_t *prefix,
unsigned char *pub_spend); unsigned char *pub_spend);
void get_hash(const unsigned char *input, const size_t in_size, void get_hash(const unsigned char *input, const size_t in_size,
unsigned char **output, int variant, uint64_t height); unsigned char *output, int variant, uint64_t height);
void get_rx_hash(const unsigned char *input, const size_t in_size,
unsigned char *output, const unsigned char *seed_hash,
const uint64_t height);
int validate_block_from_blob(const char *blob_hex, int validate_block_from_blob(const char *blob_hex,
const unsigned char *sec_view, const unsigned char *sec_view,
const unsigned char *pub_spend); const unsigned char *pub_spend);