Implementation notes: x86, hydra4, crypto_dh/surf2113

Computer: hydra4
Architecture: x86
CPU ID: AuthenticAMD-00300f10-178bfbff
SUPERCOP version: 20141014
Operation: crypto_dh
Primitive: surf2113
TimeImplementationCompilerBenchmark dateSUPERCOP version
4667142mpfqgcc -funroll-loops -m32 -march=barcelona -O -fomit-frame-pointer2014101420141014
4678717mpfqgcc -funroll-loops -m32 -march=k8 -O -fomit-frame-pointer2014101420141014
4702121mpfqgcc -funroll-loops -m32 -march=pentium-m -O -fomit-frame-pointer2014101420141014
4761428mpfqgcc -funroll-loops -m32 -march=nocona -O -fomit-frame-pointer2014101420141014
4761494mpfqgcc -funroll-loops -m32 -march=prescott -O -fomit-frame-pointer2014101420141014
4823664mpfqgcc -funroll-loops -m32 -march=pentium4 -O -fomit-frame-pointer2014101420141014
4943784mpfqgcc -m32 -march=pentium-m -O -fomit-frame-pointer2014101420141014
5013196mpfqgcc -m32 -march=native -mtune=native -O -fomit-frame-pointer2014101420141014
5022896mpfqgcc -m32 -march=barcelona -O -fomit-frame-pointer2014101420141014
5027939mpfqgcc -m32 -march=k8 -O -fomit-frame-pointer2014101420141014
5074130mpfqgcc -m32 -march=nocona -O -fomit-frame-pointer2014101420141014
5103559mpfqgcc -m32 -march=pentium4 -O -fomit-frame-pointer2014101420141014
5109441mpfqgcc -m32 -march=prescott -O -fomit-frame-pointer2014101420141014
5115767mpfqgcc -m32 -march=core2 -O -fomit-frame-pointer2014101420141014
7506054mpfqgcc -m32 -march=pentium-m -O3 -fomit-frame-pointer2014101420141014
7708725mpfqgcc -m32 -march=pentium-m -O2 -fomit-frame-pointer2014101420141014
8012710mpfqgcc -funroll-loops -m32 -march=pentium4 -Os -fomit-frame-pointer2014101420141014
8063285mpfqgcc -funroll-loops -m32 -march=prescott -Os -fomit-frame-pointer2014101420141014
8087173mpfqgcc -funroll-loops -m32 -march=nocona -Os -fomit-frame-pointer2014101420141014
8097995mpfqgcc -m32 -march=prescott -O3 -fomit-frame-pointer2014101420141014
8129043mpfqgcc -m32 -march=nocona -O3 -fomit-frame-pointer2014101420141014
8131481mpfqgcc -m32 -march=core2 -O2 -fomit-frame-pointer2014101420141014
8147080mpfqgcc -m32 -march=k8 -O3 -fomit-frame-pointer2014101420141014
8151511mpfqgcc -funroll-loops -m32 -march=nocona -O3 -fomit-frame-pointer2014101420141014
8175075mpfqgcc -m32 -march=nocona -Os -fomit-frame-pointer2014101420141014
8175317mpfqgcc -m32 -march=prescott -Os -fomit-frame-pointer2014101420141014
8184614mpfqgcc -m32 -march=pentium4 -Os -fomit-frame-pointer2014101420141014
8191970mpfqgcc -funroll-loops -m32 -march=prescott -O3 -fomit-frame-pointer2014101420141014
8210780mpfqgcc -m32 -march=core2 -Os -fomit-frame-pointer2014101420141014
8216243mpfqgcc -m32 -march=pentium4 -O3 -fomit-frame-pointer2014101420141014
8217628mpfqgcc -funroll-loops -m32 -march=pentium4 -O3 -fomit-frame-pointer2014101420141014
8218645mpfqgcc -m32 -march=pentium-m -Os -fomit-frame-pointer2014101420141014
8249716mpfqgcc -funroll-loops -m32 -march=prescott -O2 -fomit-frame-pointer2014101420141014
8251344mpfqgcc -funroll-loops -m32 -march=nocona -O2 -fomit-frame-pointer2014101420141014
8295916mpfqgcc -funroll-loops -m32 -march=pentium4 -O2 -fomit-frame-pointer2014101420141014
8381072mpfqgcc -m32 -march=k8 -O2 -fomit-frame-pointer2014101420141014
8402507mpfqgcc -m32 -march=k8 -Os -fomit-frame-pointer2014101420141014
8409991mpfqgcc -m32 -march=pentium4 -O2 -fomit-frame-pointer2014101420141014
8447653mpfqgcc -m32 -march=prescott -O2 -fomit-frame-pointer2014101420141014
8479259mpfqgcc -m32 -march=nocona -O2 -fomit-frame-pointer2014101420141014
8525681mpfqgcc -funroll-loops -m32 -march=k8 -O3 -fomit-frame-pointer2014101420141014
8553472mpfqgcc -funroll-loops -m32 -march=k8 -O2 -fomit-frame-pointer2014101420141014
8730021mpfqgcc -funroll-loops -m32 -march=k8 -Os -fomit-frame-pointer2014101420141014
8916925mpfqgcc -m32 -march=barcelona -O3 -fomit-frame-pointer2014101420141014
8921297mpfqgcc -m32 -march=native -mtune=native -O3 -fomit-frame-pointer2014101420141014
9068401mpfqgcc -funroll-loops -m32 -march=pentium-m -O2 -fomit-frame-pointer2014101420141014
9082297mpfqgcc -m32 -march=barcelona -Os -fomit-frame-pointer2014101420141014
9084773mpfqgcc -m32 -march=native -mtune=native -Os -fomit-frame-pointer2014101420141014
9096941mpfqgcc -m32 -march=barcelona -O2 -fomit-frame-pointer2014101420141014
9100642mpfqgcc -funroll-loops -m32 -march=pentium-m -Os -fomit-frame-pointer2014101420141014
9108134mpfqgcc -m32 -march=native -mtune=native -O2 -fomit-frame-pointer2014101420141014
9175463mpfqgcc -funroll-loops -m32 -march=pentium-m -O3 -fomit-frame-pointer2014101420141014
9215135mpfqgcc -funroll-loops -m32 -march=barcelona -O3 -fomit-frame-pointer2014101420141014
9239962mpfqgcc -funroll-loops -m32 -march=barcelona -O2 -fomit-frame-pointer2014101420141014
9625753mpfqgcc -funroll-loops -m32 -march=barcelona -Os -fomit-frame-pointer2014101420141014

Test failure

Implementation: crypto_dh/surf2113/mpfq
Compiler: gcc -m32 -march=core-avx-i -O2 -fomit-frame-pointer
error 111

Number of similar (compiler,implementation) pairs: 16, namely:
CompilerImplementations
gcc -m32 -march=core-avx-i -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=core-avx-i -O -fomit-frame-pointer mpfq
gcc -m32 -march=core-avx-i -Os -fomit-frame-pointer mpfq
gcc -m32 -march=core2 -O3 -fomit-frame-pointer mpfq
gcc -m32 -march=core2 -msse4.1 -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=core2 -msse4.1 -O -fomit-frame-pointer mpfq
gcc -m32 -march=core2 -msse4.1 -Os -fomit-frame-pointer mpfq
gcc -m32 -march=core2 -msse4 -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=core2 -msse4 -O -fomit-frame-pointer mpfq
gcc -m32 -march=core2 -msse4 -Os -fomit-frame-pointer mpfq
gcc -m32 -march=corei7-avx -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=corei7-avx -O -fomit-frame-pointer mpfq
gcc -m32 -march=corei7-avx -Os -fomit-frame-pointer mpfq
gcc -m32 -march=corei7 -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=corei7 -O -fomit-frame-pointer mpfq
gcc -m32 -march=corei7 -Os -fomit-frame-pointer mpfq

Compiler output

Implementation: crypto_dh/surf2113/mpfq
Compiler: gcc -funroll-loops -m32 -O2 -fomit-frame-pointer
Surf2_113.c: In file included from x86_32/mpfq_2_113.h:11:0,
Surf2_113.c: from mpfq_2_113.h:3,
Surf2_113.c: from field.h:1,
Surf2_113.c: from Surf2_113.c:11:
Surf2_113.c: /usr/lib/gcc/x86_64-linux-gnu/4.6/include/emmintrin.h:32:3: error: #error "SSE2 instruction set not enabled"
Surf2_113.c: In file included from mpfq_2_113.h:3:0,
Surf2_113.c: from field.h:1,
Surf2_113.c: from Surf2_113.c:11:
Surf2_113.c: x86_32/mpfq_2_113.h: In function 'mpfq_2_113_mul_ur':
Surf2_113.c: x86_32/mpfq_2_113.h:586:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:587:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:588:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:613:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:613:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:616:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:616:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:619:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:619:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:622:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:622:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:625:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:625:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:628:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:628:2: error: can't convert between vector values of different size
Surf2_113.c: x86_32/mpfq_2_113.h:631:2: error: can't convert between vector values of different size
Surf2_113.c: ...

Number of similar (compiler,implementation) pairs: 96, namely:
CompilerImplementations
gcc -funroll-loops -m32 -O2 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -O3 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -O -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -Os -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=athlon -O2 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=athlon -O3 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=athlon -O -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=athlon -Os -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=i386 -O2 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=i386 -O3 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=i386 -O -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=i386 -Os -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=i486 -O2 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=i486 -O3 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=i486 -O -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=i486 -Os -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=k6-2 -O2 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=k6-2 -O3 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=k6-2 -O -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=k6-2 -Os -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=k6-3 -O2 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=k6-3 -O3 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=k6-3 -O -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=k6-3 -Os -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=k6 -O2 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=k6 -O3 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=k6 -O -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=k6 -Os -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium-mmx -O2 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium-mmx -O3 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium-mmx -O -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium-mmx -Os -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium2 -O2 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium2 -O3 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium2 -O -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium2 -Os -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium3 -O2 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium3 -O3 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium3 -O -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium3 -Os -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium -O2 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium -O3 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium -O -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentium -Os -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentiumpro -O2 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentiumpro -O3 -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentiumpro -O -fomit-frame-pointer mpfq
gcc -funroll-loops -m32 -march=pentiumpro -Os -fomit-frame-pointer mpfq
gcc -m32 -O2 -fomit-frame-pointer mpfq
gcc -m32 -O3 -fomit-frame-pointer mpfq
gcc -m32 -O -fomit-frame-pointer mpfq
gcc -m32 -Os -fomit-frame-pointer mpfq
gcc -m32 -march=athlon -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=athlon -O3 -fomit-frame-pointer mpfq
gcc -m32 -march=athlon -O -fomit-frame-pointer mpfq
gcc -m32 -march=athlon -Os -fomit-frame-pointer mpfq
gcc -m32 -march=i386 -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=i386 -O3 -fomit-frame-pointer mpfq
gcc -m32 -march=i386 -O -fomit-frame-pointer mpfq
gcc -m32 -march=i386 -Os -fomit-frame-pointer mpfq
gcc -m32 -march=i486 -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=i486 -O3 -fomit-frame-pointer mpfq
gcc -m32 -march=i486 -O -fomit-frame-pointer mpfq
gcc -m32 -march=i486 -Os -fomit-frame-pointer mpfq
gcc -m32 -march=k6-2 -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=k6-2 -O3 -fomit-frame-pointer mpfq
gcc -m32 -march=k6-2 -O -fomit-frame-pointer mpfq
gcc -m32 -march=k6-2 -Os -fomit-frame-pointer mpfq
gcc -m32 -march=k6-3 -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=k6-3 -O3 -fomit-frame-pointer mpfq
gcc -m32 -march=k6-3 -O -fomit-frame-pointer mpfq
gcc -m32 -march=k6-3 -Os -fomit-frame-pointer mpfq
gcc -m32 -march=k6 -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=k6 -O3 -fomit-frame-pointer mpfq
gcc -m32 -march=k6 -O -fomit-frame-pointer mpfq
gcc -m32 -march=k6 -Os -fomit-frame-pointer mpfq
gcc -m32 -march=pentium-mmx -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=pentium-mmx -O3 -fomit-frame-pointer mpfq
gcc -m32 -march=pentium-mmx -O -fomit-frame-pointer mpfq
gcc -m32 -march=pentium-mmx -Os -fomit-frame-pointer mpfq
gcc -m32 -march=pentium2 -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=pentium2 -O3 -fomit-frame-pointer mpfq
gcc -m32 -march=pentium2 -O -fomit-frame-pointer mpfq
gcc -m32 -march=pentium2 -Os -fomit-frame-pointer mpfq
gcc -m32 -march=pentium3 -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=pentium3 -O3 -fomit-frame-pointer mpfq
gcc -m32 -march=pentium3 -O -fomit-frame-pointer mpfq
gcc -m32 -march=pentium3 -Os -fomit-frame-pointer mpfq
gcc -m32 -march=pentium -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=pentium -O3 -fomit-frame-pointer mpfq
gcc -m32 -march=pentium -O -fomit-frame-pointer mpfq
gcc -m32 -march=pentium -Os -fomit-frame-pointer mpfq
gcc -m32 -march=pentiumpro -O2 -fomit-frame-pointer mpfq
gcc -m32 -march=pentiumpro -O3 -fomit-frame-pointer mpfq
gcc -m32 -march=pentiumpro -O -fomit-frame-pointer mpfq
gcc -m32 -march=pentiumpro -Os -fomit-frame-pointer mpfq