Implementation notes: amd64, calvin, crypto_encrypt/ntruees593ep1

Computer: calvin
Architecture: amd64
CPU ID: AuthenticAMD-00600f20-178bfbff
SUPERCOP version: 20171218
Operation: crypto_encrypt
Primitive: ntruees593ep1
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
296384? ? ?? ? ?refgcc_-m64_-march=core-avx-i_-O3_-fomit-frame-pointer2017111620171020
298719? ? ?? ? ?refgcc_-m64_-march=corei7-avx_-O3_-fomit-frame-pointer2017111620171020
300543? ? ?? ? ?refgcc_-m64_-march=core2_-msse4.1_-O3_-fomit-frame-pointer2017111620171020
302887? ? ?? ? ?refgcc_-m64_-march=core2_-O3_-fomit-frame-pointer2017111620171020
303115? ? ?? ? ?refgcc_-m64_-march=corei7_-O3_-fomit-frame-pointer2017111620171020
304351? ? ?? ? ?refgcc_-m64_-march=core2_-msse4_-O3_-fomit-frame-pointer2017111620171020
306597? ? ?? ? ?refgcc_-m64_-march=native_-mtune=native_-O3_-fomit-frame-pointer2017111620171020
308439? ? ?? ? ?refgcc_-march=native_-mtune=native_-O3_-fomit-frame-pointer_-fwrapv2017111620171020
310475? ? ?? ? ?refgcc_-m64_-march=core-avx-i_-O2_-fomit-frame-pointer2017111620171020
311080? ? ?? ? ?refgcc_-m64_-march=corei7-avx_-O2_-fomit-frame-pointer2017111620171020
316173? ? ?? ? ?refgcc_-m64_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2017111620171020
316677? ? ?? ? ?refgcc_-m64_-march=core2_-msse4_-O2_-fomit-frame-pointer2017111620171020
318019? ? ?? ? ?refgcc_-m64_-march=core2_-O2_-fomit-frame-pointer2017111620171020
320018? ? ?? ? ?refgcc_-m64_-march=corei7_-O2_-fomit-frame-pointer2017111620171020
320403? ? ?? ? ?refgcc_-m64_-march=core2_-msse4_-O_-fomit-frame-pointer2017111620171020
321439? ? ?? ? ?refgcc_-m64_-march=core2_-msse4.1_-O_-fomit-frame-pointer2017111620171020
321511? ? ?? ? ?refgcc_-m64_-march=core-avx-i_-O_-fomit-frame-pointer2017111620171020
322280? ? ?? ? ?refgcc_-march=native_-mtune=native_-O2_-fomit-frame-pointer_-fwrapv2017111620171020
322792? ? ?? ? ?refgcc_-m64_-march=native_-mtune=native_-O2_-fomit-frame-pointer2017111620171020
322932? ? ?? ? ?refgcc_-m64_-march=corei7-avx_-O_-fomit-frame-pointer2017111620171020
325066? ? ?? ? ?refgcc_-m64_-march=corei7_-O_-fomit-frame-pointer2017111620171020
326125? ? ?? ? ?refgcc_-m64_-march=native_-mtune=native_-O_-fomit-frame-pointer2017111620171020
329762? ? ?? ? ?refgcc_-march=native_-mtune=native_-O_-fomit-frame-pointer_-fwrapv2017111620171020
345108? ? ?? ? ?refgcc_-m64_-march=core2_-O_-fomit-frame-pointer2017111620171020
345330? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=barcelona_-O3_-fomit-frame-pointer2017111620171020
345944? ? ?? ? ?refgcc_-funroll-loops_-march=barcelona_-O3_-fomit-frame-pointer2017111620171020
346158? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=k8_-O3_-fomit-frame-pointer2017111620171020
346715? ? ?? ? ?refgcc_-funroll-loops_-march=k8_-O3_-fomit-frame-pointer2017111620171020
347786? ? ?? ? ?refgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2017111620171020
348104? ? ?? ? ?refgcc_-funroll-loops_-m64_-O3_-fomit-frame-pointer2017111620171020
348108? ? ?? ? ?refgcc_-funroll-loops_-O3_-fomit-frame-pointer2017111620171020
348451? ? ?? ? ?refgcc_-m64_-march=k8_-O3_-fomit-frame-pointer2017111620171020
348595? ? ?? ? ?refgcc_-O3_-fomit-frame-pointer2017111620171020
348911? ? ?? ? ?refgcc_-march=k8_-O3_-fomit-frame-pointer2017111620171020
349365? ? ?? ? ?refgcc_-m64_-O3_-fomit-frame-pointer2017111620171020
349390? ? ?? ? ?refgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2017111620171020
351815? ? ?? ? ?refgcc_-march=barcelona_-O3_-fomit-frame-pointer2017111620171020
352295? ? ?? ? ?refgcc_-m64_-march=barcelona_-O3_-fomit-frame-pointer2017111620171020
357976? ? ?? ? ?refgcc_-m64_-march=nocona_-O3_-fomit-frame-pointer2017111620171020
358777? ? ?? ? ?refgcc_-funroll-loops_-march=nocona_-O3_-fomit-frame-pointer2017111620171020
359443? ? ?? ? ?refgcc_-march=nocona_-O3_-fomit-frame-pointer2017111620171020
360299? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=nocona_-O3_-fomit-frame-pointer2017111620171020
362625? ? ?? ? ?refgcc_-m64_-march=corei7_-Os_-fomit-frame-pointer2017111620171020
364260? ? ?? ? ?refgcc_-funroll-loops_-march=barcelona_-O2_-fomit-frame-pointer2017111620171020
364277? ? ?? ? ?refgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2017111620171020
364282? ? ?? ? ?refgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2017111620171020
364412? ? ?? ? ?refgcc_-funroll-loops_-O2_-fomit-frame-pointer2017111620171020
364660? ? ?? ? ?refgcc_-funroll-loops_-m64_-O2_-fomit-frame-pointer2017111620171020
364807? ? ?? ? ?refgcc_-m64_-march=core2_-msse4_-Os_-fomit-frame-pointer2017111620171020
364965? ? ?? ? ?refgcc_-m64_-march=corei7-avx_-Os_-fomit-frame-pointer2017111620171020
364973? ? ?? ? ?refgcc_-funroll-loops_-m64_-O_-fomit-frame-pointer2017111620171020
365000? ? ?? ? ?refgcc_-m64_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2017111620171020
365076? ? ?? ? ?refgcc_-funroll-loops_-march=k8_-O2_-fomit-frame-pointer2017111620171020
365096? ? ?? ? ?refgcc_-funroll-loops_-O_-fomit-frame-pointer2017111620171020
365765? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=barcelona_-O2_-fomit-frame-pointer2017111620171020
366079? ? ?? ? ?refgcc_-m64_-march=core-avx-i_-Os_-fomit-frame-pointer2017111620171020
366888? ? ?? ? ?refgcc_-m64_-march=native_-mtune=native_-Os_-fomit-frame-pointer2017111620171020
369292? ? ?? ? ?refgcc_-m64_-march=core2_-Os_-fomit-frame-pointer2017111620171020
370407? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=barcelona_-O_-fomit-frame-pointer2017111620171020
371417? ? ?? ? ?refgcc_-funroll-loops_-march=barcelona_-O_-fomit-frame-pointer2017111620171020
373420? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=nocona_-O2_-fomit-frame-pointer2017111620171020
373737? ? ?? ? ?refgcc_-funroll-loops_-march=nocona_-O2_-fomit-frame-pointer2017111620171020
373936? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=k8_-O2_-fomit-frame-pointer2017111620171020
375649? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=k8_-O_-fomit-frame-pointer2017111620171020
376699? ? ?? ? ?refgcc_-march=native_-mtune=native_-Os_-fomit-frame-pointer_-fwrapv2017111620171020
380673? ? ?? ? ?refgcc_-m64_-march=barcelona_-O2_-fomit-frame-pointer2017111620171020
380958? ? ?? ? ?refgcc_-march=barcelona_-O2_-fomit-frame-pointer2017111620171020
381053? ? ?? ? ?refgcc_-march=k8_-O2_-fomit-frame-pointer2017111620171020
381589? ? ?? ? ?refgcc_-m64_-march=k8_-O2_-fomit-frame-pointer2017111620171020
382487? ? ?? ? ?refgcc_-funroll-loops_-march=nocona_-O_-fomit-frame-pointer2017111620171020
382892? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=nocona_-O_-fomit-frame-pointer2017111620171020
383703? ? ?? ? ?refgcc_-funroll-loops_-march=k8_-O_-fomit-frame-pointer2017111620171020
386227? ? ?? ? ?refgcc_-m64_-march=barcelona_-O_-fomit-frame-pointer2017111620171020
386474? ? ?? ? ?refgcc_-march=barcelona_-O_-fomit-frame-pointer2017111620171020
386589? ? ?? ? ?refgcc_-m64_-O_-fomit-frame-pointer2017111620171020
387068? ? ?? ? ?refgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2017111620171020
387386? ? ?? ? ?refgcc_-O_-fomit-frame-pointer2017111620171020
388744? ? ?? ? ?refgcc_-m64_-O2_-fomit-frame-pointer2017111620171020
389010? ? ?? ? ?refgcc_-O2_-fomit-frame-pointer2017111620171020
389125? ? ?? ? ?refgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2017111620171020
393188? ? ?? ? ?refgcc_-m64_-march=k8_-O_-fomit-frame-pointer2017111620171020
393271? ? ?? ? ?refgcc_-march=k8_-O_-fomit-frame-pointer2017111620171020
393354? ? ?? ? ?refgcc_-march=nocona_-O2_-fomit-frame-pointer2017111620171020
394502? ? ?? ? ?refgcc_-m64_-march=nocona_-O2_-fomit-frame-pointer2017111620171020
403811? ? ?? ? ?refgcc_-march=nocona_-O_-fomit-frame-pointer2017111620171020
405045? ? ?? ? ?refgcc_-m64_-march=nocona_-O_-fomit-frame-pointer2017111620171020
447665? ? ?? ? ?refgcc_-funroll-loops_-march=nocona_-Os_-fomit-frame-pointer2017111620171020
448483? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=nocona_-Os_-fomit-frame-pointer2017111620171020
455254? ? ?? ? ?refgcc_-m64_-Os_-fomit-frame-pointer2017111620171020
455344? ? ?? ? ?refgcc_-Os_-fomit-frame-pointer2017111620171020
455399? ? ?? ? ?refgcc_-march=barcelona_-Os_-fomit-frame-pointer2017111620171020
455527? ? ?? ? ?refgcc_-m64_-march=k8_-Os_-fomit-frame-pointer2017111620171020
456054? ? ?? ? ?refgcc_-march=k8_-Os_-fomit-frame-pointer2017111620171020
456177? ? ?? ? ?refgcc_-funroll-loops_-m64_-Os_-fomit-frame-pointer2017111620171020
456269? ? ?? ? ?refgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2017111620171020
456276? ? ?? ? ?refgcc_-m64_-march=barcelona_-Os_-fomit-frame-pointer2017111620171020
456461? ? ?? ? ?refgcc_-funroll-loops_-march=barcelona_-Os_-fomit-frame-pointer2017111620171020
457080? ? ?? ? ?refgcc_-funroll-loops_-Os_-fomit-frame-pointer2017111620171020
457432? ? ?? ? ?refgcc_-funroll-loops_-march=k8_-Os_-fomit-frame-pointer2017111620171020
457636? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=k8_-Os_-fomit-frame-pointer2017111620171020
458970? ? ?? ? ?refgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2017111620171020
458989? ? ?? ? ?refgcc_-march=nocona_-Os_-fomit-frame-pointer2017111620171020
459371? ? ?? ? ?refgcc_-m64_-march=nocona_-Os_-fomit-frame-pointer2017111620171020
460458? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=barcelona_-Os_-fomit-frame-pointer2017111620171020
1119081? ? ?? ? ?refgcc2017111620171020
1120178? ? ?? ? ?refcc2017111620171020
1144542? ? ?? ? ?refgcc_-funroll-loops2017111620171020

Test failure

Implementation: crypto_encrypt/ntruees593ep1/ref
Compiler: gcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer
error 111

Number of similar (compiler,implementation) pairs: 3, namely:
CompilerImplementations
gcc -m64 -march=core-avx2 -O2 -fomit-frame-pointer ref
gcc -m64 -march=core-avx2 -O -fomit-frame-pointer ref
gcc -m64 -march=core-avx2 -Os -fomit-frame-pointer ref

Compiler output

Implementation: crypto_encrypt/ntruees593ep1/ref
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
ntru_crypto_sha1.c: ntru_crypto_sha1.c:85:33: warning: '&' within '^' [-Wbitwise-op-parentheses]
ntru_crypto_sha1.c: E += RL(A, 5) + K00_19 + (B & (C ^ D) ^ D) + data[ 0]; B = RL(B, 30);
ntru_crypto_sha1.c: ~~^~~~~~~~~ ~
ntru_crypto_sha1.c: ntru_crypto_sha1.c:85:33: note: place parentheses around the '&' expression to silence this warning
ntru_crypto_sha1.c: E += RL(A, 5) + K00_19 + (B & (C ^ D) ^ D) + data[ 0]; B = RL(B, 30);
ntru_crypto_sha1.c: ^
ntru_crypto_sha1.c: ( )
ntru_crypto_sha1.c: ntru_crypto_sha1.c:86:33: warning: '&' within '^' [-Wbitwise-op-parentheses]
ntru_crypto_sha1.c: D += RL(E, 5) + K00_19 + (A & (B ^ C) ^ C) + data[ 1]; A = RL(A, 30);
ntru_crypto_sha1.c: ~~^~~~~~~~~ ~
ntru_crypto_sha1.c: ntru_crypto_sha1.c:86:33: note: place parentheses around the '&' expression to silence this warning
ntru_crypto_sha1.c: D += RL(E, 5) + K00_19 + (A & (B ^ C) ^ C) + data[ 1]; A = RL(A, 30);
ntru_crypto_sha1.c: ^
ntru_crypto_sha1.c: ( )
ntru_crypto_sha1.c: ntru_crypto_sha1.c:87:33: warning: '&' within '^' [-Wbitwise-op-parentheses]
ntru_crypto_sha1.c: C += RL(D, 5) + K00_19 + (E & (A ^ B) ^ B) + data[ 2]; E = RL(E, 30);
ntru_crypto_sha1.c: ~~^~~~~~~~~ ~
ntru_crypto_sha1.c: ntru_crypto_sha1.c:87:33: note: place parentheses around the '&' expression to silence this warning
ntru_crypto_sha1.c: C += RL(D, 5) + K00_19 + (E & (A ^ B) ^ B) + data[ 2]; E = RL(E, 30);
ntru_crypto_sha1.c: ^
ntru_crypto_sha1.c: ( )
ntru_crypto_sha1.c: ntru_crypto_sha1.c:88:33: warning: '&' within '^' [-Wbitwise-op-parentheses]
ntru_crypto_sha1.c: B += RL(C, 5) + K00_19 + (D & (E ^ A) ^ A) + data[ 3]; D = RL(D, 30);
ntru_crypto_sha1.c: ~~^~~~~~~~~ ~
ntru_crypto_sha1.c: ntru_crypto_sha1.c:88:33: note: place parentheses around the '&' expression to silence this warning
ntru_crypto_sha1.c: ...

Number of similar (compiler,implementation) pairs: 8, namely:
CompilerImplementations
clang -O3 -fomit-frame-pointer -Qunused-arguments ref
clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments ref
clang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments ref
clang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments ref
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref
clang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref
clang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref
clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref