Implementation notes: x86, hydra4, crypto_aead/paeq128t

Computer: hydra4
Architecture: x86
CPU ID: AuthenticAMD-00300f10-178bfbff
SUPERCOP version: 20141014
Operation: crypto_aead
Primitive: paeq128t
TimeImplementationCompilerBenchmark dateSUPERCOP version
5227641refg++ -m32 -O3 -fomit-frame-pointer2014101420141014
5305650refg++ -m32 -march=prescott -O3 -fomit-frame-pointer2014101420141014
5323200refg++ -m32 -march=nocona -O3 -fomit-frame-pointer2014101420141014
5381590refg++ -m32 -march=pentium4 -O3 -fomit-frame-pointer2014101420141014
5500435refg++ -m32 -march=k8 -O3 -fomit-frame-pointer2014101420141014
5503243refg++ -m32 -march=athlon -O3 -fomit-frame-pointer2014101420141014
5505572refg++ -m32 -march=native -mtune=native -O3 -fomit-frame-pointer2014101420141014
5506165refg++ -m32 -march=barcelona -O3 -fomit-frame-pointer2014101420141014
6051965refg++ -m32 -march=pentium-mmx -O3 -fomit-frame-pointer2014101420141014
6075041refg++ -m32 -march=pentium -O3 -fomit-frame-pointer2014101420141014
6166925refg++ -m32 -march=i386 -O3 -fomit-frame-pointer2014101420141014
6285552refg++ -m32 -march=k6-3 -O3 -fomit-frame-pointer2014101420141014
6303071refg++ -m32 -march=k6 -O3 -fomit-frame-pointer2014101420141014
6313823refg++ -m32 -march=k6-2 -O3 -fomit-frame-pointer2014101420141014
6417773refg++ -m32 -march=pentiumpro -O3 -fomit-frame-pointer2014101420141014
6423662refg++ -m32 -march=pentium2 -O3 -fomit-frame-pointer2014101420141014
6514205refg++ -m32 -march=pentium-m -O3 -fomit-frame-pointer2014101420141014
6572685refg++ -m32 -march=i486 -O3 -fomit-frame-pointer2014101420141014
6675849refg++ -m32 -march=pentium3 -O3 -fomit-frame-pointer2014101420141014
11861609refg++ -m32 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2014101420141014
11865107refg++ -m32 -march=core2 -msse4 -O2 -fomit-frame-pointer2014101420141014
11936866refg++ -m32 -march=corei7 -O2 -fomit-frame-pointer2014101420141014
11958051refg++ -m32 -march=core2 -O2 -fomit-frame-pointer2014101420141014
12078831refg++ -m32 -march=core-avx-i -O2 -fomit-frame-pointer2014101420141014
12091046refg++ -m32 -march=corei7-avx -O2 -fomit-frame-pointer2014101420141014
12096264refg++ -m32 -O2 -fomit-frame-pointer2014101420141014
12134561refg++ -m32 -march=native -mtune=native -O2 -fomit-frame-pointer2014101420141014
12196256refg++ -m32 -march=athlon -O2 -fomit-frame-pointer2014101420141014
12218540refg++ -m32 -march=barcelona -O2 -fomit-frame-pointer2014101420141014
12248434refg++ -m32 -march=prescott -O2 -fomit-frame-pointer2014101420141014
12274041refg++ -m32 -march=k8 -O2 -fomit-frame-pointer2014101420141014
12277937refg++ -m32 -march=pentium4 -O2 -fomit-frame-pointer2014101420141014
12379884refg++ -m32 -march=nocona -O2 -fomit-frame-pointer2014101420141014
12905073refg++ -m32 -march=corei7 -Os -fomit-frame-pointer2014101420141014
12932946refg++ -m32 -march=core2 -msse4.1 -Os -fomit-frame-pointer2014101420141014
12939521refg++ -m32 -march=core2 -msse4 -Os -fomit-frame-pointer2014101420141014
12940048refg++ -m32 -march=corei7-avx -Os -fomit-frame-pointer2014101420141014
12946834refg++ -m32 -march=core-avx-i -Os -fomit-frame-pointer2014101420141014
12951370refg++ -m32 -march=native -mtune=native -Os -fomit-frame-pointer2014101420141014
12958023refg++ -m32 -Os -fomit-frame-pointer2014101420141014
12959751refg++ -m32 -march=barcelona -Os -fomit-frame-pointer2014101420141014
12981918refg++ -m32 -march=k8 -Os -fomit-frame-pointer2014101420141014
13019807refg++ -m32 -march=core2 -Os -fomit-frame-pointer2014101420141014
13033975refg++ -m32 -march=athlon -Os -fomit-frame-pointer2014101420141014
13118832refg++ -m32 -march=pentium4 -Os -fomit-frame-pointer2014101420141014
13125333refg++ -m32 -march=prescott -Os -fomit-frame-pointer2014101420141014
13127326refg++ -m32 -march=nocona -Os -fomit-frame-pointer2014101420141014
14237040refg++ -m32 -march=pentium4 -O -fomit-frame-pointer2014101420141014
14288294refg++ -m32 -march=native -mtune=native -O -fomit-frame-pointer2014101420141014
14362140refg++ -m32 -march=prescott -O -fomit-frame-pointer2014101420141014
14374928refg++ -m32 -march=nocona -O -fomit-frame-pointer2014101420141014
14432691refg++ -m32 -march=core-avx-i -O -fomit-frame-pointer2014101420141014
14457694refg++ -m32 -march=core2 -O -fomit-frame-pointer2014101420141014
14466921refg++ -m32 -march=core2 -msse4.1 -O -fomit-frame-pointer2014101420141014
14485790refg++ -m32 -march=athlon -O -fomit-frame-pointer2014101420141014
14499385refg++ -m32 -march=k8 -O -fomit-frame-pointer2014101420141014
14645022refg++ -m32 -march=corei7 -O -fomit-frame-pointer2014101420141014
14657706refg++ -m32 -march=barcelona -O -fomit-frame-pointer2014101420141014
14698515refg++ -m32 -O -fomit-frame-pointer2014101420141014
14727274refg++ -m32 -march=core2 -msse4 -O -fomit-frame-pointer2014101420141014
14737807refg++ -m32 -march=corei7-avx -O -fomit-frame-pointer2014101420141014
19517476refg++ -m32 -march=i386 -O2 -fomit-frame-pointer2014101420141014
20631894refg++ -m32 -march=i486 -O2 -fomit-frame-pointer2014101420141014
20821086refg++ -m32 -march=pentium -O2 -fomit-frame-pointer2014101420141014
20971934refg++ -m32 -march=pentium-mmx -O2 -fomit-frame-pointer2014101420141014
21222978refg++ -m32 -march=pentium-m -O2 -fomit-frame-pointer2014101420141014
21236092refg++ -m32 -march=pentium3 -O2 -fomit-frame-pointer2014101420141014
21242247refg++ -m32 -march=pentiumpro -O2 -fomit-frame-pointer2014101420141014
21265027refg++ -m32 -march=pentium2 -O2 -fomit-frame-pointer2014101420141014
21367975refg++ -m32 -march=k6-2 -O2 -fomit-frame-pointer2014101420141014
21433328refg++ -m32 -march=k6 -O2 -fomit-frame-pointer2014101420141014
21462835refg++ -m32 -march=k6-3 -O2 -fomit-frame-pointer2014101420141014
21724400refg++ -m32 -march=i386 -O -fomit-frame-pointer2014101420141014
21804631refg++ -m32 -march=pentium-mmx -Os -fomit-frame-pointer2014101420141014
21830905refg++ -m32 -march=pentium -Os -fomit-frame-pointer2014101420141014
22515764refg++ -m32 -march=k6-3 -O -fomit-frame-pointer2014101420141014
22524130refg++ -m32 -march=pentium-mmx -O -fomit-frame-pointer2014101420141014
22543190refg++ -m32 -march=pentium -O -fomit-frame-pointer2014101420141014
22563017refg++ -m32 -march=pentium2 -Os -fomit-frame-pointer2014101420141014
22620581refg++ -m32 -march=pentium3 -Os -fomit-frame-pointer2014101420141014
22628041refg++ -m32 -march=pentiumpro -Os -fomit-frame-pointer2014101420141014
22648700refg++ -m32 -march=k6 -O -fomit-frame-pointer2014101420141014
22682474refg++ -m32 -march=pentium-m -Os -fomit-frame-pointer2014101420141014
22696448refg++ -m32 -march=pentium2 -O -fomit-frame-pointer2014101420141014
22721684refg++ -m32 -march=pentium3 -O -fomit-frame-pointer2014101420141014
22729875refg++ -m32 -march=pentium-m -O -fomit-frame-pointer2014101420141014
22732293refg++ -m32 -march=pentiumpro -O -fomit-frame-pointer2014101420141014
22836868refg++ -m32 -march=k6-2 -O -fomit-frame-pointer2014101420141014
23014122refg++ -m32 -march=i486 -Os -fomit-frame-pointer2014101420141014
23292661refg++ -m32 -march=i386 -Os -fomit-frame-pointer2014101420141014
23310448refg++ -m32 -march=k6 -Os -fomit-frame-pointer2014101420141014
23354670refg++ -m32 -march=k6-3 -Os -fomit-frame-pointer2014101420141014
23365887refg++ -m32 -march=k6-2 -Os -fomit-frame-pointer2014101420141014
23371128refg++ -m32 -march=i486 -O -fomit-frame-pointer2014101420141014

Test failure

Implementation: crypto_aead/paeq128t/aesni
Compiler: g++ -m32 -march=core-avx-i -O2 -fomit-frame-pointer
error 111

Number of similar (compiler,implementation) pairs: 7, namely:
CompilerImplementations
g++ -m32 -march=core-avx-i -O2 -fomit-frame-pointer aesni
g++ -m32 -march=core-avx-i -O -fomit-frame-pointer aesni
g++ -m32 -march=core-avx-i -Os -fomit-frame-pointer aesni
g++ -m32 -march=core2 -O3 -fomit-frame-pointer ref
g++ -m32 -march=corei7-avx -O2 -fomit-frame-pointer aesni
g++ -m32 -march=corei7-avx -O -fomit-frame-pointer aesni
g++ -m32 -march=corei7-avx -Os -fomit-frame-pointer aesni

Compiler output

Implementation: crypto_aead/paeq128t/aesni
Compiler: g++ -m32 -O2 -fomit-frame-pointer
encrypt.cpp: In file included from /usr/lib/gcc/x86_64-linux-gnu/4.6/include/wmmintrin.h:31:0,
encrypt.cpp: from encrypt.cpp:14:
encrypt.cpp: /usr/lib/gcc/x86_64-linux-gnu/4.6/include/emmintrin.h:32:3: error: #error "SSE2 instruction set not enabled"
encrypt.cpp: In file included from encrypt.cpp:14:0:
encrypt.cpp: /usr/lib/gcc/x86_64-linux-gnu/4.6/include/wmmintrin.h:34:3: error: #error "AES/PCLMUL instructions not enabled"
encrypt.cpp: encrypt.cpp:142:27: error: '__m128i' does not name a type
encrypt.cpp: encrypt.cpp:142:36: error: ISO C++ forbids declaration of 'input1' with no type [-fpermissive]
encrypt.cpp: encrypt.cpp:142:50: error: '__m128i' does not name a type
encrypt.cpp: encrypt.cpp:142:59: error: ISO C++ forbids declaration of 'input2' with no type [-fpermissive]
encrypt.cpp: encrypt.cpp:142:67: error: '__m128i' has not been declared
encrypt.cpp: encrypt.cpp:142:85: error: '__m128i' has not been declared
encrypt.cpp: encrypt.cpp: In function 'void DoubleFPermAsm(const int*, const int*, int*, int*)':
encrypt.cpp: encrypt.cpp:145:2: error: '__m128i' was not declared in this scope
encrypt.cpp: encrypt.cpp:145:10: error: expected ';' before 'roundkey0'
encrypt.cpp: encrypt.cpp:146:10: error: expected ';' before 'roundkey1'
encrypt.cpp: encrypt.cpp:147:10: error: expected ';' before 'roundkey2'
encrypt.cpp: encrypt.cpp:148:10: error: expected ';' before 'roundkey3'
encrypt.cpp: encrypt.cpp:149:10: error: expected ';' before 'roundkeyUpdateConstant'
encrypt.cpp: encrypt.cpp:151:10: error: expected ';' before 'acc0'
encrypt.cpp: encrypt.cpp:152:10: error: expected ';' before 'acc1'
encrypt.cpp: encrypt.cpp:153:10: error: expected ';' before 'acc2'
encrypt.cpp: encrypt.cpp:154:10: error: expected ';' before 'acc3'
encrypt.cpp: encrypt.cpp:156:10: error: expected ';' before 'acc4'
encrypt.cpp: encrypt.cpp:157:10: error: expected ';' before 'acc5'
encrypt.cpp: encrypt.cpp:158:10: error: expected ';' before 'acc6'
encrypt.cpp: ...

Number of similar (compiler,implementation) pairs: 48, namely:
CompilerImplementations
g++ -m32 -O2 -fomit-frame-pointer aesni
g++ -m32 -O3 -fomit-frame-pointer aesni
g++ -m32 -O -fomit-frame-pointer aesni
g++ -m32 -Os -fomit-frame-pointer aesni
g++ -m32 -march=athlon -O2 -fomit-frame-pointer aesni
g++ -m32 -march=athlon -O3 -fomit-frame-pointer aesni
g++ -m32 -march=athlon -O -fomit-frame-pointer aesni
g++ -m32 -march=athlon -Os -fomit-frame-pointer aesni
g++ -m32 -march=i386 -O2 -fomit-frame-pointer aesni
g++ -m32 -march=i386 -O3 -fomit-frame-pointer aesni
g++ -m32 -march=i386 -O -fomit-frame-pointer aesni
g++ -m32 -march=i386 -Os -fomit-frame-pointer aesni
g++ -m32 -march=i486 -O2 -fomit-frame-pointer aesni
g++ -m32 -march=i486 -O3 -fomit-frame-pointer aesni
g++ -m32 -march=i486 -O -fomit-frame-pointer aesni
g++ -m32 -march=i486 -Os -fomit-frame-pointer aesni
g++ -m32 -march=k6-2 -O2 -fomit-frame-pointer aesni
g++ -m32 -march=k6-2 -O3 -fomit-frame-pointer aesni
g++ -m32 -march=k6-2 -O -fomit-frame-pointer aesni
g++ -m32 -march=k6-2 -Os -fomit-frame-pointer aesni
g++ -m32 -march=k6-3 -O2 -fomit-frame-pointer aesni
g++ -m32 -march=k6-3 -O3 -fomit-frame-pointer aesni
g++ -m32 -march=k6-3 -O -fomit-frame-pointer aesni
g++ -m32 -march=k6-3 -Os -fomit-frame-pointer aesni
g++ -m32 -march=k6 -O2 -fomit-frame-pointer aesni
g++ -m32 -march=k6 -O3 -fomit-frame-pointer aesni
g++ -m32 -march=k6 -O -fomit-frame-pointer aesni
g++ -m32 -march=k6 -Os -fomit-frame-pointer aesni
g++ -m32 -march=pentium-mmx -O2 -fomit-frame-pointer aesni
g++ -m32 -march=pentium-mmx -O3 -fomit-frame-pointer aesni
g++ -m32 -march=pentium-mmx -O -fomit-frame-pointer aesni
g++ -m32 -march=pentium-mmx -Os -fomit-frame-pointer aesni
g++ -m32 -march=pentium2 -O2 -fomit-frame-pointer aesni
g++ -m32 -march=pentium2 -O3 -fomit-frame-pointer aesni
g++ -m32 -march=pentium2 -O -fomit-frame-pointer aesni
g++ -m32 -march=pentium2 -Os -fomit-frame-pointer aesni
g++ -m32 -march=pentium3 -O2 -fomit-frame-pointer aesni
g++ -m32 -march=pentium3 -O3 -fomit-frame-pointer aesni
g++ -m32 -march=pentium3 -O -fomit-frame-pointer aesni
g++ -m32 -march=pentium3 -Os -fomit-frame-pointer aesni
g++ -m32 -march=pentium -O2 -fomit-frame-pointer aesni
g++ -m32 -march=pentium -O3 -fomit-frame-pointer aesni
g++ -m32 -march=pentium -O -fomit-frame-pointer aesni
g++ -m32 -march=pentium -Os -fomit-frame-pointer aesni
g++ -m32 -march=pentiumpro -O2 -fomit-frame-pointer aesni
g++ -m32 -march=pentiumpro -O3 -fomit-frame-pointer aesni
g++ -m32 -march=pentiumpro -O -fomit-frame-pointer aesni
g++ -m32 -march=pentiumpro -Os -fomit-frame-pointer aesni

Compiler output

Implementation: crypto_aead/paeq128t/aesni
Compiler: g++ -m32 -march=barcelona -O2 -fomit-frame-pointer
encrypt.cpp: In file included from encrypt.cpp:14:0:
encrypt.cpp: /usr/lib/gcc/x86_64-linux-gnu/4.6/include/wmmintrin.h:34:3: error: #error "AES/PCLMUL instructions not enabled"
encrypt.cpp: encrypt.cpp: In function 'void DoubleFPermAsm(const __m128i*, const __m128i*, __m128i*, __m128i*)':
encrypt.cpp: encrypt.cpp:168:43: error: '_mm_aesenc_si128' was not declared in this scope
encrypt.cpp: encrypt.cpp: In function 'void FPermAsm(const __m128i*, __m128i*)':
encrypt.cpp: encrypt.cpp:242:43: error: '_mm_aesenc_si128' was not declared in this scope
encrypt.cpp: In file included from encrypt.cpp:14:0:
encrypt.cpp: /usr/lib/gcc/x86_64-linux-gnu/4.6/include/wmmintrin.h:34:3: error: #error "AES/PCLMUL instructions not enabled"
encrypt.cpp: encrypt.cpp: In function 'void DoubleFPermAsm(const __m128i*, const __m128i*, __m128i*, __m128i*)':
encrypt.cpp: encrypt.cpp:168:43: error: '_mm_aesenc_si128' was not declared in this scope
encrypt.cpp: encrypt.cpp: In function 'void FPermAsm(const __m128i*, __m128i*)':
encrypt.cpp: encrypt.cpp:242:43: error: '_mm_aesenc_si128' was not declared in this scope

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

Compiler output

Implementation: crypto_aead/paeq128t/aesni
Compiler: g++ -m32 -march=core2 -O2 -fomit-frame-pointer
encrypt.cpp: In file included from encrypt.cpp:14:0:
encrypt.cpp: /usr/lib/gcc/x86_64-linux-gnu/4.6/include/wmmintrin.h:34:3: error: #error "AES/PCLMUL instructions not enabled"
encrypt.cpp: encrypt.cpp: In function 'void DoubleFPermAsm(const __m128i*, const __m128i*, __m128i*, __m128i*)':
encrypt.cpp: encrypt.cpp:168:43: error: '_mm_aesenc_si128' was not declared in this scope
encrypt.cpp: encrypt.cpp: In function 'void FPermAsm(const __m128i*, __m128i*)':
encrypt.cpp: encrypt.cpp:242:43: error: '_mm_aesenc_si128' was not declared in this scope

Number of similar (compiler,implementation) pairs: 37, namely:
CompilerImplementations
g++ -m32 -march=core2 -O2 -fomit-frame-pointer aesni
g++ -m32 -march=core2 -O3 -fomit-frame-pointer aesni
g++ -m32 -march=core2 -O -fomit-frame-pointer aesni
g++ -m32 -march=core2 -Os -fomit-frame-pointer aesni
g++ -m32 -march=core2 -msse4.1 -O2 -fomit-frame-pointer aesni
g++ -m32 -march=core2 -msse4.1 -O -fomit-frame-pointer aesni
g++ -m32 -march=core2 -msse4.1 -Os -fomit-frame-pointer aesni
g++ -m32 -march=core2 -msse4 -O2 -fomit-frame-pointer aesni
g++ -m32 -march=core2 -msse4 -O -fomit-frame-pointer aesni
g++ -m32 -march=core2 -msse4 -Os -fomit-frame-pointer aesni
g++ -m32 -march=corei7 -O2 -fomit-frame-pointer aesni
g++ -m32 -march=corei7 -O -fomit-frame-pointer aesni
g++ -m32 -march=corei7 -Os -fomit-frame-pointer aesni
g++ -m32 -march=k8 -O2 -fomit-frame-pointer aesni
g++ -m32 -march=k8 -O3 -fomit-frame-pointer aesni
g++ -m32 -march=k8 -O -fomit-frame-pointer aesni
g++ -m32 -march=k8 -Os -fomit-frame-pointer aesni
g++ -m32 -march=native -mtune=native -O2 -fomit-frame-pointer aesni
g++ -m32 -march=native -mtune=native -O3 -fomit-frame-pointer aesni
g++ -m32 -march=native -mtune=native -O -fomit-frame-pointer aesni
g++ -m32 -march=native -mtune=native -Os -fomit-frame-pointer aesni
g++ -m32 -march=nocona -O2 -fomit-frame-pointer aesni
g++ -m32 -march=nocona -O3 -fomit-frame-pointer aesni
g++ -m32 -march=nocona -O -fomit-frame-pointer aesni
g++ -m32 -march=nocona -Os -fomit-frame-pointer aesni
g++ -m32 -march=pentium-m -O2 -fomit-frame-pointer aesni
g++ -m32 -march=pentium-m -O3 -fomit-frame-pointer aesni
g++ -m32 -march=pentium-m -O -fomit-frame-pointer aesni
g++ -m32 -march=pentium-m -Os -fomit-frame-pointer aesni
g++ -m32 -march=pentium4 -O2 -fomit-frame-pointer aesni
g++ -m32 -march=pentium4 -O3 -fomit-frame-pointer aesni
g++ -m32 -march=pentium4 -O -fomit-frame-pointer aesni
g++ -m32 -march=pentium4 -Os -fomit-frame-pointer aesni
g++ -m32 -march=prescott -O2 -fomit-frame-pointer aesni
g++ -m32 -march=prescott -O3 -fomit-frame-pointer aesni
g++ -m32 -march=prescott -O -fomit-frame-pointer aesni
g++ -m32 -march=prescott -Os -fomit-frame-pointer aesni