Implementation notes: amd64, sliver, crypto_aead/joltikneq9696v1

Computer: sliver
Architecture: amd64
CPU ID: GenuineIntel-00040651-bfebfbff
SUPERCOP version: 20160731
Operation: crypto_aead
Primitive: joltikneq9696v1
TimeImplementationCompilerBenchmark dateSUPERCOP version
17829252refgcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2016072420160718
18810786refclang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2016072420160718
32908860refgcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2016072420160718
36267156refgcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2016072420160718
64375920refgcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2016072420160718

Compiler output

Implementation: crypto_aead/joltikneq9696v1/vperm
Compiler: clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
joltik.c: In file included from joltik.c:25:
joltik.c: ./joltik-avx2.c.inc:224:5: warning: while loop has empty body [-Wempty-body]
joltik.c: set_block_number_in_tweak(tweak2, 4*i-3, 4*i-2, 4*i-1, 4*i);
joltik.c: ^
joltik.c: ./joltik-avx2.c.inc:154:13: note: expanded from macro 'set_block_number_in_tweak'
joltik.c: } while(0);
joltik.c: ^
joltik.c: ./joltik-avx2.c.inc:224:5: note: put the semicolon on a separate line to silence this warning
joltik.c: ./joltik-avx2.c.inc:154:13: note: expanded from macro 'set_block_number_in_tweak'
joltik.c: } while(0);
joltik.c: ^
joltik.c: ./joltik-avx2.c.inc:246:5: warning: while loop has empty body [-Wempty-body]
joltik.c: set_stage_in_tweak(tweak, MSB_AD_LAST, MSB_AD_LAST, MSB_AD_LAST, MSB_AD_LAST);
joltik.c: ^
joltik.c: ./joltik-avx2.c.inc:164:13: note: expanded from macro 'set_stage_in_tweak'
joltik.c: } while(0);
joltik.c: ^
joltik.c: ./joltik-avx2.c.inc:246:5: note: put the semicolon on a separate line to silence this warning
joltik.c: ./joltik-avx2.c.inc:164:13: note: expanded from macro 'set_stage_in_tweak'
joltik.c: } while(0);
joltik.c: ^
joltik.c: ./joltik-avx2.c.inc:247:5: warning: while loop has empty body [-Wempty-body]
joltik.c: set_block_number_in_tweak(tweak2, i, i, i, i); /* One more full block */
joltik.c: ^
joltik.c: ./joltik-avx2.c.inc:154:13: note: expanded from macro 'set_block_number_in_tweak'
joltik.c: ...

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments vperm

Compiler output

Implementation: crypto_aead/joltikneq9696v1/ref
Compiler: clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
try.c: /tmp/try-anything-794ed6.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: warning: random() may return deterministic values, is that what you want?
try.c: /tmp/try-anything-1df53d.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: warning: random() may return deterministic values, is that what you want?

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref

Compiler output

Implementation: crypto_aead/joltikneq9696v1/vperm
Compiler: gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv
joltik.c: joltik.c:29:3: error: #error "This implementation requires either SSSE3 or AVX2 instruction sets."

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

Compiler output

Implementation: crypto_aead/joltikneq9696v1/ref
Compiler: gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv
try.c: /tmp//ccIN2ABc.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: warning: random() may return deterministic values, is that what you want?
try.c: /tmp//cccTKG1G.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: warning: random() may return deterministic values, is that what you want?

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv ref

Compiler output

Implementation: crypto_aead/joltikneq9696v1/ref
Compiler: gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv
try.c: /tmp//ccITWwgV.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: warning: random() may return deterministic values, is that what you want?
try.c: /tmp//cc49MjvN.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: warning: random() may return deterministic values, is that what you want?

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv ref

Compiler output

Implementation: crypto_aead/joltikneq9696v1/ref
Compiler: gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv
try.c: /tmp//ccxULMnm.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: warning: random() may return deterministic values, is that what you want?
try.c: /tmp//ccsPOZUW.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: warning: random() may return deterministic values, is that what you want?

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv ref

Compiler output

Implementation: crypto_aead/joltikneq9696v1/ref
Compiler: gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv
try.c: /tmp//cc0rmYDw.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: warning: random() may return deterministic values, is that what you want?
try.c: /tmp//cciIZh3B.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: warning: random() may return deterministic values, is that what you want?

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv ref