mirror of
https://github.com/xmrig/xmrig.git
synced 2025-01-25 20:16:05 +00:00
Fixed warnings.
This commit is contained in:
parent
bcae974ea1
commit
4f49533e98
7 changed files with 21 additions and 23 deletions
|
@ -26,6 +26,7 @@
|
||||||
#define XMRIG_HASHRATE_H
|
#define XMRIG_HASHRATE_H
|
||||||
|
|
||||||
|
|
||||||
|
#include <stddef.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -90,12 +90,12 @@ static void load_block(block *dst, const void *input) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void store_block(void *output, const block *src) {
|
//static void store_block(void *output, const block *src) {
|
||||||
unsigned i;
|
// unsigned i;
|
||||||
for (i = 0; i < ARGON2_QWORDS_IN_BLOCK; ++i) {
|
// for (i = 0; i < ARGON2_QWORDS_IN_BLOCK; ++i) {
|
||||||
store64((uint8_t *)output + i * sizeof(src->v[i]), src->v[i]);
|
// store64((uint8_t *)output + i * sizeof(src->v[i]), src->v[i]);
|
||||||
}
|
// }
|
||||||
}
|
//}
|
||||||
|
|
||||||
/***************Memory functions*****************/
|
/***************Memory functions*****************/
|
||||||
|
|
||||||
|
@ -484,7 +484,6 @@ void rxa2_initial_hash(uint8_t *blockhash, argon2_context *context, argon2_type
|
||||||
|
|
||||||
int rxa2_argon_initialize(argon2_instance_t *instance, argon2_context *context) {
|
int rxa2_argon_initialize(argon2_instance_t *instance, argon2_context *context) {
|
||||||
uint8_t blockhash[ARGON2_PREHASH_SEED_LENGTH];
|
uint8_t blockhash[ARGON2_PREHASH_SEED_LENGTH];
|
||||||
int result = ARGON2_OK;
|
|
||||||
|
|
||||||
if (instance == NULL || context == NULL)
|
if (instance == NULL || context == NULL)
|
||||||
return ARGON2_INCORRECT_PARAMETER;
|
return ARGON2_INCORRECT_PARAMETER;
|
||||||
|
|
|
@ -90,7 +90,7 @@ namespace randomx {
|
||||||
}
|
}
|
||||||
|
|
||||||
static void executeBytecode(InstructionByteCode* bytecode, uint8_t* scratchpad, ProgramConfiguration& config) {
|
static void executeBytecode(InstructionByteCode* bytecode, uint8_t* scratchpad, ProgramConfiguration& config) {
|
||||||
for (int pc = 0; pc < RandomX_CurrentConfig.ProgramSize; ++pc) {
|
for (int pc = 0; pc < static_cast<int>(RandomX_CurrentConfig.ProgramSize); ++pc) {
|
||||||
auto& ibc = bytecode[pc];
|
auto& ibc = bytecode[pc];
|
||||||
executeInstruction(ibc, pc, scratchpad, config);
|
executeInstruction(ibc, pc, scratchpad, config);
|
||||||
}
|
}
|
||||||
|
|
|
@ -121,7 +121,7 @@ namespace randomx {
|
||||||
|
|
||||||
cache->reciprocalCache.clear();
|
cache->reciprocalCache.clear();
|
||||||
randomx::Blake2Generator gen(key, keySize);
|
randomx::Blake2Generator gen(key, keySize);
|
||||||
for (int i = 0; i < RandomX_CurrentConfig.CacheAccesses; ++i) {
|
for (uint32_t i = 0; i < RandomX_CurrentConfig.CacheAccesses; ++i) {
|
||||||
randomx::generateSuperscalar(cache->programs[i], gen);
|
randomx::generateSuperscalar(cache->programs[i], gen);
|
||||||
for (unsigned j = 0; j < cache->programs[i].getSize(); ++j) {
|
for (unsigned j = 0; j < cache->programs[i].getSize(); ++j) {
|
||||||
auto& instr = cache->programs[i](j);
|
auto& instr = cache->programs[i](j);
|
||||||
|
|
|
@ -194,7 +194,7 @@ namespace randomx {
|
||||||
static const uint8_t NOP7[] = { 0x0F, 0x1F, 0x80, 0x00, 0x00, 0x00, 0x00 };
|
static const uint8_t NOP7[] = { 0x0F, 0x1F, 0x80, 0x00, 0x00, 0x00, 0x00 };
|
||||||
static const uint8_t NOP8[] = { 0x0F, 0x1F, 0x84, 0x00, 0x00, 0x00, 0x00, 0x00 };
|
static const uint8_t NOP8[] = { 0x0F, 0x1F, 0x84, 0x00, 0x00, 0x00, 0x00, 0x00 };
|
||||||
|
|
||||||
static const uint8_t* NOPX[] = { NOP1, NOP2, NOP3, NOP4, NOP5, NOP6, NOP7, NOP8 };
|
// static const uint8_t* NOPX[] = { NOP1, NOP2, NOP3, NOP4, NOP5, NOP6, NOP7, NOP8 };
|
||||||
|
|
||||||
size_t JitCompilerX86::getCodeSize() {
|
size_t JitCompilerX86::getCodeSize() {
|
||||||
return codePos - prologueSize;
|
return codePos - prologueSize;
|
||||||
|
|
|
@ -233,7 +233,7 @@ RandomX_ConfigurationBase RandomX_CurrentConfig;
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
|
||||||
randomx_cache *randomx_alloc_cache(randomx_flags flags) {
|
randomx_cache *randomx_alloc_cache(randomx_flags flags) {
|
||||||
randomx_cache *cache;
|
randomx_cache *cache = nullptr;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
cache = new randomx_cache();
|
cache = new randomx_cache();
|
||||||
|
@ -297,7 +297,7 @@ extern "C" {
|
||||||
}
|
}
|
||||||
|
|
||||||
randomx_dataset *randomx_alloc_dataset(randomx_flags flags) {
|
randomx_dataset *randomx_alloc_dataset(randomx_flags flags) {
|
||||||
randomx_dataset *dataset;
|
randomx_dataset *dataset = nullptr;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
dataset = new randomx_dataset();
|
dataset = new randomx_dataset();
|
||||||
|
@ -430,14 +430,12 @@ extern "C" {
|
||||||
assert(inputSize == 0 || input != nullptr);
|
assert(inputSize == 0 || input != nullptr);
|
||||||
assert(output != nullptr);
|
assert(output != nullptr);
|
||||||
alignas(16) uint64_t tempHash[8];
|
alignas(16) uint64_t tempHash[8];
|
||||||
int blakeResult = blake2b(tempHash, sizeof(tempHash), input, inputSize, nullptr, 0);
|
blake2b(tempHash, sizeof(tempHash), input, inputSize, nullptr, 0);
|
||||||
assert(blakeResult == 0);
|
|
||||||
machine->initScratchpad(&tempHash);
|
machine->initScratchpad(&tempHash);
|
||||||
machine->resetRoundingMode();
|
machine->resetRoundingMode();
|
||||||
for (int chain = 0; chain < RandomX_CurrentConfig.ProgramCount - 1; ++chain) {
|
for (uint32_t chain = 0; chain < RandomX_CurrentConfig.ProgramCount - 1; ++chain) {
|
||||||
machine->run(&tempHash);
|
machine->run(&tempHash);
|
||||||
blakeResult = blake2b(tempHash, sizeof(tempHash), machine->getRegisterFile(), sizeof(randomx::RegisterFile), nullptr, 0);
|
blake2b(tempHash, sizeof(tempHash), machine->getRegisterFile(), sizeof(randomx::RegisterFile), nullptr, 0);
|
||||||
assert(blakeResult == 0);
|
|
||||||
}
|
}
|
||||||
machine->run(&tempHash);
|
machine->run(&tempHash);
|
||||||
machine->getFinalResult(output, RANDOMX_HASH_SIZE);
|
machine->getFinalResult(output, RANDOMX_HASH_SIZE);
|
||||||
|
|
|
@ -500,7 +500,7 @@ namespace randomx {
|
||||||
// * either the last instruction applied to the register or its source must be different than this instruction
|
// * either the last instruction applied to the register or its source must be different than this instruction
|
||||||
// - this avoids optimizable instruction sequences such as "xor r1, r2; xor r1, r2" or "ror r, C1; ror r, C2" or "add r, C1; add r, C2"
|
// - this avoids optimizable instruction sequences such as "xor r1, r2; xor r1, r2" or "ror r, C1; ror r, C2" or "add r, C1; add r, C2"
|
||||||
// * register r5 cannot be the destination of the IADD_RS instruction (limitation of the x86 lea instruction)
|
// * register r5 cannot be the destination of the IADD_RS instruction (limitation of the x86 lea instruction)
|
||||||
for (unsigned i = 0; i < 8; ++i) {
|
for (int i = 0; i < 8; ++i) {
|
||||||
if (registers[i].latency <= cycle && (canReuse_ || i != src_) && (allowChainedMul || opGroup_ != SuperscalarInstructionType::IMUL_R || registers[i].lastOpGroup != SuperscalarInstructionType::IMUL_R) && (registers[i].lastOpGroup != opGroup_ || registers[i].lastOpPar != opGroupPar_) && (info_->getType() != SuperscalarInstructionType::IADD_RS || i != RegisterNeedsDisplacement))
|
if (registers[i].latency <= cycle && (canReuse_ || i != src_) && (allowChainedMul || opGroup_ != SuperscalarInstructionType::IMUL_R || registers[i].lastOpGroup != SuperscalarInstructionType::IMUL_R) && (registers[i].lastOpGroup != opGroup_ || registers[i].lastOpPar != opGroupPar_) && (info_->getType() != SuperscalarInstructionType::IADD_RS || i != RegisterNeedsDisplacement))
|
||||||
availableRegisters.push_back(i);
|
availableRegisters.push_back(i);
|
||||||
}
|
}
|
||||||
|
@ -581,7 +581,7 @@ namespace randomx {
|
||||||
static int scheduleUop(ExecutionPort::type uop, ExecutionPort::type(&portBusy)[CYCLE_MAP_SIZE][3], int cycle) {
|
static int scheduleUop(ExecutionPort::type uop, ExecutionPort::type(&portBusy)[CYCLE_MAP_SIZE][3], int cycle) {
|
||||||
//The scheduling here is done optimistically by checking port availability in order P5 -> P0 -> P1 to not overload
|
//The scheduling here is done optimistically by checking port availability in order P5 -> P0 -> P1 to not overload
|
||||||
//port P1 (multiplication) by instructions that can go to any port.
|
//port P1 (multiplication) by instructions that can go to any port.
|
||||||
for (; cycle < RandomX_CurrentConfig.SuperscalarLatency + 4; ++cycle) {
|
for (; cycle < static_cast<int>(RandomX_CurrentConfig.SuperscalarLatency) + 4; ++cycle) {
|
||||||
if ((uop & ExecutionPort::P5) != 0 && !portBusy[cycle][2]) {
|
if ((uop & ExecutionPort::P5) != 0 && !portBusy[cycle][2]) {
|
||||||
if (commit) {
|
if (commit) {
|
||||||
if (trace) std::cout << "; P5 at cycle " << cycle << std::endl;
|
if (trace) std::cout << "; P5 at cycle " << cycle << std::endl;
|
||||||
|
@ -626,7 +626,7 @@ namespace randomx {
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
//macro-ops with 2 uOPs are scheduled conservatively by requiring both uOPs to execute in the same cycle
|
//macro-ops with 2 uOPs are scheduled conservatively by requiring both uOPs to execute in the same cycle
|
||||||
for (; cycle < RandomX_CurrentConfig.SuperscalarLatency + 4; ++cycle) {
|
for (; cycle < static_cast<int>(RandomX_CurrentConfig.SuperscalarLatency) + 4; ++cycle) {
|
||||||
|
|
||||||
int cycle1 = scheduleUop<false>(mop.getUop1(), portBusy, cycle);
|
int cycle1 = scheduleUop<false>(mop.getUop1(), portBusy, cycle);
|
||||||
int cycle2 = scheduleUop<false>(mop.getUop2(), portBusy, cycle);
|
int cycle2 = scheduleUop<false>(mop.getUop2(), portBusy, cycle);
|
||||||
|
@ -669,7 +669,7 @@ namespace randomx {
|
||||||
//Since a decode cycle produces on average 3.45 macro-ops and there are only 3 ALU ports, execution ports are always
|
//Since a decode cycle produces on average 3.45 macro-ops and there are only 3 ALU ports, execution ports are always
|
||||||
//saturated first. The cycle limit is present only to guarantee loop termination.
|
//saturated first. The cycle limit is present only to guarantee loop termination.
|
||||||
//Program size is limited to SuperscalarMaxSize instructions.
|
//Program size is limited to SuperscalarMaxSize instructions.
|
||||||
for (decodeCycle = 0; decodeCycle < RandomX_CurrentConfig.SuperscalarLatency && !portsSaturated && programSize < 3 * RandomX_CurrentConfig.SuperscalarLatency + 2; ++decodeCycle) {
|
for (decodeCycle = 0; decodeCycle < static_cast<int>(RandomX_CurrentConfig.SuperscalarLatency) && !portsSaturated && programSize < 3 * static_cast<int>(RandomX_CurrentConfig.SuperscalarLatency) + 2; ++decodeCycle) {
|
||||||
|
|
||||||
//select a decode configuration
|
//select a decode configuration
|
||||||
decodeBuffer = decodeBuffer->fetchNext(currentInstruction.getType(), decodeCycle, mulCount, gen);
|
decodeBuffer = decodeBuffer->fetchNext(currentInstruction.getType(), decodeCycle, mulCount, gen);
|
||||||
|
@ -683,7 +683,7 @@ namespace randomx {
|
||||||
|
|
||||||
//if we have issued all macro-ops for the current RandomX instruction, create a new instruction
|
//if we have issued all macro-ops for the current RandomX instruction, create a new instruction
|
||||||
if (macroOpIndex >= currentInstruction.getInfo().getSize()) {
|
if (macroOpIndex >= currentInstruction.getInfo().getSize()) {
|
||||||
if (portsSaturated || programSize >= 3 * RandomX_CurrentConfig.SuperscalarLatency + 2)
|
if (portsSaturated || programSize >= 3 * static_cast<int>(RandomX_CurrentConfig.SuperscalarLatency) + 2)
|
||||||
break;
|
break;
|
||||||
//select an instruction so that the first macro-op fits into the current slot
|
//select an instruction so that the first macro-op fits into the current slot
|
||||||
currentInstruction.createForSlot(gen, decodeBuffer->getCounts()[bufferIndex], decodeBuffer->getIndex(), decodeBuffer->getSize() == bufferIndex + 1, bufferIndex == 0);
|
currentInstruction.createForSlot(gen, decodeBuffer->getCounts()[bufferIndex], decodeBuffer->getIndex(), decodeBuffer->getSize() == bufferIndex + 1, bufferIndex == 0);
|
||||||
|
@ -777,7 +777,7 @@ namespace randomx {
|
||||||
macroOpCount++;
|
macroOpCount++;
|
||||||
|
|
||||||
//terminating condition
|
//terminating condition
|
||||||
if (scheduleCycle >= RandomX_CurrentConfig.SuperscalarLatency) {
|
if (scheduleCycle >= static_cast<int>(RandomX_CurrentConfig.SuperscalarLatency)) {
|
||||||
portsSaturated = true;
|
portsSaturated = true;
|
||||||
}
|
}
|
||||||
cycle = topCycle;
|
cycle = topCycle;
|
||||||
|
|
Loading…
Reference in a new issue