Implementation notes: amd64, bigmem, crypto_aead/aegis128

Computer: bigmem
Architecture: amd64
CPU ID: GenuineIntel-000206e6-bfebfbff
SUPERCOP version: 20141124
Operation: crypto_aead
Primitive: aegis128
TimeImplementationCompilerBenchmark dateSUPERCOP version
77576refgcc -Os -fomit-frame-pointer2015021520141124
77588refgcc -m64 -march=k8 -Os -fomit-frame-pointer2015021520141124
77636refgcc -funroll-loops -Os -fomit-frame-pointer2015021520141124
77645refgcc -m64 -Os -fomit-frame-pointer2015021520141124
77645refgcc -march=k8 -Os -fomit-frame-pointer2015021520141124
77650refgcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer2015021520141124
77676refgcc -fno-schedule-insns -Os -fomit-frame-pointer2015021520141124
77713refgcc -funroll-loops -march=k8 -Os -fomit-frame-pointer2015021520141124
77727refgcc -funroll-loops -m64 -Os -fomit-frame-pointer2015021520141124
77735refgcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2015021520141124
77823refgcc -m64 -march=core2 -Os -fomit-frame-pointer2015021520141124
77823refgcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer2015021520141124
77823refgcc -march=nocona -Os -fomit-frame-pointer2015021520141124
77826refgcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer2015021520141124
77829refgcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer2015021520141124
77831refgcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2015021520141124
77874refgcc -march=barcelona -Os -fomit-frame-pointer2015021520141124
77888refgcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer2015021520141124
77891refgcc -m64 -march=barcelona -Os -fomit-frame-pointer2015021520141124
77905refgcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer2015021520141124
77908refgcc -m64 -march=nocona -Os -fomit-frame-pointer2015021520141124
77954refgcc -funroll-loops -march=nocona -Os -fomit-frame-pointer2015021520141124
79404refgcc -funroll-loops -march=barcelona -O -fomit-frame-pointer2015021520141124
79404refgcc -m64 -march=core2 -O -fomit-frame-pointer2015021520141124
79410refgcc -funroll-loops -O -fomit-frame-pointer2015021520141124
79412refgcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer2015021520141124
79430refgcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer2015021520141124
79450refgcc -funroll-loops -m64 -O -fomit-frame-pointer2015021520141124
79452refgcc -funroll-loops -march=nocona -O -fomit-frame-pointer2015021520141124
79455refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2015021520141124
79458refgcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer2015021520141124
79458refgcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2015021520141124
79475refgcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer2015021520141124
79492refgcc -funroll-loops -march=k8 -O -fomit-frame-pointer2015021520141124
79495refgcc -O -fomit-frame-pointer2015021520141124
79509refgcc -m64 -march=nocona -O -fomit-frame-pointer2015021520141124
79546refgcc -march=nocona -O -fomit-frame-pointer2015021520141124
79557refgcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer2015021520141124
79568refgcc -m64 -O -fomit-frame-pointer2015021520141124
79580refgcc -m64 -march=k8 -O -fomit-frame-pointer2015021520141124
79597refgcc -march=k8 -O -fomit-frame-pointer2015021520141124
79611refgcc -m64 -march=barcelona -O -fomit-frame-pointer2015021520141124
79614refgcc -fno-schedule-insns -O -fomit-frame-pointer2015021520141124
79688refgcc -march=barcelona -O -fomit-frame-pointer2015021520141124
79874refgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2015021520141124
79894refgcc -funroll-loops -O3 -fomit-frame-pointer2015021520141124
80005refgcc -funroll-loops -m64 -O3 -fomit-frame-pointer2015021520141124
80435refgcc -funroll-loops -O2 -fomit-frame-pointer2015021520141124
80455refgcc -funroll-loops -m64 -O2 -fomit-frame-pointer2015021520141124
80529refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2015021520141124
80679refgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer2015021520141124
80719refgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer2015021520141124
80744refgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer2015021520141124
80781refgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer2015021520141124
80821refgcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer2015021520141124
80835refgcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer2015021520141124
80855refgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer2015021520141124
80920refgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer2015021520141124
81127refgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2015021520141124
81150refgcc -m64 -march=core2 -O2 -fomit-frame-pointer2015021520141124
81158refgcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer2015021520141124
81240refgcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2015021520141124
81328refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2015021520141124
81351refgcc -m64 -march=core2 -O3 -fomit-frame-pointer2015021520141124
81370refgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer2015021520141124
81371refgcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer2015021520141124
81413refgcc -m64 -march=nocona -O2 -fomit-frame-pointer2015021520141124
81532refgcc -march=nocona -O3 -fomit-frame-pointer2015021520141124
81549refgcc -m64 -march=nocona -O3 -fomit-frame-pointer2015021520141124
81580refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer2015021520141124
81583refgcc -march=nocona -O2 -fomit-frame-pointer2015021520141124
81645refgcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer2015021520141124
81679refgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer2015021520141124
81688refgcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer2015021520141124
81790refgcc -O3 -fomit-frame-pointer2015021520141124
81812refgcc -m64 -O3 -fomit-frame-pointer2015021520141124
81827refgcc -fno-schedule-insns -O3 -fomit-frame-pointer2015021520141124
82067refgcc -O2 -fomit-frame-pointer2015021520141124
82085refgcc -fno-schedule-insns -O2 -fomit-frame-pointer2015021520141124
82090refgcc -m64 -O2 -fomit-frame-pointer2015021520141124
82175refgcc -march=barcelona -O3 -fomit-frame-pointer2015021520141124
82274refgcc -m64 -march=barcelona -O3 -fomit-frame-pointer2015021520141124
82334refgcc -march=k8 -O3 -fomit-frame-pointer2015021520141124
82339refgcc -m64 -march=barcelona -O2 -fomit-frame-pointer2015021520141124
82339refgcc -m64 -march=k8 -O3 -fomit-frame-pointer2015021520141124
82373refgcc -m64 -march=k8 -O2 -fomit-frame-pointer2015021520141124
82405refgcc -march=barcelona -O2 -fomit-frame-pointer2015021520141124
82419refgcc -march=k8 -O2 -fomit-frame-pointer2015021520141124
160712refgcc2015021520141124
160888refcc2015021520141124
160893refgcc -funroll-loops2015021520141124

Compiler output

Implementation: crypto_aead/aegis128/aesni
Compiler: cc
encrypt.c: In file included from encrypt.c:5:
encrypt.c: /usr/lib/gcc/x86_64-linux-gnu/4.4.3/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: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:35: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:36: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:37: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:38: 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: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:68: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:69: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:70: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:71: 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: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:105: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:106: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:107: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:108: 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: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:131: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:132: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:133: 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:
encrypt.c: /usr/lib/gcc/x86_64-linux-gnu/4.4.3/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: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:35: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:36: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:37: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:38: 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: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:68: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:69: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:70: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:71: 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: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:105: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:106: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:107: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:108: 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: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:131: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:132: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:133: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: ...
encrypt.c: In file included from encrypt.c:5:
encrypt.c: /usr/lib/gcc/x86_64-linux-gnu/4.4.3/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: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:35: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:36: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:37: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:38: 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: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:68: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:69: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:70: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:71: 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: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:105: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:106: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:107: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:108: 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: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:131: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:132: error: incompatible types when assigning to type '__m128i' from type 'int'
encrypt.c: encrypt.c:133: 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