Implementation notes: x86, hydra4, crypto_aead/paeq64

Computer: hydra4
Architecture: x86
CPU ID: AuthenticAMD-00300f10-178bfbff
SUPERCOP version: 20141014
Operation: crypto_aead
Primitive: paeq64
TimeImplementationCompilerBenchmark dateSUPERCOP version
4506914refg++ -m32 -O3 -fomit-frame-pointer2014101420141014
4576720refg++ -m32 -march=nocona -O3 -fomit-frame-pointer2014101420141014
4612542refg++ -m32 -march=prescott -O3 -fomit-frame-pointer2014101420141014
4650882refg++ -m32 -march=k8 -O3 -fomit-frame-pointer2014101420141014
4660376refg++ -m32 -march=native -mtune=native -O3 -fomit-frame-pointer2014101420141014
4667484refg++ -m32 -march=barcelona -O3 -fomit-frame-pointer2014101420141014
4714304refg++ -m32 -march=pentium4 -O3 -fomit-frame-pointer2014101420141014
4793509refg++ -m32 -march=athlon -O3 -fomit-frame-pointer2014101420141014
5411274refg++ -m32 -march=pentium -O3 -fomit-frame-pointer2014101420141014
5442442refg++ -m32 -march=pentium-mmx -O3 -fomit-frame-pointer2014101420141014
5613883refg++ -m32 -march=k6-3 -O3 -fomit-frame-pointer2014101420141014
5633897refg++ -m32 -march=k6-2 -O3 -fomit-frame-pointer2014101420141014
5704249refg++ -m32 -march=pentium-m -O3 -fomit-frame-pointer2014101420141014
5792483refg++ -m32 -march=k6 -O3 -fomit-frame-pointer2014101420141014
5813577refg++ -m32 -march=pentium2 -O3 -fomit-frame-pointer2014101420141014
5930270refg++ -m32 -march=pentiumpro -O3 -fomit-frame-pointer2014101420141014
5950682refg++ -m32 -march=pentium3 -O3 -fomit-frame-pointer2014101420141014
5995595refg++ -m32 -march=i386 -O3 -fomit-frame-pointer2014101420141014
6025453refg++ -m32 -march=i486 -O3 -fomit-frame-pointer2014101420141014
10658084refg++ -m32 -march=prescott -O2 -fomit-frame-pointer2014101420141014
10662565refg++ -m32 -march=corei7-avx -O2 -fomit-frame-pointer2014101420141014
10664183refg++ -m32 -march=nocona -O2 -fomit-frame-pointer2014101420141014
10705176refg++ -m32 -march=core-avx-i -O2 -fomit-frame-pointer2014101420141014
10762191refg++ -m32 -march=k8 -O2 -fomit-frame-pointer2014101420141014
10762537refg++ -m32 -march=athlon -O2 -fomit-frame-pointer2014101420141014
10875412refg++ -m32 -O2 -fomit-frame-pointer2014101420141014
10879112refg++ -m32 -march=corei7 -O2 -fomit-frame-pointer2014101420141014
10881393refg++ -m32 -march=core2 -O2 -fomit-frame-pointer2014101420141014
10881745refg++ -m32 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2014101420141014
10893886refg++ -m32 -march=core2 -msse4 -O2 -fomit-frame-pointer2014101420141014
10912980refg++ -m32 -march=barcelona -O2 -fomit-frame-pointer2014101420141014
10968302refg++ -m32 -march=native -mtune=native -O2 -fomit-frame-pointer2014101420141014
11108464refg++ -m32 -march=pentium4 -O2 -fomit-frame-pointer2014101420141014
11739877refg++ -m32 -march=core2 -msse4 -Os -fomit-frame-pointer2014101420141014
11740084refg++ -m32 -march=native -mtune=native -Os -fomit-frame-pointer2014101420141014
11743910refg++ -m32 -march=corei7 -Os -fomit-frame-pointer2014101420141014
11746847refg++ -m32 -march=core-avx-i -Os -fomit-frame-pointer2014101420141014
11747611refg++ -m32 -march=corei7-avx -Os -fomit-frame-pointer2014101420141014
11749140refg++ -m32 -march=core2 -msse4.1 -Os -fomit-frame-pointer2014101420141014
11750735refg++ -m32 -Os -fomit-frame-pointer2014101420141014
11768409refg++ -m32 -march=k8 -Os -fomit-frame-pointer2014101420141014
11770839refg++ -m32 -march=core2 -Os -fomit-frame-pointer2014101420141014
11778351refg++ -m32 -march=athlon -Os -fomit-frame-pointer2014101420141014
11782201refg++ -m32 -march=barcelona -Os -fomit-frame-pointer2014101420141014
11906127refg++ -m32 -march=prescott -Os -fomit-frame-pointer2014101420141014
11911434refg++ -m32 -march=nocona -Os -fomit-frame-pointer2014101420141014
11921044refg++ -m32 -march=pentium4 -Os -fomit-frame-pointer2014101420141014
12909999refg++ -m32 -march=barcelona -O -fomit-frame-pointer2014101420141014
12993899refg++ -m32 -march=athlon -O -fomit-frame-pointer2014101420141014
13001220refg++ -m32 -march=k8 -O -fomit-frame-pointer2014101420141014
13001641refg++ -m32 -march=native -mtune=native -O -fomit-frame-pointer2014101420141014
13006238refg++ -m32 -march=prescott -O -fomit-frame-pointer2014101420141014
13043842refg++ -m32 -march=core2 -O -fomit-frame-pointer2014101420141014
13056513refg++ -m32 -O -fomit-frame-pointer2014101420141014
13058358refg++ -m32 -march=nocona -O -fomit-frame-pointer2014101420141014
13059692refg++ -m32 -march=core-avx-i -O -fomit-frame-pointer2014101420141014
13066658refg++ -m32 -march=core2 -msse4 -O -fomit-frame-pointer2014101420141014
13077145refg++ -m32 -march=corei7 -O -fomit-frame-pointer2014101420141014
13079758refg++ -m32 -march=pentium4 -O -fomit-frame-pointer2014101420141014
13082889refg++ -m32 -march=core2 -msse4.1 -O -fomit-frame-pointer2014101420141014
13131815refg++ -m32 -march=corei7-avx -O -fomit-frame-pointer2014101420141014
18358985refg++ -m32 -march=i386 -O2 -fomit-frame-pointer2014101420141014
19226976refg++ -m32 -march=i486 -O2 -fomit-frame-pointer2014101420141014
19578187refg++ -m32 -march=pentium -O2 -fomit-frame-pointer2014101420141014
19590570refg++ -m32 -march=pentium-mmx -O2 -fomit-frame-pointer2014101420141014
20300097refg++ -m32 -march=k6-3 -O2 -fomit-frame-pointer2014101420141014
20475705refg++ -m32 -march=k6 -O2 -fomit-frame-pointer2014101420141014
20495900refg++ -m32 -march=k6-2 -O2 -fomit-frame-pointer2014101420141014
20505521refg++ -m32 -march=pentium-mmx -Os -fomit-frame-pointer2014101420141014
20604558refg++ -m32 -march=pentium -Os -fomit-frame-pointer2014101420141014
20885443refg++ -m32 -march=pentium3 -O2 -fomit-frame-pointer2014101420141014
20928141refg++ -m32 -march=pentium2 -O2 -fomit-frame-pointer2014101420141014
20946299refg++ -m32 -march=pentium-m -O2 -fomit-frame-pointer2014101420141014
20990179refg++ -m32 -march=pentiumpro -O2 -fomit-frame-pointer2014101420141014
21233441refg++ -m32 -march=pentiumpro -Os -fomit-frame-pointer2014101420141014
21252048refg++ -m32 -march=pentium2 -Os -fomit-frame-pointer2014101420141014
21350032refg++ -m32 -march=pentium-m -Os -fomit-frame-pointer2014101420141014
21350569refg++ -m32 -march=pentium3 -Os -fomit-frame-pointer2014101420141014
21475931refg++ -m32 -march=pentium2 -O -fomit-frame-pointer2014101420141014
21481770refg++ -m32 -march=pentiumpro -O -fomit-frame-pointer2014101420141014
21598512refg++ -m32 -march=k6-3 -O -fomit-frame-pointer2014101420141014
21632938refg++ -m32 -march=k6-2 -O -fomit-frame-pointer2014101420141014
21674071refg++ -m32 -march=pentium3 -O -fomit-frame-pointer2014101420141014
21689905refg++ -m32 -march=i386 -O -fomit-frame-pointer2014101420141014
21695689refg++ -m32 -march=i386 -Os -fomit-frame-pointer2014101420141014
21700423refg++ -m32 -march=pentium-mmx -O -fomit-frame-pointer2014101420141014
21701340refg++ -m32 -march=k6 -O -fomit-frame-pointer2014101420141014
21719123refg++ -m32 -march=pentium-m -O -fomit-frame-pointer2014101420141014
21750307refg++ -m32 -march=i486 -Os -fomit-frame-pointer2014101420141014
21756832refg++ -m32 -march=pentium -O -fomit-frame-pointer2014101420141014
21993114refg++ -m32 -march=k6-3 -Os -fomit-frame-pointer2014101420141014
22001596refg++ -m32 -march=k6-2 -Os -fomit-frame-pointer2014101420141014
22033775refg++ -m32 -march=k6 -Os -fomit-frame-pointer2014101420141014
22212844refg++ -m32 -march=i486 -O -fomit-frame-pointer2014101420141014

Test failure

Implementation: crypto_aead/paeq64/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/paeq64/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:13:
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:13: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:140:27: error: '__m128i' does not name a type
encrypt.cpp: encrypt.cpp:140:36: error: ISO C++ forbids declaration of 'input1' with no type [-fpermissive]
encrypt.cpp: encrypt.cpp:140:50: error: '__m128i' does not name a type
encrypt.cpp: encrypt.cpp:140:59: error: ISO C++ forbids declaration of 'input2' with no type [-fpermissive]
encrypt.cpp: encrypt.cpp:140:67: error: '__m128i' has not been declared
encrypt.cpp: encrypt.cpp:140: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:143:2: error: '__m128i' was not declared in this scope
encrypt.cpp: encrypt.cpp:143:10: error: expected ';' before 'roundkey0'
encrypt.cpp: encrypt.cpp:144:10: error: expected ';' before 'roundkey1'
encrypt.cpp: encrypt.cpp:145:10: error: expected ';' before 'roundkey2'
encrypt.cpp: encrypt.cpp:146:10: error: expected ';' before 'roundkey3'
encrypt.cpp: encrypt.cpp:147:10: error: expected ';' before 'roundkeyUpdateConstant'
encrypt.cpp: encrypt.cpp:149:10: error: expected ';' before 'acc0'
encrypt.cpp: encrypt.cpp:150:10: error: expected ';' before 'acc1'
encrypt.cpp: encrypt.cpp:151:10: error: expected ';' before 'acc2'
encrypt.cpp: encrypt.cpp:152:10: error: expected ';' before 'acc3'
encrypt.cpp: encrypt.cpp:154:10: error: expected ';' before 'acc4'
encrypt.cpp: encrypt.cpp:155:10: error: expected ';' before 'acc5'
encrypt.cpp: encrypt.cpp:156: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/paeq64/aesni
Compiler: g++ -m32 -march=barcelona -O2 -fomit-frame-pointer
encrypt.cpp: In file included from encrypt.cpp:13: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:166: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:240:43: error: '_mm_aesenc_si128' was not declared in this scope
encrypt.cpp: In file included from encrypt.cpp:13: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:166: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:240: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/paeq64/aesni
Compiler: g++ -m32 -march=core2 -O2 -fomit-frame-pointer
encrypt.cpp: In file included from encrypt.cpp:13: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:166: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:240: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