Implementation notes: aarch64, supercoplxc, crypto_aead/silverv1

Computer: supercoplxc
Architecture: aarch64
CPU ID: 410fd034
SUPERCOP version: 20190816
Operation: crypto_aead
Primitive: silverv1
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
17104024844 0 041737 920 880littleendoptnotaesnigcc_-O3_-fomit-frame-pointer2019092420190816
17192027212 0 045449 920 880littleendoptnotaesnigcc_-funroll-loops_-O3_-fomit-frame-pointer2019092420190816
17632026216 0 043888 912 864littleendoptnotaesnigcc_-funroll-loops_-O2_-fomit-frame-pointer2019092420190816
17952022708 0 038344 912 864littleendoptnotaesnigcc_-O2_-fomit-frame-pointer2019092420190816
18904026448 0 044264 912 864littleendoptnotaesnigcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019092420190816
19216022532 0 037208 896 856littleendoptnotaesnigcc_-funroll-loops_-Os_-fomit-frame-pointer2019092420190816
19224022532 0 037208 896 856littleendoptnotaesnigcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019092420190816
19400027104 0 045377 920 880littleendoptnotaesnigcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019092420190816
19992024024 0 041566 800 888littleendoptnotaesniclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019092420190816
21128024028 0 041502 800 888littleendoptnotaesniclang_-O3_-fomit-frame-pointer_-Qunused-arguments2019092420190816
21160024028 0 041550 800 888littleendoptnotaesniclang_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2019092420190816
21256024028 0 041550 800 888littleendoptnotaesniclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019092420190816
21280024028 0 041550 800 888littleendoptnotaesniclang_-O3_-fwrapv_-mavx2_-fomit-frame-pointer_-Qunused-arguments2019092420190816
21688019212 0 036750 800 888anotherlittleendclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019092420190816
21864019672 0 036577 920 880anotherlittleendgcc_-O3_-fomit-frame-pointer2019092420190816
21904021496 0 039769 920 880anotherlittleendgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019092420190816
22064021452 0 039713 920 880anotherlittleendgcc_-funroll-loops_-O3_-fomit-frame-pointer2019092420190816
22096016880 0 031576 896 856anotherlittleendgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019092420190816
22152016880 0 031576 896 856anotherlittleendgcc_-funroll-loops_-Os_-fomit-frame-pointer2019092420190816
22520020408 0 038088 912 864anotherlittleendgcc_-funroll-loops_-O2_-fomit-frame-pointer2019092420190816
22576020732 0 038552 912 864anotherlittleendgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019092420190816
22864017304 0 032952 912 864anotherlittleendgcc_-O2_-fomit-frame-pointer2019092420190816
23528019108 0 036630 800 888anotherlittleendclang_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2019092420190816
23560019108 0 036630 800 888anotherlittleendclang_-O3_-fwrapv_-mavx2_-fomit-frame-pointer_-Qunused-arguments2019092420190816
23576019108 0 036582 800 888anotherlittleendclang_-O3_-fomit-frame-pointer_-Qunused-arguments2019092420190816
23632019108 0 036630 800 888anotherlittleendclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019092420190816
25680024784 0 041713 920 880littleendoptnotaesnigcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019092420190816
26640022732 0 038352 912 864littleendoptnotaesnigcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019092420190816
26992022472 0 037104 896 856littleendoptnotaesnigcc_-Os_-fomit-frame-pointer2019092420190816
26992022472 0 037104 896 856littleendoptnotaesnigcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2019092420190816
28536016872 0 031528 896 856anotherlittleendgcc_-Os_-fomit-frame-pointer2019092420190816
28552016872 0 031528 896 856anotherlittleendgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2019092420190816
28832019752 0 036705 920 880anotherlittleendgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019092420190816
29992017332 0 032968 912 864anotherlittleendgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019092420190816
37080027664 0 046648 912 864littleendoptnotaesnigcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019092420190816
37112027664 0 046648 912 864littleendoptnotaesnigcc_-funroll-loops_-O_-fomit-frame-pointer2019092420190816
37368023128 0 038896 912 864littleendoptnotaesnigcc_-O_-fomit-frame-pointer2019092420190816
37416023128 0 038896 912 864littleendoptnotaesnigcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019092420190816
42296022024 0 041016 912 864anotherlittleendgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019092420190816
42312022024 0 041016 912 864anotherlittleendgcc_-funroll-loops_-O_-fomit-frame-pointer2019092420190816
43040017516 0 033296 912 864anotherlittleendgcc_-O_-fomit-frame-pointer2019092420190816
43040017516 0 033296 912 864anotherlittleendgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019092420190816
104312038676 0 060800 896 864littleendoptnotaesnigcc_-funroll-loops2019092420190816
104392038676 0 060800 896 864littleendoptnotaesnicc2019092420190816
104472038676 0 060800 896 864littleendoptnotaesnigcc2019092420190816
110720015544 0 032497 920 880refgcc_-O3_-fomit-frame-pointer2019092420190816
110808016204 0 034497 920 880refgcc_-funroll-loops_-O3_-fomit-frame-pointer2019092420190816
111232016124 0 034441 920 880refgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019092420190816
117736013764 0 031472 912 864refgcc_-funroll-loops_-O2_-fomit-frame-pointer2019092420190816
117864013952 0 031800 912 864refgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019092420190816
135184025512 0 047664 896 864anotherlittleendcc2019092420190816
135272025512 0 047664 896 864anotherlittleendgcc_-funroll-loops2019092420190816
135360025512 0 047664 896 864anotherlittleendgcc2019092420190816
139256014602 0 032118 800 888refclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019092420190816
142704015460 0 032441 920 880refgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019092420190816
149840014102 0 031558 800 888refclang_-O3_-fomit-frame-pointer_-Qunused-arguments2019092420190816
150952014574 0 032078 800 888refclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019092420190816
150960014574 0 032078 800 888refclang_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2019092420190816
151120014574 0 032078 800 888refclang_-O3_-fwrapv_-mavx2_-fomit-frame-pointer_-Qunused-arguments2019092420190816
18639208824 0 024496 912 864refgcc_-O2_-fomit-frame-pointer2019092420190816
191768014952 0 033968 912 864refgcc_-funroll-loops_-O_-fomit-frame-pointer2019092420190816
191784014952 0 033968 912 864refgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019092420190816
20106407838 0 022560 896 856refgcc_-funroll-loops_-Os_-fomit-frame-pointer2019092420190816
20164807838 0 022560 896 856refgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019092420190816
21176008812 0 024472 912 864refgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019092420190816
21913607722 0 022384 896 856refgcc_-Os_-fomit-frame-pointer2019092420190816
21918407722 0 022384 896 856refgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2019092420190816
23619208144 0 023944 912 864refgcc_-O_-fomit-frame-pointer2019092420190816
23644008144 0 023944 912 864refgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019092420190816
765856014760 0 036920 896 864refcc2019092420190816
771576014760 0 036920 896 864refgcc_-funroll-loops2019092420190816
787992014760 0 036920 896 864refgcc2019092420190816

Compiler output

Implementation: aesnioptimized
Security model: unknown
Compiler: cc
encrypt.c: In file included from encrypt.c:36:
encrypt.c: macs4AESNI.h:6:10: fatal error: wmmintrin.h: No such file or directory
encrypt.c: #include <wmmintrin.h>
encrypt.c: ^~~~~~~~~~~~~
encrypt.c: compilation terminated.

Number of similar (compiler,implementation) pairs: 19, namely:
CompilerImplementations
cc aesnioptimized
gcc aesnioptimized
gcc -O2 -fomit-frame-pointer aesnioptimized
gcc -O3 -fomit-frame-pointer aesnioptimized
gcc -O -fomit-frame-pointer aesnioptimized
gcc -Os -fomit-frame-pointer aesnioptimized
gcc -fno-schedule-insns -O2 -fomit-frame-pointer aesnioptimized
gcc -fno-schedule-insns -O3 -fomit-frame-pointer aesnioptimized
gcc -fno-schedule-insns -O -fomit-frame-pointer aesnioptimized
gcc -fno-schedule-insns -Os -fomit-frame-pointer aesnioptimized
gcc -funroll-loops aesnioptimized
gcc -funroll-loops -O2 -fomit-frame-pointer aesnioptimized
gcc -funroll-loops -O3 -fomit-frame-pointer aesnioptimized
gcc -funroll-loops -O -fomit-frame-pointer aesnioptimized
gcc -funroll-loops -Os -fomit-frame-pointer aesnioptimized
gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer aesnioptimized
gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer aesnioptimized
gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer aesnioptimized
gcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer aesnioptimized

Compiler output

Implementation: aesnioptimized
Security model: unknown
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
encrypt.c: In file included from encrypt.c:36:
encrypt.c: In file included from ./macs4AESNI.h:6:
encrypt.c: In file included from /usr/lib/llvm-7/lib/clang/7.0.1/include/wmmintrin.h:27:
encrypt.c: In file included from /usr/lib/llvm-7/lib/clang/7.0.1/include/emmintrin.h:27:
encrypt.c: In file included from /usr/lib/llvm-7/lib/clang/7.0.1/include/xmmintrin.h:27:
encrypt.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:64:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
encrypt.c: return (__m64)__builtin_ia32_vec_init_v2si(__i, 0);
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:143:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
encrypt.c: return (__m64)__builtin_ia32_packsswb((__v4hi)__m1, (__v4hi)__m2);
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:173:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
encrypt.c: return (__m64)__builtin_ia32_packssdw((__v2si)__m1, (__v2si)__m2);
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:203:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
encrypt.c: return (__m64)__builtin_ia32_packuswb((__v4hi)__m1, (__v4hi)__m2);
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:230:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
encrypt.c: return (__m64)__builtin_ia32_punpckhbw((__v8qi)__m1, (__v8qi)__m2);
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:253:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
encrypt.c: return (__m64)__builtin_ia32_punpckhwd((__v4hi)__m1, (__v4hi)__m2);
encrypt.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
encrypt.c: /usr/lib/llvm-7/lib/clang/7.0.1/include/mmintrin.h:274:12: error: invalid conversion between vector type '__m64' (vector of 1 'long long' value) and integer type 'int' of different size
encrypt.c: return (__m64)__builtin_ia32_punpckhdq((__v2si)__m1, (__v2si)__m2);
encrypt.c: ...

Number of similar (compiler,implementation) pairs: 5, namely:
CompilerImplementations
clang -O3 -fomit-frame-pointer -Qunused-arguments aesnioptimized
clang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments aesnioptimized
clang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments aesnioptimized
clang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments aesnioptimized
clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments aesnioptimized

Compiler output

Implementation: bigendoptimized
Security model: unknown
Compiler: cc
encrypt.c: encrypt.c:28:2: error: #error "This code produces standard results only on BE machines"
encrypt.c: #error "This code produces standard results only on BE machines"
encrypt.c: ^~~~~

Number of similar (compiler,implementation) pairs: 19, namely:
CompilerImplementations
cc bigendoptimized
gcc bigendoptimized
gcc -O2 -fomit-frame-pointer bigendoptimized
gcc -O3 -fomit-frame-pointer bigendoptimized
gcc -O -fomit-frame-pointer bigendoptimized
gcc -Os -fomit-frame-pointer bigendoptimized
gcc -fno-schedule-insns -O2 -fomit-frame-pointer bigendoptimized
gcc -fno-schedule-insns -O3 -fomit-frame-pointer bigendoptimized
gcc -fno-schedule-insns -O -fomit-frame-pointer bigendoptimized
gcc -fno-schedule-insns -Os -fomit-frame-pointer bigendoptimized
gcc -funroll-loops bigendoptimized
gcc -funroll-loops -O2 -fomit-frame-pointer bigendoptimized
gcc -funroll-loops -O3 -fomit-frame-pointer bigendoptimized
gcc -funroll-loops -O -fomit-frame-pointer bigendoptimized
gcc -funroll-loops -Os -fomit-frame-pointer bigendoptimized
gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer bigendoptimized
gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer bigendoptimized
gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer bigendoptimized
gcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer bigendoptimized

Compiler output

Implementation: bigendoptimized
Security model: unknown
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
encrypt.c: encrypt.c:28:2: error: "This code produces standard results only on BE machines"
encrypt.c: #error "This code produces standard results only on BE machines"
encrypt.c: ^
encrypt.c: 1 error generated.

Number of similar (compiler,implementation) pairs: 5, namely:
CompilerImplementations
clang -O3 -fomit-frame-pointer -Qunused-arguments bigendoptimized
clang -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments bigendoptimized
clang -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments bigendoptimized
clang -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments bigendoptimized
clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments bigendoptimized