1
0
mirror of https://github.com/PurpleI2P/i2pd.git synced 2025-01-08 18:47:52 +00:00

remove AVX and SSE for CipherBlock XOR

This commit is contained in:
orignal 2018-11-27 14:33:31 -05:00
parent fcd6eb7801
commit 0c9ebc36d4

View File

@ -108,43 +108,10 @@ namespace crypto
void operator^=(const ChipherBlock& other) // XOR void operator^=(const ChipherBlock& other) // XOR
{ {
if (!(((size_t)buf | (size_t)other.buf) & 0x0F)) // multiple of 16 ? if (!(((size_t)buf | (size_t)other.buf) & 0x03)) // multiple of 4 ?
{ {
// try 128 bits if applicable
#ifdef __AVX__
if (i2p::cpu::avx)
{
__asm__
(
"vmovaps (%[buf]), %%xmm0 \n"
"vmovaps (%[other]), %%xmm1 \n"
"vxorps %%xmm0, %%xmm1, %%xmm0 \n"
"vmovaps %%xmm0, (%[buf]) \n"
:
: [buf]"r"(buf), [other]"r"(other.buf)
: "%xmm0", "%xmm1", "memory"
);
}
else
#endif
{
#if defined(__SSE__) // SSE
__asm__
(
"movaps (%[buf]), %%xmm0 \n"
"movaps (%[other]), %%xmm1 \n"
"pxor %%xmm1, %%xmm0 \n"
"movaps %%xmm0, (%[buf]) \n"
:
: [buf]"r"(buf), [other]"r"(other.buf)
: "%xmm0", "%xmm1", "memory"
);
#else
// if not we always can cast to uint32_t *
for (int i = 0; i < 4; i++) for (int i = 0; i < 4; i++)
reinterpret_cast<uint32_t *>(buf)[i] ^= reinterpret_cast<const uint32_t *>(other.buf)[i]; reinterpret_cast<uint32_t *>(buf)[i] ^= reinterpret_cast<const uint32_t *>(other.buf)[i];
#endif
}
} }
else else
{ {