b3f9d4f8d6
* Add McEliece reference implementations * Add Vec implementations of McEliece * Add sse implementations * Add AVX2 implementations * Get rid of stuff not supported by Mac ABI * restrict to two cores * Ditch .data files * Remove .hidden from all .S files * speed up duplicate consistency tests by batching * make cpuinfo more robust * Hope to stabilize macos cpuinfo without ccache * Revert "Hope to stabilize macos cpuinfo without ccache" This reverts commit 6129c3cabe1abbc8b956bc87e902a698e32bf322. * Just hardcode what's available at travis * Fixed-size types in api.h * namespace all header files in mceliece * Ditch operations.h * Get rid of static inline functions * fixup! Ditch operations.h
19 lines
435 B
C
19 lines
435 B
C
#include "uint32_sort.h"
|
|
|
|
#include "int32_sort.h"
|
|
|
|
|
|
/* can save time by vectorizing xor loops */
|
|
/* can save time by integrating xor loops with int32_sort */
|
|
|
|
void PQCLEAN_MCELIECE348864F_AVX_uint32_sort(uint32_t *x, size_t n) {
|
|
size_t j;
|
|
for (j = 0; j < n; ++j) {
|
|
x[j] ^= 0x80000000;
|
|
}
|
|
PQCLEAN_MCELIECE348864F_AVX_int32_sort((int32_t *) x, n);
|
|
for (j = 0; j < n; ++j) {
|
|
x[j] ^= 0x80000000;
|
|
}
|
|
}
|