Browse Source

restore BlockCipher XOR using SSE

pull/1274/head
orignal 6 years ago
parent
commit
f7e9975192
  1. 13
      libi2pd/Crypto.h

13
libi2pd/Crypto.h

@ -125,6 +125,18 @@ namespace crypto @@ -125,6 +125,18 @@ namespace crypto
else
#endif
{
#if defined(__SSE__) // SSE
__asm__
(
"movups (%[buf]), %%xmm0 \n"
"movups (%[other]), %%xmm1 \n"
"pxor %%xmm1, %%xmm0 \n"
"movups %%xmm0, (%[buf]) \n"
:
: [buf]"r"(buf), [other]"r"(other.buf)
: "%xmm0", "%xmm1", "memory"
);
#else
if (!(((size_t)buf | (size_t)other.buf) & 0x03)) // multiple of 4 ?
{
// we are good to cast to uint32_t *
@ -136,6 +148,7 @@ namespace crypto @@ -136,6 +148,7 @@ namespace crypto
for (int i = 0; i < 16; i++)
buf[i] ^= other.buf[i];
}
#endif
}
}
};

Loading…
Cancel
Save