Implementation notes: amd64, sand, crypto_hash/keccakc512treed2

Computer: sand
Architecture: amd64
CPU ID: GenuineIntel-000506e3-bfebfbff
SUPERCOP version: 20171218
Operation: crypto_hash
Primitive: keccakc512treed2
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
15260? ? ?? ? ?sseu4clang_-march=native_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2018041420171218
15280? ? ?? ? ?sseu4clang_-O3_-fwrapv_-march=native_-fomit-frame-pointer_-Qunused-arguments2018041420171218
16184? ? ?? ? ?sseu24clang_-march=native_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2018041420171218
16198? ? ?? ? ?sseu24clang_-O3_-fwrapv_-march=native_-fomit-frame-pointer_-Qunused-arguments2018041420171218

Compiler output

Implementation: crypto_hash/keccakc512treed2/xopu24
Compiler: cc
DoublePermutation.c: DoublePermutation.c:507:5: error: '__builtin_ia32_vprotqi' needs target feature xop
DoublePermutation.c: rounds
DoublePermutation.c: ^
DoublePermutation.c: ./KeccakF-1600-unrolling.macros:17:5: note: expanded from macro 'rounds'
DoublePermutation.c: thetaRhoPiChiIotaPrepareTheta( 0, A, E) \
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:78:21: note: expanded from macro 'thetaRhoPiChiIotaPrepareTheta'
DoublePermutation.c: Da = XOR128(Cu, ROL64in128(Ce, 1)); \
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:33:37: note: expanded from macro 'ROL64in128'
DoublePermutation.c: #define ROL64in128(a, o) _mm_roti_epi64(a, o)
DoublePermutation.c: ^
DoublePermutation.c: /usr/lib/clang/5.0.1/include/xopintrin.h:250:12: note: expanded from macro '_mm_roti_epi64'
DoublePermutation.c: (__m128i)__builtin_ia32_vprotqi((__v2di)(__m128i)(A), (N)); })
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:507:5: error: '__builtin_ia32_vprotqi' needs target feature xop
DoublePermutation.c: ./KeccakF-1600-unrolling.macros:17:5: note: expanded from macro 'rounds'
DoublePermutation.c: thetaRhoPiChiIotaPrepareTheta( 0, A, E) \
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:79:21: note: expanded from macro 'thetaRhoPiChiIotaPrepareTheta'
DoublePermutation.c: De = XOR128(Ca, ROL64in128(Ci, 1)); \
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:33:37: note: expanded from macro 'ROL64in128'
DoublePermutation.c: #define ROL64in128(a, o) _mm_roti_epi64(a, o)
DoublePermutation.c: ^
DoublePermutation.c: ...

Number of similar (compiler,implementation) pairs: 7, namely:
CompilerImplementations
cc xopu24
clang -O3 -fomit-frame-pointer -Qunused-arguments xopu24
clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments xopu24
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments xopu24
clang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments xopu24
clang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments xopu24
clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments xopu24

Compiler output

Implementation: crypto_hash/keccakc512treed2/sseu24
Compiler: cc
DoublePermutation.c: DoublePermutation.c:507:5: error: always_inline function '_mm_shuffle_epi8' requires target feature 'ssse3', but would be inlined into function 'KeccakDoublePermutationOnWords' that is compiled without support for 'ssse3'
DoublePermutation.c: rounds
DoublePermutation.c: ^
DoublePermutation.c: ./KeccakF-1600-unrolling.macros:17:5: note: expanded from macro 'rounds'
DoublePermutation.c: thetaRhoPiChiIotaPrepareTheta( 0, A, E) \
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:136:11: note: expanded from macro 'thetaRhoPiChiIotaPrepareTheta'
DoublePermutation.c: Bko = ROL64in128_8(A##mu); \
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:38:37: note: expanded from macro 'ROL64in128_8'
DoublePermutation.c: #define ROL64in128_8(a) _mm_shuffle_epi8(a, CONST128(rho8))
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:507:5: error: always_inline function '_mm_shuffle_epi8' requires target feature 'ssse3', but would be inlined into function 'KeccakDoublePermutationOnWords' that is compiled without support for 'ssse3'
DoublePermutation.c: ./KeccakF-1600-unrolling.macros:17:5: note: expanded from macro 'rounds'
DoublePermutation.c: thetaRhoPiChiIotaPrepareTheta( 0, A, E) \
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:161:11: note: expanded from macro 'thetaRhoPiChiIotaPrepareTheta'
DoublePermutation.c: Bmu = ROL64in128_56(A##so); \
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:39:37: note: expanded from macro 'ROL64in128_56'
DoublePermutation.c: #define ROL64in128_56(a) _mm_shuffle_epi8(a, CONST128(rho56))
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:507:5: error: always_inline function '_mm_shuffle_epi8' requires target feature 'ssse3', but would be inlined into function 'KeccakDoublePermutationOnWords' that is compiled without support for 'ssse3'
DoublePermutation.c: ./KeccakF-1600-unrolling.macros:18:5: note: expanded from macro 'rounds'
DoublePermutation.c: thetaRhoPiChiIotaPrepareTheta( 1, E, A) \
DoublePermutation.c: ...

Number of similar (compiler,implementation) pairs: 5, namely:
CompilerImplementations
cc sseu24
clang -O3 -fomit-frame-pointer -Qunused-arguments sseu24
clang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments sseu24
clang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments sseu24
clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments sseu24

Compiler output

Implementation: crypto_hash/keccakc512treed2/sseu4
Compiler: cc
DoublePermutation.c: DoublePermutation.c:507:5: error: always_inline function '_mm_shuffle_epi8' requires target feature 'ssse3', but would be inlined into function 'KeccakDoublePermutationOnWords' that is compiled without support for 'ssse3'
DoublePermutation.c: rounds
DoublePermutation.c: ^
DoublePermutation.c: ./KeccakF-1600-unrolling.macros:90:9: note: expanded from macro 'rounds'
DoublePermutation.c: thetaRhoPiChiIotaPrepareTheta(i , A, E) \
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:136:11: note: expanded from macro 'thetaRhoPiChiIotaPrepareTheta'
DoublePermutation.c: Bko = ROL64in128_8(A##mu); \
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:38:37: note: expanded from macro 'ROL64in128_8'
DoublePermutation.c: #define ROL64in128_8(a) _mm_shuffle_epi8(a, CONST128(rho8))
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:507:5: error: always_inline function '_mm_shuffle_epi8' requires target feature 'ssse3', but would be inlined into function 'KeccakDoublePermutationOnWords' that is compiled without support for 'ssse3'
DoublePermutation.c: ./KeccakF-1600-unrolling.macros:90:9: note: expanded from macro 'rounds'
DoublePermutation.c: thetaRhoPiChiIotaPrepareTheta(i , A, E) \
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:161:11: note: expanded from macro 'thetaRhoPiChiIotaPrepareTheta'
DoublePermutation.c: Bmu = ROL64in128_56(A##so); \
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:39:37: note: expanded from macro 'ROL64in128_56'
DoublePermutation.c: #define ROL64in128_56(a) _mm_shuffle_epi8(a, CONST128(rho56))
DoublePermutation.c: ^
DoublePermutation.c: DoublePermutation.c:507:5: error: always_inline function '_mm_shuffle_epi8' requires target feature 'ssse3', but would be inlined into function 'KeccakDoublePermutationOnWords' that is compiled without support for 'ssse3'
DoublePermutation.c: ./KeccakF-1600-unrolling.macros:91:9: note: expanded from macro 'rounds'
DoublePermutation.c: thetaRhoPiChiIotaPrepareTheta(i+1, E, A) \
DoublePermutation.c: ...

Number of similar (compiler,implementation) pairs: 5, namely:
CompilerImplementations
cc sseu4
clang -O3 -fomit-frame-pointer -Qunused-arguments sseu4
clang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments sseu4
clang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments sseu4
clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments sseu4

Compiler output

Implementation: crypto_hash/keccakc512treed2/sseu24
Compiler: clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
try.c: /tmp/try-anything-adeea9.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: random() may return deterministic values, is that what you want?
try.c: /tmp/try-anything-58d2a9.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: random() may return deterministic values, is that what you want?

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

Compiler output

Implementation: crypto_hash/keccakc512treed2/sseu4
Compiler: clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
try.c: /tmp/try-anything-ee0b42.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: random() may return deterministic values, is that what you want?
try.c: /tmp/try-anything-e93aa8.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: random() may return deterministic values, is that what you want?

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

Compiler output

Implementation: crypto_hash/keccakc512treed2/sseu4
Compiler: clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
try.c: /tmp/try-anything-03bf82.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: random() may return deterministic values, is that what you want?
try.c: /tmp/try-anything-ecc157.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): 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 sseu4

Compiler output

Implementation: crypto_hash/keccakc512treed2/sseu24
Compiler: clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
try.c: /tmp/try-anything-7b4742.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): warning: random() may return deterministic values, is that what you want?
try.c: /tmp/try-anything-a4abf4.o: In function `alignedcalloc':
try.c: try-anything.c:(.text+0x...): 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 sseu24

Compiler output

Implementation: crypto_hash/keccakc512treed2/sseu24
Compiler: gcc
DoublePermutation.c: DoublePermutation.c:17:23: error: x86intrin.h: No such file or directory
DoublePermutation.c: In file included from DoublePermutation.c:18:
DoublePermutation.c: DoublePermutation.h:18: error: expected '=', ',', ';', 'asm' or '__attribute__' before 'V128'
DoublePermutation.c: DoublePermutation.h:20: error: expected ')' before '*' token
DoublePermutation.c: DoublePermutation.h:21: error: expected ')' before '*' token
DoublePermutation.c: DoublePermutation.h:22: error: expected ')' before '*' token
DoublePermutation.c: DoublePermutation.h:23: error: expected ')' before '*' token
DoublePermutation.c: DoublePermutation.h:24: error: expected ')' before '*' token
DoublePermutation.c: DoublePermutation.h:25: error: expected ')' before '*' token
DoublePermutation.c: DoublePermutation.c:499: error: expected ')' before '*' token
DoublePermutation.c: DoublePermutation.c:513: error: expected ')' before '*' token
DoublePermutation.c: DoublePermutation.c:527: error: expected ')' before '*' token
DoublePermutation.c: DoublePermutation.c:541: error: expected ')' before '*' token
DoublePermutation.c: DoublePermutation.c:555: error: expected ')' before '*' token
DoublePermutation.c: DoublePermutation.c:569: error: expected ')' before '*' token

Number of similar (compiler,implementation) pairs: 198, namely:
CompilerImplementations
gcc sseu24 sseu4 xopu24
gcc -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -fno-schedule-insns -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -fno-schedule-insns -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -fno-schedule-insns -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -fno-schedule-insns -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops sseu24 sseu4 xopu24
gcc -funroll-loops -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -m64 -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -m64 -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -m64 -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -m64 -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -march=k8 -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -march=k8 -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -march=nocona -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -funroll-loops -march=nocona -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -march=k8 -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -march=k8 -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -march=k8 -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -march=k8 -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -march=native -mtune=native -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -march=nocona -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -march=nocona -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -march=nocona -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -m64 -march=nocona -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -march=k8 -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -march=k8 -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -march=k8 -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -march=k8 -Os -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv sseu24 sseu4 xopu24
gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv sseu24 sseu4 xopu24
gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv sseu24 sseu4 xopu24
gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv sseu24 sseu4 xopu24
gcc -march=nocona -O2 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -march=nocona -O3 -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -march=nocona -O -fomit-frame-pointer sseu24 sseu4 xopu24
gcc -march=nocona -Os -fomit-frame-pointer sseu24 sseu4 xopu24