Implementation notes: amd64, pmnod003, crypto_kem/mceliece6960119f

Computer: pmnod003
Architecture: amd64
CPU ID: GenuineIntel-00050654-bfebfbff
SUPERCOP version: 20190816
Operation: crypto_kem
Primitive: mceliece6960119f
TimeImplementationCompilerBenchmark dateSUPERCOP version
420146avxgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2019082020190816
638332ssegcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2019082020190816
709974ssegcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2019082020190816
720182ssegcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2019082020190816
735846ssegcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2019082020190816
1687400vecgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2019082020190816
1854328vecicc -xCORE-AVX512 -O3 -fomit-frame-pointer2019082020190816
1882432vecicc -xCORE-AVX512 -O2 -fomit-frame-pointer2019082020190816
1906620vecicc -xCOMMON-AVX512 -O3 -fomit-frame-pointer2019082020190816
1925202vecicc -xSSE4.2 -O3 -fomit-frame-pointer2019082020190816
1963642vecicc -xCORE-AVX-I -O3 -fomit-frame-pointer2019082020190816
1964780vecicc -xAVX -O3 -fomit-frame-pointer2019082020190816
1981220vecicc -xSSE4.2 -O2 -fomit-frame-pointer2019082020190816
2027210vecicc -xAVX -O2 -fomit-frame-pointer2019082020190816
2031320vecicc -xSSE4.1 -O3 -fomit-frame-pointer2019082020190816
2036942vecicc -xCORE-AVX-I -O2 -fomit-frame-pointer2019082020190816
2075418vecicc -xSSE4.1 -O2 -fomit-frame-pointer2019082020190816
2079528vecicc -xCOMMON-AVX512 -O2 -fomit-frame-pointer2019082020190816
2111114vecicc -xCORE-AVX2 -O2 -fomit-frame-pointer2019082020190816
2121206vecicc -xCORE-AVX2 -O3 -fomit-frame-pointer2019082020190816
2809576vecgcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2019082020190816
2834838vecgcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2019082020190816
2859630vecgcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2019082020190816
269686776reficc -xCOMMON-AVX512 -O2 -fomit-frame-pointer2019082020190816
271717310reficc -xCOMMON-AVX512 -O3 -fomit-frame-pointer2019082020190816
272170692reficc -xSSE4.1 -O3 -fomit-frame-pointer2019082020190816
272378376reficc -xSSE4.1 -O2 -fomit-frame-pointer2019082020190816
272462750reficc -xCORE-AVX-I -O3 -fomit-frame-pointer2019082020190816
272571314reficc -xAVX -O3 -fomit-frame-pointer2019082020190816
272574796reficc -xSSE4.2 -O3 -fomit-frame-pointer2019082020190816
273446090reficc -xSSE4.2 -O2 -fomit-frame-pointer2019082020190816
274236828reficc -xCORE-AVX-I -O2 -fomit-frame-pointer2019082020190816
274242008reficc -xAVX -O2 -fomit-frame-pointer2019082020190816
275077572reficc -xCORE-AVX2 -O2 -fomit-frame-pointer2019082020190816
275418116reficc -xCORE-AVX2 -O3 -fomit-frame-pointer2019082020190816
275599198reficc -xCORE-AVX512 -O3 -fomit-frame-pointer2019082020190816
275755094reficc -xCORE-AVX512 -O2 -fomit-frame-pointer2019082020190816
288352314refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2019082020190816
388944050refgcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2019082020190816
390994760refgcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2019082020190816
391758576refgcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2019082020190816

Compiler output

Implementation: crypto_kem/mceliece6960119f/avx
Compiler: gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv
bm.c: In file included from /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/immintrin.h:51,
bm.c: from vec256.h:11,
bm.c: from bm.h:10,
bm.c: from bm.c:6:
bm.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/avxintrin.h: In function 'bm':
bm.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/avxintrin.h:524:20: error: the last argument must be a 1-bit immediate
bm.c: 524 | return (__m128i) __builtin_ia32_vextractf128_si256 ((__v8si)__X, __N);
bm.c: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
bm.c: In file included from vec128.h:12,
bm.c: from bm.h:9,
bm.c: from bm.c:6:
bm.c: /software/compilers/gcc/gcc-9.2.0-full+isl+binutils/lib/gcc/x86_64-pc-linux-gnu/9.2.0/include/smmintrin.h:456:10: error: selector must be an integer constant in the range 0..1
bm.c: 456 | return __builtin_ia32_vec_ext_v2di ((__v2di)__X, __N);
bm.c: | ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Number of similar (compiler,implementation) pairs: 3, namely:
CompilerImplementations
gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv avx
gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv avx
gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv avx

Compiler output

Implementation: crypto_kem/mceliece6960119f/sse
Compiler: icc -xAVX -O2 -fomit-frame-pointer
bm.c: bm.c(129): (col. 30) catastrophic error: Intrinsic parameter must be an immediate value
bm.c: compilation aborted for bm.c (code 1)

Number of similar (compiler,implementation) pairs: 14, namely:
CompilerImplementations
icc -xAVX -O2 -fomit-frame-pointer sse
icc -xAVX -O3 -fomit-frame-pointer sse
icc -xCOMMON-AVX512 -O2 -fomit-frame-pointer sse
icc -xCOMMON-AVX512 -O3 -fomit-frame-pointer sse
icc -xCORE-AVX-I -O2 -fomit-frame-pointer sse
icc -xCORE-AVX-I -O3 -fomit-frame-pointer sse
icc -xCORE-AVX2 -O2 -fomit-frame-pointer sse
icc -xCORE-AVX2 -O3 -fomit-frame-pointer sse
icc -xCORE-AVX512 -O2 -fomit-frame-pointer sse
icc -xCORE-AVX512 -O3 -fomit-frame-pointer sse
icc -xSSE4.1 -O2 -fomit-frame-pointer sse
icc -xSSE4.1 -O3 -fomit-frame-pointer sse
icc -xSSE4.2 -O2 -fomit-frame-pointer sse
icc -xSSE4.2 -O3 -fomit-frame-pointer sse

Compiler output

Implementation: crypto_kem/mceliece6960119f/avx
Compiler: icc -xAVX -O2 -fomit-frame-pointer
bm.c: bm.c(133): (col. 30) catastrophic error: Intrinsic parameter must be an immediate value
bm.c: compilation aborted for bm.c (code 1)

Number of similar (compiler,implementation) pairs: 14, namely:
CompilerImplementations
icc -xAVX -O2 -fomit-frame-pointer avx
icc -xAVX -O3 -fomit-frame-pointer avx
icc -xCOMMON-AVX512 -O2 -fomit-frame-pointer avx
icc -xCOMMON-AVX512 -O3 -fomit-frame-pointer avx
icc -xCORE-AVX-I -O2 -fomit-frame-pointer avx
icc -xCORE-AVX-I -O3 -fomit-frame-pointer avx
icc -xCORE-AVX2 -O2 -fomit-frame-pointer avx
icc -xCORE-AVX2 -O3 -fomit-frame-pointer avx
icc -xCORE-AVX512 -O2 -fomit-frame-pointer avx
icc -xCORE-AVX512 -O3 -fomit-frame-pointer avx
icc -xSSE4.1 -O2 -fomit-frame-pointer avx
icc -xSSE4.1 -O3 -fomit-frame-pointer avx
icc -xSSE4.2 -O2 -fomit-frame-pointer avx
icc -xSSE4.2 -O3 -fomit-frame-pointer avx

Compiler output

Implementation: crypto_kem/mceliece6960119f/vec
Compiler: icc -xAVX -O2 -fomit-frame-pointer
pk_gen.c: pk_gen.c(205): warning #167: argument of type "vec={uint64_t={unsigned long}} (*)[13]" is incompatible with parameter of type "const vec={uint64_t={unsigned long}} (*)[13]"
pk_gen.c: de_bitslicing(list, prod);
pk_gen.c: ^
pk_gen.c:

Number of similar (compiler,implementation) pairs: 14, namely:
CompilerImplementations
icc -xAVX -O2 -fomit-frame-pointer vec
icc -xAVX -O3 -fomit-frame-pointer vec
icc -xCOMMON-AVX512 -O2 -fomit-frame-pointer vec
icc -xCOMMON-AVX512 -O3 -fomit-frame-pointer vec
icc -xCORE-AVX-I -O2 -fomit-frame-pointer vec
icc -xCORE-AVX-I -O3 -fomit-frame-pointer vec
icc -xCORE-AVX2 -O2 -fomit-frame-pointer vec
icc -xCORE-AVX2 -O3 -fomit-frame-pointer vec
icc -xCORE-AVX512 -O2 -fomit-frame-pointer vec
icc -xCORE-AVX512 -O3 -fomit-frame-pointer vec
icc -xSSE4.1 -O2 -fomit-frame-pointer vec
icc -xSSE4.1 -O3 -fomit-frame-pointer vec
icc -xSSE4.2 -O2 -fomit-frame-pointer vec
icc -xSSE4.2 -O3 -fomit-frame-pointer vec