2019-04-21 00:20:21 +02:00
|
|
|
#include "../randomx.h"
|
|
|
|
#include <iostream>
|
|
|
|
#include <iomanip>
|
|
|
|
#include <thread>
|
|
|
|
|
|
|
|
int main() {
|
2019-05-03 16:50:05 +02:00
|
|
|
const char myKey[] = "RandomX example key";
|
2019-04-21 00:20:21 +02:00
|
|
|
const char myInput[] = "RandomX example input";
|
|
|
|
char hash[RANDOMX_HASH_SIZE];
|
|
|
|
|
|
|
|
randomx_cache *myCache = randomx_alloc_cache((randomx_flags)(RANDOMX_FLAG_JIT | RANDOMX_FLAG_LARGE_PAGES));
|
|
|
|
if (myCache == nullptr) {
|
|
|
|
std::cout << "Cache allocation failed" << std::endl;
|
|
|
|
return 1;
|
|
|
|
}
|
2019-05-03 16:50:05 +02:00
|
|
|
randomx_init_cache(myCache, myKey, sizeof myKey);
|
2019-04-21 00:20:21 +02:00
|
|
|
|
|
|
|
randomx_dataset *myDataset = randomx_alloc_dataset(RANDOMX_FLAG_LARGE_PAGES);
|
|
|
|
if (myDataset == nullptr) {
|
|
|
|
std::cout << "Dataset allocation failed" << std::endl;
|
|
|
|
return 1;
|
|
|
|
}
|
2019-05-03 16:50:05 +02:00
|
|
|
|
2019-04-23 22:15:55 +02:00
|
|
|
auto datasetItemCount = randomx_dataset_item_count();
|
|
|
|
std::thread t1(&randomx_init_dataset, myDataset, myCache, 0, datasetItemCount / 2);
|
2019-05-03 16:50:05 +02:00
|
|
|
std::thread t2(&randomx_init_dataset, myDataset, myCache, datasetItemCount / 2, datasetItemCount - datasetItemCount / 2);
|
2019-04-21 00:20:21 +02:00
|
|
|
t1.join();
|
|
|
|
t2.join();
|
|
|
|
randomx_release_cache(myCache);
|
|
|
|
|
2019-04-21 23:23:13 +02:00
|
|
|
randomx_vm *myMachine = randomx_create_vm((randomx_flags)(RANDOMX_FLAG_FULL_MEM | RANDOMX_FLAG_JIT | RANDOMX_FLAG_HARD_AES | RANDOMX_FLAG_LARGE_PAGES), nullptr, myDataset);
|
2019-05-03 16:50:05 +02:00
|
|
|
if (myMachine == nullptr) {
|
|
|
|
std::cout << "Failed to create a virtual machine" << std::endl;
|
|
|
|
return 1;
|
|
|
|
}
|
2019-04-21 00:20:21 +02:00
|
|
|
|
|
|
|
randomx_calculate_hash(myMachine, &myInput, sizeof myInput, hash);
|
|
|
|
|
|
|
|
randomx_destroy_vm(myMachine);
|
|
|
|
randomx_release_dataset(myDataset);
|
|
|
|
|
|
|
|
for (unsigned i = 0; i < RANDOMX_HASH_SIZE; ++i)
|
|
|
|
std::cout << std::hex << ((int)hash[i] & 0xff);
|
|
|
|
|
|
|
|
std::cout << std::endl;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|