mirror of
https://github.com/xmrig/xmrig.git
synced 2025-01-22 10:45:06 +00:00
VAES crash fixes
This commit is contained in:
parent
77367abe13
commit
1a9eaaad8f
2 changed files with 21 additions and 21 deletions
|
@ -140,7 +140,7 @@ static inline bool has_osxsave() { return has_feature(PROCESSOR_INFO,
|
||||||
static inline bool has_aes_ni() { return has_feature(PROCESSOR_INFO, ECX_Reg, 1 << 25); }
|
static inline bool has_aes_ni() { return has_feature(PROCESSOR_INFO, ECX_Reg, 1 << 25); }
|
||||||
static inline bool has_avx() { return has_feature(PROCESSOR_INFO, ECX_Reg, 1 << 28) && has_osxsave() && has_xcr_avx(); }
|
static inline bool has_avx() { return has_feature(PROCESSOR_INFO, ECX_Reg, 1 << 28) && has_osxsave() && has_xcr_avx(); }
|
||||||
static inline bool has_avx2() { return has_feature(EXTENDED_FEATURES, EBX_Reg, 1 << 5) && has_osxsave() && has_xcr_avx(); }
|
static inline bool has_avx2() { return has_feature(EXTENDED_FEATURES, EBX_Reg, 1 << 5) && has_osxsave() && has_xcr_avx(); }
|
||||||
static inline bool has_vaes() { return has_feature(EXTENDED_FEATURES, ECX_Reg, 1 << 9); }
|
static inline bool has_vaes() { return has_feature(EXTENDED_FEATURES, ECX_Reg, 1 << 9) && has_osxsave() && has_xcr_avx(); }
|
||||||
static inline bool has_avx512f() { return has_feature(EXTENDED_FEATURES, EBX_Reg, 1 << 16) && has_osxsave() && has_xcr_avx512(); }
|
static inline bool has_avx512f() { return has_feature(EXTENDED_FEATURES, EBX_Reg, 1 << 16) && has_osxsave() && has_xcr_avx512(); }
|
||||||
static inline bool has_bmi2() { return has_feature(EXTENDED_FEATURES, EBX_Reg, 1 << 8); }
|
static inline bool has_bmi2() { return has_feature(EXTENDED_FEATURES, EBX_Reg, 1 << 8); }
|
||||||
static inline bool has_pdpe1gb() { return has_feature(PROCESSOR_EXT_INFO, EDX_Reg, 1 << 26); }
|
static inline bool has_pdpe1gb() { return has_feature(PROCESSOR_EXT_INFO, EDX_Reg, 1 << 26); }
|
||||||
|
|
|
@ -179,16 +179,16 @@ NOINLINE void cn_explode_scratchpad_vaes(cryptonight_ctx* ctx)
|
||||||
|
|
||||||
if (props.half_mem() && !ctx->first_half) {
|
if (props.half_mem() && !ctx->first_half) {
|
||||||
const __m256i* p = reinterpret_cast<const __m256i*>(ctx->save_state);
|
const __m256i* p = reinterpret_cast<const __m256i*>(ctx->save_state);
|
||||||
xin01 = _mm256_load_si256(p + 0);
|
xin01 = _mm256_loadu_si256(p + 0);
|
||||||
xin23 = _mm256_load_si256(p + 1);
|
xin23 = _mm256_loadu_si256(p + 1);
|
||||||
xin45 = _mm256_load_si256(p + 2);
|
xin45 = _mm256_loadu_si256(p + 2);
|
||||||
xin67 = _mm256_load_si256(p + 3);
|
xin67 = _mm256_loadu_si256(p + 3);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
xin01 = _mm256_load_si256(reinterpret_cast<const __m256i*>(input + 4));
|
xin01 = _mm256_loadu_si256(reinterpret_cast<const __m256i*>(input + 4));
|
||||||
xin23 = _mm256_load_si256(reinterpret_cast<const __m256i*>(input + 6));
|
xin23 = _mm256_loadu_si256(reinterpret_cast<const __m256i*>(input + 6));
|
||||||
xin45 = _mm256_load_si256(reinterpret_cast<const __m256i*>(input + 8));
|
xin45 = _mm256_loadu_si256(reinterpret_cast<const __m256i*>(input + 8));
|
||||||
xin67 = _mm256_load_si256(reinterpret_cast<const __m256i*>(input + 10));
|
xin67 = _mm256_loadu_si256(reinterpret_cast<const __m256i*>(input + 10));
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr int output_increment = 64 / sizeof(__m256i);
|
constexpr int output_increment = 64 / sizeof(__m256i);
|
||||||
|
@ -228,10 +228,10 @@ NOINLINE void cn_explode_scratchpad_vaes(cryptonight_ctx* ctx)
|
||||||
|
|
||||||
if (props.half_mem() && ctx->first_half) {
|
if (props.half_mem() && ctx->first_half) {
|
||||||
__m256i* p = reinterpret_cast<__m256i*>(ctx->save_state);
|
__m256i* p = reinterpret_cast<__m256i*>(ctx->save_state);
|
||||||
_mm256_store_si256(p + 0, xin01);
|
_mm256_storeu_si256(p + 0, xin01);
|
||||||
_mm256_store_si256(p + 1, xin23);
|
_mm256_storeu_si256(p + 1, xin23);
|
||||||
_mm256_store_si256(p + 2, xin45);
|
_mm256_storeu_si256(p + 2, xin45);
|
||||||
_mm256_store_si256(p + 3, xin67);
|
_mm256_storeu_si256(p + 3, xin67);
|
||||||
}
|
}
|
||||||
|
|
||||||
_mm256_zeroupper();
|
_mm256_zeroupper();
|
||||||
|
@ -347,10 +347,10 @@ NOINLINE void cn_implode_scratchpad_vaes(cryptonight_ctx* ctx)
|
||||||
|
|
||||||
vaes_genkey(reinterpret_cast<__m128i*>(output) + 2, &k0, &k1, &k2, &k3, &k4, &k5, &k6, &k7, &k8, &k9);
|
vaes_genkey(reinterpret_cast<__m128i*>(output) + 2, &k0, &k1, &k2, &k3, &k4, &k5, &k6, &k7, &k8, &k9);
|
||||||
|
|
||||||
xout01 = _mm256_load_si256(output + 2);
|
xout01 = _mm256_loadu_si256(output + 2);
|
||||||
xout23 = _mm256_load_si256(output + 3);
|
xout23 = _mm256_loadu_si256(output + 3);
|
||||||
xout45 = _mm256_load_si256(output + 4);
|
xout45 = _mm256_loadu_si256(output + 4);
|
||||||
xout67 = _mm256_load_si256(output + 5);
|
xout67 = _mm256_loadu_si256(output + 5);
|
||||||
|
|
||||||
const __m256i* input_begin = input;
|
const __m256i* input_begin = input;
|
||||||
for (size_t part = 0; part < (props.half_mem() ? 2 : 1); ++part) {
|
for (size_t part = 0; part < (props.half_mem() ? 2 : 1); ++part) {
|
||||||
|
@ -390,10 +390,10 @@ NOINLINE void cn_implode_scratchpad_vaes(cryptonight_ctx* ctx)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
_mm256_store_si256(output + 2, xout01);
|
_mm256_storeu_si256(output + 2, xout01);
|
||||||
_mm256_store_si256(output + 3, xout23);
|
_mm256_storeu_si256(output + 3, xout23);
|
||||||
_mm256_store_si256(output + 4, xout45);
|
_mm256_storeu_si256(output + 4, xout45);
|
||||||
_mm256_store_si256(output + 5, xout67);
|
_mm256_storeu_si256(output + 5, xout67);
|
||||||
|
|
||||||
_mm256_zeroupper();
|
_mm256_zeroupper();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue