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
else else
#endif #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 ? if (!(((size_t)buf | (size_t)other.buf) & 0x03)) // multiple of 4 ?
{ {
// we are good to cast to uint32_t * // we are good to cast to uint32_t *
@ -136,6 +148,7 @@ namespace crypto
for (int i = 0; i < 16; i++) for (int i = 0; i < 16; i++)
buf[i] ^= other.buf[i]; buf[i] ^= other.buf[i];
} }
#endif
} }
} }
}; };

Loading…
Cancel
Save