Implementation notes: aarch64, supercoplxc, crypto_encrypt/r5nd1pke0d

Computer: supercoplxc
Architecture: aarch64
CPU ID: 410fd034
SUPERCOP version: 20190816
Operation: crypto_encrypt
Primitive: r5nd1pke0d
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
145896022168 0 055860 976 1608optclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019120520190816
145944022168 0 055860 976 1608avx2clang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019120520190816
147672021908 0 055700 976 1608optclang_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2019120520190816
147920021908 0 055700 976 1608avx2clang_-O3_-fwrapv_-mavx2_-fomit-frame-pointer_-Qunused-arguments2019120520190816
148856021908 0 055700 976 1608optclang_-O3_-fwrapv_-mavx2_-fomit-frame-pointer_-Qunused-arguments2019120520190816
148872021908 0 055700 976 1608optclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019120520190816
149032021908 0 055700 976 1608avx2clang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019120520190816
149408021908 0 055700 976 1608avx2clang_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2019120520190816
149880021908 0 055652 976 1608avx2clang_-O3_-fomit-frame-pointer_-Qunused-arguments2019120520190816
150400021908 0 055652 976 1608optclang_-O3_-fomit-frame-pointer_-Qunused-arguments2019120520190816
157632034240 0 066221 1088 1592optgcc_-funroll-loops_-O3_-fomit-frame-pointer2019120520190816
158128033624 0 065997 1088 1592optgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019120520190816
158464033624 0 065997 1088 1592avx2gcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019120520190816
158736034240 0 066221 1088 1592avx2gcc_-funroll-loops_-O3_-fomit-frame-pointer2019120520190816
161848025504 0 058877 1088 1592optgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019120520190816
163440025752 0 058933 1088 1592avx2gcc_-O3_-fomit-frame-pointer2019120520190816
164264025752 0 058933 1088 1592optgcc_-O3_-fomit-frame-pointer2019120520190816
165960025504 0 058877 1088 1592avx2gcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019120520190816
292432029512 0 061221 1088 1576optgcc_-funroll-loops_-O2_-fomit-frame-pointer2019120520190816
293184029204 0 061285 1088 1576avx2gcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019120520190816
293544029204 0 061285 1088 1576optgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019120520190816
309232029512 0 061221 1088 1576avx2gcc_-funroll-loops_-O2_-fomit-frame-pointer2019120520190816
395552030288 0 062949 1088 1576avx2gcc_-funroll-loops_-O_-fomit-frame-pointer2019120520190816
398888030288 0 062949 1088 1576avx2gcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019120520190816
401448030288 0 062949 1088 1576optgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019120520190816
450968018076 0 053853 1088 1576optgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019120520190816
451256018076 0 053853 1088 1576avx2gcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019120520190816
452824018408 0 054061 1088 1576avx2gcc_-O_-fomit-frame-pointer2019120520190816
460376018028 0 053909 1088 1576avx2gcc_-O2_-fomit-frame-pointer2019120520190816
461872018408 0 054061 1088 1576optgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019120520190816
462496018028 0 053909 1088 1576optgcc_-O2_-fomit-frame-pointer2019120520190816
466640018408 0 054061 1088 1576avx2gcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019120520190816
467776018408 0 054061 1088 1576optgcc_-O_-fomit-frame-pointer2019120520190816
478888030288 0 062949 1088 1576optgcc_-funroll-loops_-O_-fomit-frame-pointer2019120520190816
538312016412 0 056427 1072 1568optgcc_-Os_-fomit-frame-pointer2019120520190816
538480016412 0 056427 1072 1568avx2gcc_-Os_-fomit-frame-pointer2019120520190816
538768016396 0 056459 1072 1568optgcc_-funroll-loops_-Os_-fomit-frame-pointer2019120520190816
538968016412 0 056427 1072 1568avx2gcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2019120520190816
540056016396 0 056459 1072 1568avx2gcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019120520190816
540224016412 0 056427 1072 1568optgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2019120520190816
540344016396 0 056459 1072 1568optgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019120520190816
540568016396 0 056459 1072 1568avx2gcc_-funroll-loops_-Os_-fomit-frame-pointer2019120520190816
2205312054809 652 49696094 1736 2096refgcc_-funroll-loops_-O3_-fomit-frame-pointer2019120520190816
2246928054561 652 49695974 1736 2096refgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2019120520190816
2251216041007 652 49681998 1736 2080refgcc_-funroll-loops_-O2_-fomit-frame-pointer2019120520190816
2447880034717 0 060917 1072 1584avx2gcc2019120520190816
2471136034717 0 060917 1072 1584optgcc2019120520190816
2473792034717 0 060917 1072 1584optcc2019120520190816
2481528034717 0 060917 1072 1584avx2gcc_-funroll-loops2019120520190816
2482320034717 0 060917 1072 1584optgcc_-funroll-loops2019120520190816
2486480034717 0 060917 1072 1584avx2cc2019120520190816
2519256040975 652 49682118 1736 2080refgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2019120520190816
3772904039445 652 49681382 1736 2096refgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2019120520190816
3776256031085 648 50073717 1592 2112refclang_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2019120520190816
3781296031501 648 50074053 1592 2112refclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2019120520190816
3788192026632 652 49671167 1776 2072refgcc_-Os_-fomit-frame-pointer2019120520190816
3805472026632 652 49671167 1776 2072refgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2019120520190816
3815416031009 648 50073589 1592 2112refclang_-O3_-fomit-frame-pointer_-Qunused-arguments2019120520190816
3816488031085 648 50073717 1592 2112refclang_-O3_-fwrapv_-mavx2_-fomit-frame-pointer_-Qunused-arguments2019120520190816
3817232039493 652 49681510 1736 2096refgcc_-O3_-fomit-frame-pointer2019120520190816
3822904031085 648 50073717 1592 2112refclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2019120520190816
3826920029295 652 49671238 1736 2080refgcc_-O2_-fomit-frame-pointer2019120520190816
3835512041535 652 49683894 1736 2080refgcc_-funroll-loops_-O_-fomit-frame-pointer2019120520190816
3851024029519 652 49671238 1736 2080refgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2019120520190816
3895568041535 652 49683894 1736 2080refgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2019120520190816
3998464030555 652 49672110 1736 2080refgcc_-O_-fomit-frame-pointer2019120520190816
4052528030555 652 49672110 1736 2080refgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2019120520190816
4269256026596 652 49671183 1776 2072refgcc_-funroll-loops_-Os_-fomit-frame-pointer2019120520190816
4278128026596 652 49671183 1776 2072refgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2019120520190816
17196672040000 652 49687425 1776 2080refcc2019120520190816
17467096040000 652 49687425 1776 2080refgcc_-funroll-loops2019120520190816
17513168040000 652 49687425 1776 2080refgcc2019120520190816

Compiler output

Implementation: avx2
Security model: unknown
Compiler: cc
a_fixed.c: In file included from a_fixed.h:13,
a_fixed.c: from a_fixed.c:10:
a_fixed.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
a_fixed.c: #warning AVX2 not supported by platform
a_fixed.c: ^~~~~~~
a_random.c: In file included from a_random.h:13,
a_random.c: from a_random.c:10:
a_random.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
a_random.c: #warning AVX2 not supported by platform
a_random.c: ^~~~~~~
cca_encrypt.c: In file included from cca_encrypt.h:14,
cca_encrypt.c: from cca_encrypt.c:12:
cca_encrypt.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
cca_encrypt.c: #warning AVX2 not supported by platform
cca_encrypt.c: ^~~~~~~
cpa_kem.c: In file included from cpa_kem.h:13,
cpa_kem.c: from cpa_kem.c:11:
cpa_kem.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
cpa_kem.c: #warning AVX2 not supported by platform
cpa_kem.c: ^~~~~~~
drbg.c: In file included from drbg.h:13,
drbg.c: from drbg.c:18:
drbg.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
drbg.c: #warning AVX2 not supported by platform
drbg.c: ^~~~~~~
matmul.c: In file included from matmul.h:8,
matmul.c: from matmul.c:8:
matmul.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
matmul.c: #warning AVX2 not supported by platform
matmul.c: ^~~~~~~
matmul_avx2.c: In file included from matmul.h:8,
matmul_avx2.c: from matmul_avx2.c:8:
matmul_avx2.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
matmul_avx2.c: #warning AVX2 not supported by platform
matmul_avx2.c: ^~~~~~~
matmul_cm.c: In file included from matmul.h:8,
matmul_cm.c: from matmul_cm.c:7:
matmul_cm.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
matmul_cm.c: #warning AVX2 not supported by platform
matmul_cm.c: ^~~~~~~
probe_cm.c: In file included from probe_cm.c:6:
probe_cm.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
probe_cm.c: #warning AVX2 not supported by platform
probe_cm.c: ^~~~~~~
r5_cca_kem.c: In file included from r5_cca_kem.c:7:
r5_cca_kem.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
r5_cca_kem.c: #warning AVX2 not supported by platform
r5_cca_kem.c: ^~~~~~~
r5_cca_pke.c: In file included from r5_cca_pke.c:12:
r5_cca_pke.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
r5_cca_pke.c: #warning AVX2 not supported by platform
r5_cca_pke.c: ^~~~~~~
r5_cpa_kem.c: In file included from r5_cpa_kem.c:9:
r5_cpa_kem.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
r5_cpa_kem.c: #warning AVX2 not supported by platform
r5_cpa_kem.c: ^~~~~~~
r5_cpa_pke_n1.c: In file included from r5_cpa_pke_n1.c:6:
r5_cpa_pke_n1.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
r5_cpa_pke_n1.c: #warning AVX2 not supported by platform
r5_cpa_pke_n1.c: ^~~~~~~
r5_cpa_pke_nd.c: In file included from r5_cpa_pke_nd.c:7:
r5_cpa_pke_nd.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
r5_cpa_pke_nd.c: #warning AVX2 not supported by platform
r5_cpa_pke_nd.c: ^~~~~~~
r5_dem.c: In file included from r5_dem.c:11:
r5_dem.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
r5_dem.c: #warning AVX2 not supported by platform
r5_dem.c: ^~~~~~~
ringmul.c: In file included from ringmul.h:9,
ringmul.c: from ringmul.c:8:
ringmul.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
ringmul.c: #warning AVX2 not supported by platform
ringmul.c: ^~~~~~~
ringmul_cm.c: In file included from ringmul.h:9,
ringmul_cm.c: from ringmul_cm.c:8:
ringmul_cm.c: r5_parameter_sets.h:140:2: warning: #warning AVX2 not supported by platform [-Wcpp]
ringmul_cm.c: #warning AVX2 not supported by platform
ringmul_cm.c: ^~~~~~~

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

Compiler output

Implementation: avx2
Security model: unknown
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
a_fixed.c: In file included from a_fixed.c:10:
a_fixed.c: In file included from ./a_fixed.h:13:
a_fixed.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
a_fixed.c: #warning AVX2 not supported by platform
a_fixed.c: ^
a_fixed.c: 1 warning generated.
a_random.c: In file included from a_random.c:10:
a_random.c: In file included from ./a_random.h:13:
a_random.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
a_random.c: #warning AVX2 not supported by platform
a_random.c: ^
a_random.c: 1 warning generated.
cca_encrypt.c: In file included from cca_encrypt.c:12:
cca_encrypt.c: In file included from ./cca_encrypt.h:14:
cca_encrypt.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
cca_encrypt.c: #warning AVX2 not supported by platform
cca_encrypt.c: ^
cca_encrypt.c: 1 warning generated.
cpa_kem.c: In file included from cpa_kem.c:11:
cpa_kem.c: In file included from ./cpa_kem.h:13:
cpa_kem.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
cpa_kem.c: #warning AVX2 not supported by platform
cpa_kem.c: ^
cpa_kem.c: 1 warning generated.
drbg.c: In file included from drbg.c:18:
drbg.c: In file included from ./drbg.h:13:
drbg.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
drbg.c: #warning AVX2 not supported by platform
drbg.c: ^
drbg.c: 1 warning generated.
matmul.c: In file included from matmul.c:8:
matmul.c: In file included from ./matmul.h:8:
matmul.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
matmul.c: #warning AVX2 not supported by platform
matmul.c: ^
matmul.c: 1 warning generated.
matmul_avx2.c: In file included from matmul_avx2.c:8:
matmul_avx2.c: In file included from ./matmul.h:8:
matmul_avx2.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
matmul_avx2.c: #warning AVX2 not supported by platform
matmul_avx2.c: ^
matmul_avx2.c: 1 warning generated.
matmul_cm.c: In file included from matmul_cm.c:7:
matmul_cm.c: In file included from ./matmul.h:8:
matmul_cm.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
matmul_cm.c: #warning AVX2 not supported by platform
matmul_cm.c: ^
matmul_cm.c: 1 warning generated.
probe_cm.c: In file included from probe_cm.c:6:
probe_cm.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
probe_cm.c: #warning AVX2 not supported by platform
probe_cm.c: ^
probe_cm.c: 1 warning generated.
r5_cca_kem.c: In file included from r5_cca_kem.c:7:
r5_cca_kem.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
r5_cca_kem.c: #warning AVX2 not supported by platform
r5_cca_kem.c: ^
r5_cca_kem.c: 1 warning generated.
r5_cca_pke.c: In file included from r5_cca_pke.c:12:
r5_cca_pke.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
r5_cca_pke.c: #warning AVX2 not supported by platform
r5_cca_pke.c: ^
r5_cca_pke.c: 1 warning generated.
r5_cpa_kem.c: In file included from r5_cpa_kem.c:9:
r5_cpa_kem.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
r5_cpa_kem.c: #warning AVX2 not supported by platform
r5_cpa_kem.c: ^
r5_cpa_kem.c: 1 warning generated.
r5_cpa_pke_n1.c: In file included from r5_cpa_pke_n1.c:6:
r5_cpa_pke_n1.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
r5_cpa_pke_n1.c: #warning AVX2 not supported by platform
r5_cpa_pke_n1.c: ^
r5_cpa_pke_n1.c: 1 warning generated.
r5_cpa_pke_nd.c: In file included from r5_cpa_pke_nd.c:7:
r5_cpa_pke_nd.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
r5_cpa_pke_nd.c: #warning AVX2 not supported by platform
r5_cpa_pke_nd.c: ^
r5_cpa_pke_nd.c: 1 warning generated.
r5_dem.c: In file included from r5_dem.c:11:
r5_dem.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
r5_dem.c: #warning AVX2 not supported by platform
r5_dem.c: ^
r5_dem.c: 1 warning generated.
ringmul.c: In file included from ringmul.c:8:
ringmul.c: In file included from ./ringmul.h:9:
ringmul.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
ringmul.c: #warning AVX2 not supported by platform
ringmul.c: ^
ringmul.c: 1 warning generated.
ringmul_cm.c: In file included from ringmul_cm.c:8:
ringmul_cm.c: In file included from ./ringmul.h:9:
ringmul_cm.c: ./r5_parameter_sets.h:140:2: warning: AVX2 not supported by platform [-W#warnings]
ringmul_cm.c: #warning AVX2 not supported by platform
ringmul_cm.c: ^
ringmul_cm.c: 1 warning generated.

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