Implementation notes: aarch64, supercoplxc, crypto_aead/aes128cpfbv1

Computer: supercoplxc
Architecture: aarch64
CPU ID: 410fd034
SUPERCOP version: 20190816
Operation: crypto_aead
Primitive: aes128cpfbv1
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
1659202608 0 020841 920 880refgcc_-O3_-fomit-frame-pointer2019090320190816
1659202616 0 022169 920 880refgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019090320190816
1663202616 0 020833 920 880refgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019090320190816
1665602608 0 022185 920 880refgcc_-funroll-loops_-O3_-fomit-frame-pointer2019090320190816
1761603956 0 023072 912 864refgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019090320190816
1762403884 0 022904 912 864refgcc_-funroll-loops_-O2_-fomit-frame-pointer2019090320190816
2085602348 0 021310 800 888refclang_-O3_-fwrapv_-mavx2_-fomit-frame-pointer_-Qunused-arguments2019090320190816
2085602348 0 021310 800 888refclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019090320190816
2087202348 0 021310 800 888refclang_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2019090320190816
2088802292 0 021270 800 888refclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019090320190816
2092002364 0 021278 800 888refclang_-O3_-fomit-frame-pointer_-Qunused-arguments2019090320190816
2467205108 0 025416 912 864refgcc_-funroll-loops_-O_-fomit-frame-pointer2019090320190816
2467205108 0 025416 912 864refgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019090320190816
25464016216 0 030904 920 856gladmangcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019090320190816
25488016216 0 030904 920 856gladmangcc_-funroll-loops_-Os_-fomit-frame-pointer2019090320190816
25672018188 0 036401 944 880gladmangcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019090320190816
26032016824 0 037833 944 880gladmangcc_-O3_-fomit-frame-pointer2019090320190816
26056018812 0 036568 936 864gladmangcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019090320190816
26432016560 0 034134 800 888gladmanclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019090320190816
26520016572 0 032184 936 864gladmangcc_-O2_-fomit-frame-pointer2019090320190816
26520018176 0 036425 944 880gladmangcc_-funroll-loops_-O3_-fomit-frame-pointer2019090320190816
26552017924 0 036097 920 880aesrefgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019090320190816
26920018472 0 036136 936 864gladmangcc_-funroll-loops_-O2_-fomit-frame-pointer2019090320190816
26968017904 0 036105 920 880aesrefgcc_-funroll-loops_-O3_-fomit-frame-pointer2019090320190816
26976017904 0 034761 920 880aesrefgcc_-O3_-fomit-frame-pointer2019090320190816
27944018716 0 036424 912 864aesrefgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019090320190816
28608018628 0 036240 912 864aesrefgcc_-funroll-loops_-O2_-fomit-frame-pointer2019090320190816
29912016436 0 033942 800 888gladmanclang_-O3_-fomit-frame-pointer_-Qunused-arguments2019090320190816
30008016468 0 034022 800 888gladmanclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019090320190816
30016016468 0 034022 800 888gladmanclang_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2019090320190816
30112016468 0 034022 800 888gladmanclang_-O3_-fwrapv_-mavx2_-fomit-frame-pointer_-Qunused-arguments2019090320190816
30424016252 0 033822 800 888aesrefclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019090320190816
30832015752 0 030416 896 856aesrefgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019090320190816
30872015752 0 030416 896 856aesrefgcc_-funroll-loops_-Os_-fomit-frame-pointer2019090320190816
31144015996 0 031576 912 864aesrefgcc_-O2_-fomit-frame-pointer2019090320190816
3153602104 0 019080 912 864refgcc_-O2_-fomit-frame-pointer2019090320190816
3188001896 0 017968 896 856refgcc_-funroll-loops_-Os_-fomit-frame-pointer2019090320190816
3188801896 0 017968 896 856refgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019090320190816
3190401896 0 017912 896 856refgcc_-Os_-fomit-frame-pointer2019090320190816
3190401896 0 017912 896 856refgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2019090320190816
3251202112 0 019032 912 864refgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019090320190816
32848016208 0 033710 800 888aesrefclang_-O3_-fomit-frame-pointer_-Qunused-arguments2019090320190816
32912016200 0 033758 800 888aesrefclang_-O3_-fwrapv_-mavx2_-fomit-frame-pointer_-Qunused-arguments2019090320190816
32912016200 0 033758 800 888aesrefclang_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2019090320190816
32920016200 0 033758 800 888aesrefclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019090320190816
3346402092 0 019184 912 864refgcc_-O_-fomit-frame-pointer2019090320190816
3347202092 0 019184 912 864refgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019090320190816
33664016216 0 030848 920 856gladmangcc_-Os_-fomit-frame-pointer2019090320190816
33664016216 0 030848 920 856gladmangcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2019090320190816
34752017928 0 034761 920 880aesrefgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019090320190816
37896016744 0 032296 936 864gladmangcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019090320190816
37952016848 0 037825 944 880gladmangcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019090320190816
38536015752 0 030352 896 856aesrefgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2019090320190816
38544015752 0 030352 896 856aesrefgcc_-Os_-fomit-frame-pointer2019090320190816
40120016052 0 031568 912 864aesrefgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019090320190816
51184019960 0 038896 936 864gladmangcc_-funroll-loops_-O_-fomit-frame-pointer2019090320190816
51184019960 0 038896 936 864gladmangcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019090320190816
51304017296 0 033000 936 864gladmangcc_-O_-fomit-frame-pointer2019090320190816
51312017296 0 033000 936 864gladmangcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019090320190816
52576019668 0 038552 912 864aesrefgcc_-funroll-loops_-O_-fomit-frame-pointer2019090320190816
52584019668 0 038552 912 864aesrefgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019090320190816
55744016204 0 031872 912 864aesrefgcc_-O_-fomit-frame-pointer2019090320190816
55792016204 0 031872 912 864aesrefgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019090320190816
9000003036 0 026568 896 864refgcc2019090320190816
9000003036 0 026568 896 864refgcc_-funroll-loops2019090320190816
9001603036 0 026568 896 864refcc2019090320190816
153544027692 0 049920 920 864gladmangcc2019090320190816
153744027692 0 049920 920 864gladmancc2019090320190816
154184027692 0 049920 920 864gladmangcc_-funroll-loops2019090320190816
172784022368 0 044528 896 864aesrefgcc2019090320190816
173144022368 0 044528 896 864aesrefcc2019090320190816
173344022368 0 044528 896 864aesrefgcc_-funroll-loops2019090320190816

Compiler output

Implementation: aesni
Security model: unknown
Compiler: cc
cpfbkey.c: cpfbkey.c:15:10: fatal error: wmmintrin.h: No such file or directory
cpfbkey.c: #include <wmmintrin.h>
cpfbkey.c: ^~~~~~~~~~~~~
cpfbkey.c: compilation terminated.

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

Compiler output

Implementation: aesni
Security model: unknown
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
cpfbkey.c: In file included from cpfbkey.c:15:
cpfbkey.c: In file included from /usr/lib/llvm-7/lib/clang/7.0.1/include/wmmintrin.h:27:
cpfbkey.c: In file included from /usr/lib/llvm-7/lib/clang/7.0.1/include/emmintrin.h:27:
cpfbkey.c: In file included from /usr/lib/llvm-7/lib/clang/7.0.1/include/xmmintrin.h:27:
cpfbkey.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
cpfbkey.c: return (__m64)__builtin_ia32_vec_init_v2si(__i, 0);
cpfbkey.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
cpfbkey.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
cpfbkey.c: return (__m64)__builtin_ia32_packsswb((__v4hi)__m1, (__v4hi)__m2);
cpfbkey.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
cpfbkey.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
cpfbkey.c: return (__m64)__builtin_ia32_packssdw((__v2si)__m1, (__v2si)__m2);
cpfbkey.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
cpfbkey.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
cpfbkey.c: return (__m64)__builtin_ia32_packuswb((__v4hi)__m1, (__v4hi)__m2);
cpfbkey.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
cpfbkey.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
cpfbkey.c: return (__m64)__builtin_ia32_punpckhbw((__v8qi)__m1, (__v8qi)__m2);
cpfbkey.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
cpfbkey.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
cpfbkey.c: return (__m64)__builtin_ia32_punpckhwd((__v4hi)__m1, (__v4hi)__m2);
cpfbkey.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
cpfbkey.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
cpfbkey.c: return (__m64)__builtin_ia32_punpckhdq((__v2si)__m1, (__v2si)__m2);
cpfbkey.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
cpfbkey.c: ...

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

Compiler output

Implementation: evp
Security model: unknown
Compiler: cc
encrypt.c: encrypt.c:170:82: error: array type has incomplete element type 'EVP_CIPHER_CTX' {aka 'struct evp_cipher_ctx_st'}
encrypt.c: static void gen_kappa(unsigned char* nonce, unsigned char* kappa, EVP_CIPHER_CTX ctx_key[1]){
encrypt.c: ^~~~~~~
encrypt.c: encrypt.c: In function 'crypto_aead_aes128cpfbv1_evp_encrypt':
encrypt.c: encrypt.c:188:20: error: array type has incomplete element type 'EVP_CIPHER_CTX' {aka 'struct evp_cipher_ctx_st'}
encrypt.c: EVP_CIPHER_CTX ctx_k[1];
encrypt.c: ^~~~~
encrypt.c: encrypt.c:189:20: error: array type has incomplete element type 'EVP_CIPHER_CTX' {aka 'struct evp_cipher_ctx_st'}
encrypt.c: EVP_CIPHER_CTX ctx_kappa_0[1];
encrypt.c: ^~~~~~~~~~~
encrypt.c: encrypt.c:190:20: error: array type has incomplete element type 'EVP_CIPHER_CTX' {aka 'struct evp_cipher_ctx_st'}
encrypt.c: EVP_CIPHER_CTX ctx_kappa_m[1];
encrypt.c: ^~~~~~~~~~~
encrypt.c: encrypt.c:204:31: error: type of formal parameter 3 is incomplete
encrypt.c: gen_kappa(nonce, kappa_0, ctx_k);
encrypt.c: ^~~~~
encrypt.c: encrypt.c:265:28: error: type of formal parameter 3 is incomplete
encrypt.c: gen_kappa(nonce, kappa_m, ctx_k);
encrypt.c: ^~~~~
encrypt.c: encrypt.c: In function 'crypto_aead_aes128cpfbv1_evp_decrypt':
encrypt.c: encrypt.c:330:20: error: array type has incomplete element type 'EVP_CIPHER_CTX' {aka 'struct evp_cipher_ctx_st'}
encrypt.c: EVP_CIPHER_CTX ctx_k[1];
encrypt.c: ^~~~~
encrypt.c: encrypt.c:331:20: error: array type has incomplete element type 'EVP_CIPHER_CTX' {aka 'struct evp_cipher_ctx_st'}
encrypt.c: EVP_CIPHER_CTX ctx_kappa_0[1];
encrypt.c: ...

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

Compiler output

Implementation: evp
Security model: unknown
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
encrypt.c: encrypt.c:170:89: error: array has incomplete element type 'EVP_CIPHER_CTX' (aka 'struct evp_cipher_ctx_st')
encrypt.c: static void gen_kappa(unsigned char* nonce, unsigned char* kappa, EVP_CIPHER_CTX ctx_key[1]){
encrypt.c: ^
encrypt.c: /usr/include/openssl/ossl_typ.h:90:16: note: forward declaration of 'struct evp_cipher_ctx_st'
encrypt.c: typedef struct evp_cipher_ctx_st EVP_CIPHER_CTX;
encrypt.c: ^
encrypt.c: encrypt.c:188:25: error: array has incomplete element type 'EVP_CIPHER_CTX' (aka 'struct evp_cipher_ctx_st')
encrypt.c: EVP_CIPHER_CTX ctx_k[1];
encrypt.c: ^
encrypt.c: /usr/include/openssl/ossl_typ.h:90:16: note: forward declaration of 'struct evp_cipher_ctx_st'
encrypt.c: typedef struct evp_cipher_ctx_st EVP_CIPHER_CTX;
encrypt.c: ^
encrypt.c: encrypt.c:189:31: error: array has incomplete element type 'EVP_CIPHER_CTX' (aka 'struct evp_cipher_ctx_st')
encrypt.c: EVP_CIPHER_CTX ctx_kappa_0[1];
encrypt.c: ^
encrypt.c: /usr/include/openssl/ossl_typ.h:90:16: note: forward declaration of 'struct evp_cipher_ctx_st'
encrypt.c: typedef struct evp_cipher_ctx_st EVP_CIPHER_CTX;
encrypt.c: ^
encrypt.c: encrypt.c:190:31: error: array has incomplete element type 'EVP_CIPHER_CTX' (aka 'struct evp_cipher_ctx_st')
encrypt.c: EVP_CIPHER_CTX ctx_kappa_m[1];
encrypt.c: ^
encrypt.c: /usr/include/openssl/ossl_typ.h:90:16: note: forward declaration of 'struct evp_cipher_ctx_st'
encrypt.c: typedef struct evp_cipher_ctx_st EVP_CIPHER_CTX;
encrypt.c: ^
encrypt.c: encrypt.c:330:25: error: array has incomplete element type 'EVP_CIPHER_CTX' (aka 'struct evp_cipher_ctx_st')
encrypt.c: ...

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