|
| static const char * | regR [] = { "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15" } |
| |
| static const char * | regR32 [] = { "r8d", "r9d", "r10d", "r11d", "r12d", "r13d", "r14d", "r15d" } |
| |
| static const char * | regFE [] = { "xmm0", "xmm1", "xmm2", "xmm3", "xmm4", "xmm5", "xmm6", "xmm7" } |
| |
| static const char * | regF [] = { "xmm0", "xmm1", "xmm2", "xmm3" } |
| |
| static const char * | regE [] = { "xmm4", "xmm5", "xmm6", "xmm7" } |
| |
| static const char * | regA [] = { "xmm8", "xmm9", "xmm10", "xmm11" } |
| |
| static const char * | tempRegx = "xmm12" |
| |
| static const char * | mantissaMaskReg = "xmm13" |
| |
| static const char * | exponentMaskReg = "xmm14" |
| |
| static const char * | scaleMaskReg = "xmm15" |
| |
| static const char * | regIc = "rbx" |
| |
| static const char * | regIc32 = "ebx" |
| |
| static const char * | regIc8 = "bl" |
| |
| static const char * | regScratchpadAddr = "rsi" |
| |
| constexpr int | maxSeedSize = 60 |
| |
| constexpr int | ceil_NULL = 0 |
| |
| constexpr int | wtSum |
| |
| constexpr uint32_t | ArgonBlockSize = 1024 |
| |
| constexpr int | ArgonSaltSize = sizeof("" RANDOMX_ARGON_SALT) - 1 |
| |
| constexpr int | SuperscalarMaxSize = 3 * RANDOMX_SUPERSCALAR_LATENCY + 2 |
| |
| constexpr size_t | CacheLineSize = RANDOMX_DATASET_ITEM_SIZE |
| |
| constexpr int | ScratchpadSize = RANDOMX_SCRATCHPAD_L3 |
| |
| constexpr uint32_t | CacheLineAlignMask = (RANDOMX_DATASET_BASE_SIZE - 1) & ~(CacheLineSize - 1) |
| |
| constexpr uint32_t | CacheSize = RANDOMX_ARGON_MEMORY * ArgonBlockSize |
| |
| constexpr uint64_t | DatasetSize = RANDOMX_DATASET_BASE_SIZE + RANDOMX_DATASET_EXTRA_SIZE |
| |
| constexpr uint32_t | DatasetExtraItems = RANDOMX_DATASET_EXTRA_SIZE / RANDOMX_DATASET_ITEM_SIZE |
| |
| constexpr uint32_t | ConditionMask = ((1 << RANDOMX_JUMP_BITS) - 1) |
| |
| constexpr int | ConditionOffset = RANDOMX_JUMP_OFFSET |
| |
| constexpr int | StoreL3Condition = 14 |
| |
| constexpr bool | trace = false |
| |
| constexpr uint32_t | ScratchpadL1 = RANDOMX_SCRATCHPAD_L1 / sizeof(int_reg_t) |
| |
| constexpr uint32_t | ScratchpadL2 = RANDOMX_SCRATCHPAD_L2 / sizeof(int_reg_t) |
| |
| constexpr uint32_t | ScratchpadL3 = RANDOMX_SCRATCHPAD_L3 / sizeof(int_reg_t) |
| |
| constexpr int | ScratchpadL1Mask = (ScratchpadL1 - 1) * 8 |
| |
| constexpr int | ScratchpadL2Mask = (ScratchpadL2 - 1) * 8 |
| |
| constexpr int | ScratchpadL1Mask16 = (ScratchpadL1 / 2 - 1) * 16 |
| |
| constexpr int | ScratchpadL2Mask16 = (ScratchpadL2 / 2 - 1) * 16 |
| |
| constexpr int | ScratchpadL3Mask = (ScratchpadL3 - 1) * 8 |
| |
| constexpr int | ScratchpadL3Mask64 = (ScratchpadL3 / 8 - 1) * 64 |
| |
| constexpr int | RegistersCount = 8 |
| |
| constexpr int | RegisterCountFlt = RegistersCount / 2 |
| |
| constexpr int | RegisterNeedsDisplacement = 5 |
| |
| constexpr int | RegisterNeedsSib = 4 |
| |
| constexpr int | mantissaSize = 52 |
| |
| constexpr int | exponentSize = 11 |
| |
| constexpr uint64_t | mantissaMask = (1ULL << mantissaSize) - 1 |
| |
| constexpr uint64_t | exponentMask = (1ULL << exponentSize) - 1 |
| |
| constexpr int | exponentBias = 1023 |
| |
| constexpr int | dynamicExponentBits = 4 |
| |
| constexpr int | staticExponentBits = 4 |
| |
| constexpr uint64_t | constExponentBits = 0x300 |
| |
| constexpr uint64_t | dynamicMantissaMask = (1ULL << (mantissaSize + dynamicExponentBits)) - 1 |
| |
| constexpr uint64_t | superscalarMul0 = 6364136223846793005ULL |
| |
| constexpr uint64_t | superscalarAdd1 = 9298411001130361340ULL |
| |
| constexpr uint64_t | superscalarAdd2 = 12065312585734608966ULL |
| |
| constexpr uint64_t | superscalarAdd3 = 9306329213124626780ULL |
| |
| constexpr uint64_t | superscalarAdd4 = 5281919268842080866ULL |
| |
| constexpr uint64_t | superscalarAdd5 = 10536153434571861004ULL |
| |
| constexpr uint64_t | superscalarAdd6 = 3398623926847679864ULL |
| |
| constexpr uint64_t | superscalarAdd7 = 9549104520008361294ULL |
| |
| static const size_t | CodeSize = ((uint8_t*)randomx_init_dataset_aarch64_end) - ((uint8_t*)randomx_program_aarch64) |
| |
| static const size_t | MainLoopBegin = ((uint8_t*)randomx_program_aarch64_main_loop) - ((uint8_t*)randomx_program_aarch64) |
| |
| static const size_t | PrologueSize = ((uint8_t*)randomx_program_aarch64_vm_instructions) - ((uint8_t*)randomx_program_aarch64) |
| |
| static const size_t | ImulRcpLiteralsEnd = ((uint8_t*)randomx_program_aarch64_imul_rcp_literals_end) - ((uint8_t*)randomx_program_aarch64) |
| |
| static const size_t | CalcDatasetItemSize |
| |
| constexpr uint32_t | IntRegMap [8] = { 4, 5, 6, 7, 12, 13, 14, 15 } |
| |
| constexpr size_t | MaxRandomXInstrCodeSize = 32 |
| |
| constexpr size_t | MaxSuperscalarInstrSize = 14 |
| |
| constexpr size_t | SuperscalarProgramHeader = 128 |
| |
| constexpr size_t | CodeAlign = 4096 |
| |
| constexpr size_t | ReserveCodeSize = CodeAlign |
| |
| constexpr size_t | RandomXCodeSize = alignSize(ReserveCodeSize + MaxRandomXInstrCodeSize * RANDOMX_PROGRAM_SIZE, CodeAlign) |
| |
| constexpr size_t | SuperscalarSize = alignSize(ReserveCodeSize + (SuperscalarProgramHeader + MaxSuperscalarInstrSize * SuperscalarMaxSize) * RANDOMX_CACHE_ACCESSES, CodeAlign) |
| |
| constexpr int32_t | superScalarHashOffset = RandomXCodeSize |
| |
| const uint8_t * | codePrologue = ADDR(randomx_program_prologue) |
| |
| const uint8_t * | codeLoopBegin = ADDR(randomx_program_loop_begin) |
| |
| const uint8_t * | codeLoopLoad = ADDR(randomx_program_loop_load) |
| |
| const uint8_t * | codeProgamStart = ADDR(randomx_program_start) |
| |
| const uint8_t * | codeReadDataset = ADDR(randomx_program_read_dataset) |
| |
| const uint8_t * | codeReadDatasetLightSshInit = ADDR(randomx_program_read_dataset_sshash_init) |
| |
| const uint8_t * | codeReadDatasetLightSshFin = ADDR(randomx_program_read_dataset_sshash_fin) |
| |
| const uint8_t * | codeDatasetInit = ADDR(randomx_dataset_init) |
| |
| const uint8_t * | codeLoopStore = ADDR(randomx_program_loop_store) |
| |
| const uint8_t * | codeLoopEnd = ADDR(randomx_program_loop_end) |
| |
| const uint8_t * | codeEpilogue = ADDR(randomx_program_epilogue) |
| |
| const uint8_t * | codeProgramEnd = ADDR(randomx_program_end) |
| |
| const uint8_t * | codeShhLoad = ADDR(randomx_sshash_load) |
| |
| const uint8_t * | codeShhPrefetch = ADDR(randomx_sshash_prefetch) |
| |
| const uint8_t * | codeShhEnd = ADDR(randomx_sshash_end) |
| |
| const uint8_t * | codeShhInit = ADDR(randomx_sshash_init) |
| |
| const int32_t | prologueSize = codeLoopBegin - codePrologue |
| |
| const int32_t | loopLoadSize = codeProgamStart - codeLoopLoad |
| |
| const int32_t | readDatasetSize = codeReadDatasetLightSshInit - codeReadDataset |
| |
| const int32_t | readDatasetLightInitSize = codeReadDatasetLightSshFin - codeReadDatasetLightSshInit |
| |
| const int32_t | readDatasetLightFinSize = codeLoopStore - codeReadDatasetLightSshFin |
| |
| const int32_t | loopStoreSize = codeLoopEnd - codeLoopStore |
| |
| const int32_t | datasetInitSize = codeEpilogue - codeDatasetInit |
| |
| const int32_t | epilogueSize = codeShhLoad - codeEpilogue |
| |
| const int32_t | codeSshLoadSize = codeShhPrefetch - codeShhLoad |
| |
| const int32_t | codeSshPrefetchSize = codeShhEnd - codeShhPrefetch |
| |
| const int32_t | codeSshInitSize = codeProgramEnd - codeShhInit |
| |
| const int32_t | epilogueOffset = CodeSize - epilogueSize |
| |
| static const uint8_t | REX_ADD_RR [] = { 0x4d, 0x03 } |
| |
| static const uint8_t | REX_ADD_RM [] = { 0x4c, 0x03 } |
| |
| static const uint8_t | REX_SUB_RR [] = { 0x4d, 0x2b } |
| |
| static const uint8_t | REX_SUB_RM [] = { 0x4c, 0x2b } |
| |
| static const uint8_t | REX_MOV_RR [] = { 0x41, 0x8b } |
| |
| static const uint8_t | REX_MOV_RR64 [] = { 0x49, 0x8b } |
| |
| static const uint8_t | REX_MOV_R64R [] = { 0x4c, 0x8b } |
| |
| static const uint8_t | REX_IMUL_RR [] = { 0x4d, 0x0f, 0xaf } |
| |
| static const uint8_t | REX_IMUL_RRI [] = { 0x4d, 0x69 } |
| |
| static const uint8_t | REX_IMUL_RM [] = { 0x4c, 0x0f, 0xaf } |
| |
| static const uint8_t | REX_MUL_R [] = { 0x49, 0xf7 } |
| |
| static const uint8_t | REX_MUL_M [] = { 0x48, 0xf7 } |
| |
| static const uint8_t | REX_81 [] = { 0x49, 0x81 } |
| |
| static const uint8_t | AND_EAX_I = 0x25 |
| |
| static const uint8_t | MOV_EAX_I = 0xb8 |
| |
| static const uint8_t | MOV_RAX_I [] = { 0x48, 0xb8 } |
| |
| static const uint8_t | MOV_RCX_I [] = { 0x48, 0xb9 } |
| |
| static const uint8_t | REX_LEA [] = { 0x4f, 0x8d } |
| |
| static const uint8_t | REX_MUL_MEM [] = { 0x48, 0xf7, 0x24, 0x0e } |
| |
| static const uint8_t | REX_IMUL_MEM [] = { 0x48, 0xf7, 0x2c, 0x0e } |
| |
| static const uint8_t | REX_SHR_RAX [] = { 0x48, 0xc1, 0xe8 } |
| |
| static const uint8_t | RAX_ADD_SBB_1 [] = { 0x48, 0x83, 0xC0, 0x01, 0x48, 0x83, 0xD8, 0x00 } |
| |
| static const uint8_t | MUL_RCX [] = { 0x48, 0xf7, 0xe1 } |
| |
| static const uint8_t | REX_SHR_RDX [] = { 0x48, 0xc1, 0xea } |
| |
| static const uint8_t | REX_SH [] = { 0x49, 0xc1 } |
| |
| static const uint8_t | MOV_RCX_RAX_SAR_RCX_63 [] = { 0x48, 0x89, 0xc1, 0x48, 0xc1, 0xf9, 0x3f } |
| |
| static const uint8_t | AND_ECX_I [] = { 0x81, 0xe1 } |
| |
| static const uint8_t | ADD_RAX_RCX [] = { 0x48, 0x01, 0xC8 } |
| |
| static const uint8_t | SAR_RAX_I8 [] = { 0x48, 0xC1, 0xF8 } |
| |
| static const uint8_t | NEG_RAX [] = { 0x48, 0xF7, 0xD8 } |
| |
| static const uint8_t | ADD_R_RAX [] = { 0x4C, 0x03 } |
| |
| static const uint8_t | XOR_EAX_EAX [] = { 0x33, 0xC0 } |
| |
| static const uint8_t | ADD_RDX_R [] = { 0x4c, 0x01 } |
| |
| static const uint8_t | SUB_RDX_R [] = { 0x4c, 0x29 } |
| |
| static const uint8_t | SAR_RDX_I8 [] = { 0x48, 0xC1, 0xFA } |
| |
| static const uint8_t | TEST_RDX_RDX [] = { 0x48, 0x85, 0xD2 } |
| |
| static const uint8_t | SETS_AL_ADD_RDX_RAX [] = { 0x0F, 0x98, 0xC0, 0x48, 0x03, 0xD0 } |
| |
| static const uint8_t | REX_NEG [] = { 0x49, 0xF7 } |
| |
| static const uint8_t | REX_XOR_RR [] = { 0x4D, 0x33 } |
| |
| static const uint8_t | REX_XOR_RI [] = { 0x49, 0x81 } |
| |
| static const uint8_t | REX_XOR_RM [] = { 0x4c, 0x33 } |
| |
| static const uint8_t | REX_ROT_CL [] = { 0x49, 0xd3 } |
| |
| static const uint8_t | REX_ROT_I8 [] = { 0x49, 0xc1 } |
| |
| static const uint8_t | SHUFPD [] = { 0x66, 0x0f, 0xc6 } |
| |
| static const uint8_t | REX_ADDPD [] = { 0x66, 0x41, 0x0f, 0x58 } |
| |
| static const uint8_t | REX_CVTDQ2PD_XMM12 [] = { 0xf3, 0x44, 0x0f, 0xe6, 0x24, 0x06 } |
| |
| static const uint8_t | REX_SUBPD [] = { 0x66, 0x41, 0x0f, 0x5c } |
| |
| static const uint8_t | REX_XORPS [] = { 0x41, 0x0f, 0x57 } |
| |
| static const uint8_t | REX_MULPD [] = { 0x66, 0x41, 0x0f, 0x59 } |
| |
| static const uint8_t | REX_MAXPD [] = { 0x66, 0x41, 0x0f, 0x5f } |
| |
| static const uint8_t | REX_DIVPD [] = { 0x66, 0x41, 0x0f, 0x5e } |
| |
| static const uint8_t | SQRTPD [] = { 0x66, 0x0f, 0x51 } |
| |
| static const uint8_t | AND_OR_MOV_LDMXCSR [] = { 0x25, 0x00, 0x60, 0x00, 0x00, 0x0D, 0xC0, 0x9F, 0x00, 0x00, 0x50, 0x0F, 0xAE, 0x14, 0x24, 0x58 } |
| |
| static const uint8_t | ROL_RAX [] = { 0x48, 0xc1, 0xc0 } |
| |
| static const uint8_t | XOR_ECX_ECX [] = { 0x33, 0xC9 } |
| |
| static const uint8_t | REX_CMP_R32I [] = { 0x41, 0x81 } |
| |
| static const uint8_t | REX_CMP_M32I [] = { 0x81, 0x3c, 0x06 } |
| |
| static const uint8_t | MOVAPD [] = { 0x66, 0x0f, 0x29 } |
| |
| static const uint8_t | REX_MOV_MR [] = { 0x4c, 0x89 } |
| |
| static const uint8_t | REX_XOR_EAX [] = { 0x41, 0x33 } |
| |
| static const uint8_t | SUB_EBX [] = { 0x83, 0xEB, 0x01 } |
| |
| static const uint8_t | JNZ [] = { 0x0f, 0x85 } |
| |
| static const uint8_t | JMP = 0xe9 |
| |
| static const uint8_t | REX_XOR_RAX_R64 [] = { 0x49, 0x33 } |
| |
| static const uint8_t | REX_XCHG [] = { 0x4d, 0x87 } |
| |
| static const uint8_t | REX_ANDPS_XMM12 [] = { 0x45, 0x0F, 0x54, 0xE5, 0x45, 0x0F, 0x56, 0xE6 } |
| |
| static const uint8_t | REX_PADD [] = { 0x66, 0x44, 0x0f } |
| |
| static const uint8_t | PADD_OPCODES [] = { 0xfc, 0xfd, 0xfe, 0xd4 } |
| |
| static const uint8_t | CALL = 0xe8 |
| |
| static const uint8_t | REX_ADD_I [] = { 0x49, 0x81 } |
| |
| static const uint8_t | REX_TEST [] = { 0x49, 0xF7 } |
| |
| static const uint8_t | JZ [] = { 0x0f, 0x84 } |
| |
| static const uint8_t | RET = 0xc3 |
| |
| static const uint8_t | LEA_32 [] = { 0x41, 0x8d } |
| |
| static const uint8_t | MOVNTI [] = { 0x4c, 0x0f, 0xc3 } |
| |
| static const uint8_t | ADD_EBX_I [] = { 0x81, 0xc3 } |
| |
| static const uint8_t | NOP1 [] = { 0x90 } |
| |
| static const uint8_t | NOP2 [] = { 0x66, 0x90 } |
| |
| static const uint8_t | NOP3 [] = { 0x66, 0x66, 0x90 } |
| |
| static const uint8_t | NOP4 [] = { 0x0F, 0x1F, 0x40, 0x00 } |
| |
| static const uint8_t | NOP5 [] = { 0x0F, 0x1F, 0x44, 0x00, 0x00 } |
| |
| static const uint8_t | NOP6 [] = { 0x66, 0x0F, 0x1F, 0x44, 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 * | NOPX [] = { NOP1, NOP2, NOP3, NOP4, NOP5, NOP6, NOP7, NOP8 } |
| |
| const MacroOp | IMULH_R_ops_array [] = { MacroOp::Mov_rr, MacroOp::Mul_r, MacroOp::Mov_rr } |
| |
| const MacroOp | ISMULH_R_ops_array [] = { MacroOp::Mov_rr, MacroOp::Imul_r, MacroOp::Mov_rr } |
| |
| const MacroOp | IMUL_RCP_ops_array [] = { MacroOp::Mov_ri64, MacroOp(MacroOp::Imul_rr, true) } |
| |
| const int | buffer0 [] = { 4, 8, 4 } |
| |
| const int | buffer1 [] = { 7, 3, 3, 3 } |
| |
| const int | buffer2 [] = { 3, 7, 3, 3 } |
| |
| const int | buffer3 [] = { 4, 9, 3 } |
| |
| const int | buffer4 [] = { 4, 4, 4, 4 } |
| |
| const int | buffer5 [] = { 3, 3, 10 } |
| |
| const SuperscalarInstructionInfo * | slot_3 [] = { &SuperscalarInstructionInfo::ISUB_R, &SuperscalarInstructionInfo::IXOR_R } |
| |
| const SuperscalarInstructionInfo * | slot_3L [] = { &SuperscalarInstructionInfo::ISUB_R, &SuperscalarInstructionInfo::IXOR_R, &SuperscalarInstructionInfo::IMULH_R, &SuperscalarInstructionInfo::ISMULH_R } |
| |
| const SuperscalarInstructionInfo * | slot_4 [] = { &SuperscalarInstructionInfo::IROR_C, &SuperscalarInstructionInfo::IADD_RS } |
| |
| const SuperscalarInstructionInfo * | slot_7 [] = { &SuperscalarInstructionInfo::IXOR_C7, &SuperscalarInstructionInfo::IADD_C7 } |
| |
| const SuperscalarInstructionInfo * | slot_8 [] = { &SuperscalarInstructionInfo::IXOR_C8, &SuperscalarInstructionInfo::IADD_C8 } |
| |
| const SuperscalarInstructionInfo * | slot_9 [] = { &SuperscalarInstructionInfo::IXOR_C9, &SuperscalarInstructionInfo::IADD_C9 } |
| |
| const SuperscalarInstructionInfo * | slot_10 = &SuperscalarInstructionInfo::IMUL_RCP |
| |
| constexpr int | CYCLE_MAP_SIZE = RANDOMX_SUPERSCALAR_LATENCY + 4 |
| |
| constexpr int | LOOK_FORWARD_CYCLES = 4 |
| |
| constexpr int | MAX_THROWAWAY_COUNT = 256 |
| |
| static volatile rx_vec_i128 | aesDummy |
| |