Implementation notes: amd64, jos, crypto_aead/aegis128

Computer: jos
Architecture: amd64
CPU ID: GenuineIntel-00010676-bfebfbff
SUPERCOP version: 20141014
Operation: crypto_aead
Primitive: aegis128
TimeImplementationCompilerBenchmark dateSUPERCOP version
88245refgcc -funroll-loops -O -fomit-frame-pointer2014070420140622
88275refgcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer2014070420140622
88298refgcc -funroll-loops -m64 -O -fomit-frame-pointer2014070420140622
88343refgcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2014070420140622
88350refgcc -march=nocona -O -fomit-frame-pointer2014070420140622
88365refgcc -funroll-loops -march=nocona -O -fomit-frame-pointer2014070420140622
88432refgcc -fno-schedule-insns -O -fomit-frame-pointer2014070420140622
88433refgcc -m64 -march=core2 -O -fomit-frame-pointer2014070420140622
88447refgcc -O -fomit-frame-pointer2014070420140622
88448refgcc -m64 -march=barcelona -O -fomit-frame-pointer2014070420140622
88463refgcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer2014070420140622
88493refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2014070420140622
88507refgcc -m64 -O -fomit-frame-pointer2014070420140622
88507refgcc -m64 -march=nocona -O -fomit-frame-pointer2014070420140622
88530refgcc -funroll-loops -march=k8 -O -fomit-frame-pointer2014070420140622
88538refgcc -march=barcelona -O -fomit-frame-pointer2014070420140622
88590refgcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer2014070420140622
88680refgcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer2014070420140622
88710refgcc -funroll-loops -march=barcelona -O -fomit-frame-pointer2014070420140622
88837refgcc -march=k8 -O -fomit-frame-pointer2014070420140622
88838refgcc -m64 -march=k8 -O -fomit-frame-pointer2014070420140622
88883refgcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer2014070420140622
89985refgcc -march=nocona -Os -fomit-frame-pointer2014070420140622
90045refgcc -funroll-loops -march=nocona -Os -fomit-frame-pointer2014070420140622
90113refgcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer2014070420140622
90120refgcc -m64 -march=nocona -Os -fomit-frame-pointer2014070420140622
90165refgcc -m64 -march=core2 -Os -fomit-frame-pointer2014070420140622
90173refgcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2014070420140622
90203refgcc -funroll-loops -march=k8 -Os -fomit-frame-pointer2014070420140622
90210refgcc -funroll-loops -Os -fomit-frame-pointer2014070420140622
90210refgcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer2014070420140622
90210refgcc -march=barcelona -Os -fomit-frame-pointer2014070420140622
90232refgcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer2014070420140622
90247refgcc -fno-schedule-insns -Os -fomit-frame-pointer2014070420140622
90270refgcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2014070420140622
90270refgcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer2014070420140622
90293refgcc -Os -fomit-frame-pointer2014070420140622
90300refgcc -march=k8 -Os -fomit-frame-pointer2014070420140622
90315refgcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer2014070420140622
90360refgcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer2014070420140622
90382refgcc -funroll-loops -m64 -Os -fomit-frame-pointer2014070420140622
90458refgcc -m64 -Os -fomit-frame-pointer2014070420140622
90472refgcc -m64 -march=k8 -Os -fomit-frame-pointer2014070420140622
90555refgcc -m64 -march=barcelona -Os -fomit-frame-pointer2014070420140622
93300refgcc -funroll-loops -m64 -O3 -fomit-frame-pointer2014070420140622
93353refgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2014070420140622
93405refgcc -funroll-loops -O3 -fomit-frame-pointer2014070420140622
93450refgcc -funroll-loops -O2 -fomit-frame-pointer2014070420140622
93465refgcc -funroll-loops -m64 -O2 -fomit-frame-pointer2014070420140622
93548refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2014070420140622
93638refgcc -m64 -O3 -fomit-frame-pointer2014070420140622
93720refgcc -O3 -fomit-frame-pointer2014070420140622
93773refgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer2014070420140622
93810refgcc -fno-schedule-insns -O3 -fomit-frame-pointer2014070420140622
93810refgcc -m64 -march=core2 -O3 -fomit-frame-pointer2014070420140622
93840refgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer2014070420140622
93900refgcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer2014070420140622
93915refgcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer2014070420140622
93937refgcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer2014070420140622
93975refgcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer2014070420140622
93975refgcc -m64 -march=core2 -O2 -fomit-frame-pointer2014070420140622
93975refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2014070420140622
94005refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer2014070420140622
94027refgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2014070420140622
94058refgcc -m64 -march=nocona -O3 -fomit-frame-pointer2014070420140622
94072refgcc -O2 -fomit-frame-pointer2014070420140622
94080refgcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2014070420140622
94095refgcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer2014070420140622
94102refgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer2014070420140622
94140refgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer2014070420140622
94140refgcc -m64 -O2 -fomit-frame-pointer2014070420140622
94193refgcc -fno-schedule-insns -O2 -fomit-frame-pointer2014070420140622
94215refgcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer2014070420140622
94320refgcc -march=nocona -O3 -fomit-frame-pointer2014070420140622
94388refgcc -m64 -march=nocona -O2 -fomit-frame-pointer2014070420140622
94500refgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer2014070420140622
94530refgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer2014070420140622
94553refgcc -march=nocona -O2 -fomit-frame-pointer2014070420140622
94560refgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer2014070420140622
94613refgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer2014070420140622
94748refgcc -m64 -march=barcelona -O3 -fomit-frame-pointer2014070420140622
94755refgcc -march=barcelona -O3 -fomit-frame-pointer2014070420140622
94785refgcc -march=k8 -O3 -fomit-frame-pointer2014070420140622
94807refgcc -m64 -march=k8 -O3 -fomit-frame-pointer2014070420140622
94882refgcc -m64 -march=barcelona -O2 -fomit-frame-pointer2014070420140622
94897refgcc -march=barcelona -O2 -fomit-frame-pointer2014070420140622
94905refgcc -m64 -march=k8 -O2 -fomit-frame-pointer2014070420140622
94965refgcc -march=k8 -O2 -fomit-frame-pointer2014070420140622
189495refgcc2014070420140622
190110refcc2014070420140622
190687refgcc -funroll-loops2014070420140622

Compiler output

Implementation: crypto_aead/aegis128/aesni
Compiler: cc
encrypt.c: In file included from encrypt.c:5:0:
encrypt.c: /usr/lib64/gcc/x86_64-suse-linux/4.5/include/wmmintrin.h:34:3: error: #error "AES/PCLMUL instructions not enabled"
encrypt.c: encrypt.c: In function 'aegis128_initialization':
encrypt.c: encrypt.c:34:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:35:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:36:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:37:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:38:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c: In function 'aegis128_tag_generation':
encrypt.c: encrypt.c:67:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:68:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:69:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:70:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:71:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c: In function 'aegis128_enc_aut_step':
encrypt.c: encrypt.c:104:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:105:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:106:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:107:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:108:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c: In function 'aegis128_dec_aut_step':
encrypt.c: encrypt.c:130:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:131:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:132:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:133:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: ...

Number of similar (compiler,implementation) pairs: 87, 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
gcc -funroll-loops -m64 -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -O -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -Os -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer aesni
gcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer aesni
gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -march=barcelona -O -fomit-frame-pointer aesni
gcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer aesni
gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -march=k8 -O -fomit-frame-pointer aesni
gcc -funroll-loops -march=k8 -Os -fomit-frame-pointer aesni
gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer aesni
gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer aesni
gcc -funroll-loops -march=nocona -O -fomit-frame-pointer aesni
gcc -funroll-loops -march=nocona -Os -fomit-frame-pointer aesni
gcc -m64 -O2 -fomit-frame-pointer aesni
gcc -m64 -O3 -fomit-frame-pointer aesni
gcc -m64 -O -fomit-frame-pointer aesni
gcc -m64 -Os -fomit-frame-pointer aesni
gcc -m64 -march=core2 -O2 -fomit-frame-pointer aesni
gcc -m64 -march=core2 -O3 -fomit-frame-pointer aesni
gcc -m64 -march=core2 -O -fomit-frame-pointer aesni
gcc -m64 -march=core2 -Os -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer aesni
gcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer aesni
gcc -m64 -march=k8 -O2 -fomit-frame-pointer aesni
gcc -m64 -march=k8 -O3 -fomit-frame-pointer aesni
gcc -m64 -march=k8 -O -fomit-frame-pointer aesni
gcc -m64 -march=k8 -Os -fomit-frame-pointer aesni
gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer aesni
gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer aesni
gcc -m64 -march=native -mtune=native -O -fomit-frame-pointer aesni
gcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer aesni
gcc -m64 -march=nocona -O2 -fomit-frame-pointer aesni
gcc -m64 -march=nocona -O3 -fomit-frame-pointer aesni
gcc -m64 -march=nocona -O -fomit-frame-pointer aesni
gcc -m64 -march=nocona -Os -fomit-frame-pointer aesni
gcc -march=barcelona -O2 -fomit-frame-pointer aesni
gcc -march=barcelona -O3 -fomit-frame-pointer aesni
gcc -march=barcelona -O -fomit-frame-pointer aesni
gcc -march=barcelona -Os -fomit-frame-pointer aesni
gcc -march=k8 -O2 -fomit-frame-pointer aesni
gcc -march=k8 -O3 -fomit-frame-pointer aesni
gcc -march=k8 -O -fomit-frame-pointer aesni
gcc -march=k8 -Os -fomit-frame-pointer aesni
gcc -march=nocona -O2 -fomit-frame-pointer aesni
gcc -march=nocona -O3 -fomit-frame-pointer aesni
gcc -march=nocona -O -fomit-frame-pointer aesni
gcc -march=nocona -Os -fomit-frame-pointer aesni

Compiler output

Implementation: crypto_aead/aegis128/aesni
Compiler: gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
encrypt.c: In file included from encrypt.c:5:0:
encrypt.c: /usr/lib64/gcc/x86_64-suse-linux/4.5/include/wmmintrin.h:34:3: error: #error "AES/PCLMUL instructions not enabled"
encrypt.c: encrypt.c: In function 'aegis128_initialization':
encrypt.c: encrypt.c:34:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:35:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:36:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:37:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:38:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c: In function 'aegis128_tag_generation':
encrypt.c: encrypt.c:67:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:68:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:69:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:70:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:71:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c: In function 'aegis128_enc_aut_step':
encrypt.c: encrypt.c:104:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:105:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:106:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:107:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:108:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c: In function 'aegis128_dec_aut_step':
encrypt.c: encrypt.c:130:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:131:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:132:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:133:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: ...
encrypt.c: In file included from encrypt.c:5:0:
encrypt.c: /usr/lib64/gcc/x86_64-suse-linux/4.5/include/wmmintrin.h:34:3: error: #error "AES/PCLMUL instructions not enabled"
encrypt.c: encrypt.c: In function 'aegis128_initialization':
encrypt.c: encrypt.c:34:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:35:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:36:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:37:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:38:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c: In function 'aegis128_tag_generation':
encrypt.c: encrypt.c:67:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:68:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:69:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:70:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:71:23: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c: In function 'aegis128_enc_aut_step':
encrypt.c: encrypt.c:104:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:105:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:106:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:107:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:108:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c: In function 'aegis128_dec_aut_step':
encrypt.c: encrypt.c:130:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:131:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:132:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:133:18: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: ...

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
gcc -m64 -march=barcelona -O2 -fomit-frame-pointer aesni
gcc -m64 -march=barcelona -O3 -fomit-frame-pointer aesni
gcc -m64 -march=barcelona -O -fomit-frame-pointer aesni
gcc -m64 -march=barcelona -Os -fomit-frame-pointer aesni