Implementation notes: amd64, hydra2, crypto_dh/kummer

Computer: hydra2
Architecture: amd64
CPU ID: GenuineIntel-000206c2-bfebfbff
SUPERCOP version: 20141014
Operation: crypto_dh
Primitive: kummer
TimeImplementationCompilerBenchmark dateSUPERCOP version
1218216refclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer2014101420141014
1218244refclang -O3 -fwrapv -mavx2 -fomit-frame-pointer2014101420141014
1218588refclang -O3 -fwrapv -march=native -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer2014101420141014
1218796refclang -O3 -fwrapv -march=native -fomit-frame-pointer2014101420141014
1218920refclang -O3 -fwrapv -mavx2 -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer2014101420141014
1219124refclang -O3 -fomit-frame-pointer2014101420141014
1220216refgcc -m64 -march=nocona -O2 -fomit-frame-pointer2014101420141014
1220924refclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer2014101420141014
1221360refgcc -march=nocona -O2 -fomit-frame-pointer2014101420141014
1224528refgcc -march=nocona -O -fomit-frame-pointer2014101420141014
1224536refgcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer2014101420141014
1225696refgcc -m64 -march=nocona -O -fomit-frame-pointer2014101420141014
1225860refgcc -funroll-loops -march=nocona -O -fomit-frame-pointer2014101420141014
1227412refgcc -march=nocona -O3 -fomit-frame-pointer2014101420141014
1228448refgcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer2014101420141014
1230064refgcc -m64 -march=nocona -O3 -fomit-frame-pointer2014101420141014
1232036refgcc -m64 -march=core2 -O -fomit-frame-pointer2014101420141014
1232108refgcc -m64 -march=corei7 -O -fomit-frame-pointer2014101420141014
1232248refgcc -funroll-loops -march=barcelona -O -fomit-frame-pointer2014101420141014
1232420refgcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2014101420141014
1232588refgcc -m64 -O -fomit-frame-pointer2014101420141014
1232616refgcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer2014101420141014
1232812refgcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer2014101420141014
1233068refgcc -fno-schedule-insns -O -fomit-frame-pointer2014101420141014
1233916refgcc -O -fomit-frame-pointer2014101420141014
1234028refgcc -march=nocona -Os -fomit-frame-pointer2014101420141014
1234108refgcc -march=barcelona -Os -fomit-frame-pointer2014101420141014
1234176refgcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer2014101420141014
1234192refgcc -Os -fomit-frame-pointer2014101420141014
1234216refgcc -m64 -march=corei7 -Os -fomit-frame-pointer2014101420141014
1234272refgcc -march=k8 -Os -fomit-frame-pointer2014101420141014
1234356refgcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2014101420141014
1234428refgcc -m64 -march=barcelona -Os -fomit-frame-pointer2014101420141014
1234528refgcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer2014101420141014
1234548refgcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer2014101420141014
1234624refgcc -funroll-loops -m64 -Os -fomit-frame-pointer2014101420141014
1234744refgcc -m64 -march=nocona -Os -fomit-frame-pointer2014101420141014
1234904refgcc -funroll-loops -march=nocona -Os -fomit-frame-pointer2014101420141014
1235120refgcc -fno-schedule-insns -Os -fomit-frame-pointer2014101420141014
1235180refgcc -m64 -march=k8 -Os -fomit-frame-pointer2014101420141014
1235384refgcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer2014101420141014
1235400refgcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer2014101420141014
1235432refgcc -m64 -Os -fomit-frame-pointer2014101420141014
1235448refgcc -funroll-loops -Os -fomit-frame-pointer2014101420141014
1235620refgcc -funroll-loops -march=k8 -Os -fomit-frame-pointer2014101420141014
1235776refgcc -m64 -march=core2 -Os -fomit-frame-pointer2014101420141014
1235884refgcc -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer2014101420141014
1235888refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2014101420141014
1235912refgcc -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer2014101420141014
1235968refgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2014101420141014
1235996refgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer2014101420141014
1236048refgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer2014101420141014
1236048refgcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer2014101420141014
1236072refgcc -funroll-loops -m64 -O2 -fomit-frame-pointer2014101420141014
1236108refgcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer2014101420141014
1236264refgcc -m64 -march=corei7 -O3 -fomit-frame-pointer2014101420141014
1236268refgcc -march=k8 -O3 -fomit-frame-pointer2014101420141014
1236304refgcc -march=barcelona -O3 -fomit-frame-pointer2014101420141014
1236320refgcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer2014101420141014
1236364refgcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2014101420141014
1236368refgcc -fno-schedule-insns -O3 -fomit-frame-pointer2014101420141014
1236428refgcc -funroll-loops -O2 -fomit-frame-pointer2014101420141014
1236436refgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer2014101420141014
1236452refgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer2014101420141014
1236472refgcc -funroll-loops -O3 -fomit-frame-pointer2014101420141014
1236536refgcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer2014101420141014
1236580refgcc -funroll-loops -m64 -O3 -fomit-frame-pointer2014101420141014
1236624refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2014101420141014
1236652refgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer2014101420141014
1236788refgcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer2014101420141014
1237120refgcc -m64 -O3 -fomit-frame-pointer2014101420141014
1237136refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer2014101420141014
1237216refgcc -O3 -fomit-frame-pointer2014101420141014
1237288refgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer2014101420141014
1237384refgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer2014101420141014
1237396refgcc -m64 -march=barcelona -O3 -fomit-frame-pointer2014101420141014
1237464refgcc -m64 -march=k8 -O3 -fomit-frame-pointer2014101420141014
1237664refgcc -m64 -march=core2 -O3 -fomit-frame-pointer2014101420141014
1239104refgcc -funroll-loops -m64 -O -fomit-frame-pointer2014101420141014
1239120refgcc -funroll-loops -O -fomit-frame-pointer2014101420141014
1239852refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2014101420141014
1240544refgcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer2014101420141014
1240792refgcc -funroll-loops -march=k8 -O -fomit-frame-pointer2014101420141014
1241348refgcc -march=barcelona -O2 -fomit-frame-pointer2014101420141014
1241532refgcc -m64 -march=barcelona -O2 -fomit-frame-pointer2014101420141014
1241892refgcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2014101420141014
1242156refgcc -m64 -march=core2 -O2 -fomit-frame-pointer2014101420141014
1242360refgcc -m64 -march=k8 -O2 -fomit-frame-pointer2014101420141014
1242460refgcc -O2 -fomit-frame-pointer2014101420141014
1242680refgcc -march=k8 -O2 -fomit-frame-pointer2014101420141014
1242768refgcc -m64 -O2 -fomit-frame-pointer2014101420141014
1242828refgcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer2014101420141014
1243136refgcc -m64 -march=corei7 -O2 -fomit-frame-pointer2014101420141014
1243180refgcc -fno-schedule-insns -O2 -fomit-frame-pointer2014101420141014
1243180refgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2014101420141014
1248204refgcc -march=k8 -O -fomit-frame-pointer2014101420141014
1251272refgcc -march=barcelona -O -fomit-frame-pointer2014101420141014
1251496refgcc -m64 -march=barcelona -O -fomit-frame-pointer2014101420141014
1251804refgcc -m64 -march=k8 -O -fomit-frame-pointer2014101420141014
1258848refgcc2014101420141014
1259268refcc2014101420141014
1259500refgcc -funroll-loops2014101420141014

Compiler output

Implementation: crypto_dh/kummer/ref
Compiler: clang -O3 -fomit-frame-pointer
try.c: try-anything.c:110:19: warning: if statement has empty body [-Wempty-body]
try.c: ;
try.c: ^
try.c: 1 warning generated.
try.c: try-anything.c:110:19: warning: if statement has empty body [-Wempty-body]
try.c: ;
try.c: ^
try.c: 1 warning generated.

Number of similar (compiler,implementation) pairs: 2, namely:
CompilerImplementations
clang -O3 -fomit-frame-pointer ref
clang -O3 -fwrapv -march=native -fomit-frame-pointer ref

Compiler output

Implementation: crypto_dh/kummer/ref
Compiler: clang -O3 -fwrapv -march=native -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer
dh.c: clang: warning: argument unused during compilation: '-fpolly'
dh.c: clang: warning: argument unused during compilation: '-fvectorize'
dh.c: clang: warning: argument unused during compilation: '-fslp-vectorize'
dh.c: clang: warning: argument unused during compilation: '-fslp-vectorize-aggressive'
keypair.c: clang: warning: argument unused during compilation: '-fpolly'
keypair.c: clang: warning: argument unused during compilation: '-fvectorize'
keypair.c: clang: warning: argument unused during compilation: '-fslp-vectorize'
keypair.c: clang: warning: argument unused during compilation: '-fslp-vectorize-aggressive'
try.c: try-anything.c:110:19: warning: if statement has empty body [-Wempty-body]
try.c: ;
try.c: ^
try.c: 1 warning generated.
try.c: try-anything.c:110:19: warning: if statement has empty body [-Wempty-body]
try.c: ;
try.c: ^
try.c: 1 warning generated.

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -O3 -fwrapv -march=native -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer ref

Compiler output

Implementation: crypto_dh/kummer/ref
Compiler: clang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer
dh.c: clang: warning: argument unused during compilation: '-mcpu=core-avx2'
dh.c: clang: warning: argument unused during compilation: '-mavx2'
dh.c: clang: warning: argument unused during compilation: '-mpclmul'
keypair.c: clang: warning: argument unused during compilation: '-mcpu=core-avx2'
keypair.c: clang: warning: argument unused during compilation: '-mavx2'
keypair.c: clang: warning: argument unused during compilation: '-mpclmul'
try.c: try-anything.c:110:19: warning: if statement has empty body [-Wempty-body]
try.c: ;
try.c: ^
try.c: 1 warning generated.
try.c: try-anything.c:110:19: warning: if statement has empty body [-Wempty-body]
try.c: ;
try.c: ^
try.c: 1 warning generated.

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer ref

Compiler output

Implementation: crypto_dh/kummer/ref
Compiler: clang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer
dh.c: clang: warning: argument unused during compilation: '-mcpu=core-avx2'
dh.c: clang: warning: argument unused during compilation: '-mavx2'
dh.c: clang: warning: argument unused during compilation: '-mpclmul'
dh.c: clang: warning: argument unused during compilation: '-fpolly'
dh.c: clang: warning: argument unused during compilation: '-fvectorize'
dh.c: clang: warning: argument unused during compilation: '-fslp-vectorize'
dh.c: clang: warning: argument unused during compilation: '-fslp-vectorize-aggressive'
keypair.c: clang: warning: argument unused during compilation: '-mcpu=core-avx2'
keypair.c: clang: warning: argument unused during compilation: '-mavx2'
keypair.c: clang: warning: argument unused during compilation: '-mpclmul'
keypair.c: clang: warning: argument unused during compilation: '-fpolly'
keypair.c: clang: warning: argument unused during compilation: '-fvectorize'
keypair.c: clang: warning: argument unused during compilation: '-fslp-vectorize'
keypair.c: clang: warning: argument unused during compilation: '-fslp-vectorize-aggressive'
try.c: try-anything.c:110:19: warning: if statement has empty body [-Wempty-body]
try.c: ;
try.c: ^
try.c: 1 warning generated.
try.c: try-anything.c:110:19: warning: if statement has empty body [-Wempty-body]
try.c: ;
try.c: ^
try.c: 1 warning generated.

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer ref

Compiler output

Implementation: crypto_dh/kummer/ref
Compiler: clang -O3 -fwrapv -mavx2 -fomit-frame-pointer
dh.c: clang: warning: argument unused during compilation: '-mavx2'
keypair.c: clang: warning: argument unused during compilation: '-mavx2'
try.c: try-anything.c:110:19: warning: if statement has empty body [-Wempty-body]
try.c: ;
try.c: ^
try.c: 1 warning generated.
try.c: try-anything.c:110:19: warning: if statement has empty body [-Wempty-body]
try.c: ;
try.c: ^
try.c: 1 warning generated.

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -O3 -fwrapv -mavx2 -fomit-frame-pointer ref

Compiler output

Implementation: crypto_dh/kummer/ref
Compiler: clang -O3 -fwrapv -mavx2 -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer
dh.c: clang: warning: argument unused during compilation: '-mavx2'
dh.c: clang: warning: argument unused during compilation: '-fpolly'
dh.c: clang: warning: argument unused during compilation: '-fvectorize'
dh.c: clang: warning: argument unused during compilation: '-fslp-vectorize'
dh.c: clang: warning: argument unused during compilation: '-fslp-vectorize-aggressive'
keypair.c: clang: warning: argument unused during compilation: '-mavx2'
keypair.c: clang: warning: argument unused during compilation: '-fpolly'
keypair.c: clang: warning: argument unused during compilation: '-fvectorize'
keypair.c: clang: warning: argument unused during compilation: '-fslp-vectorize'
keypair.c: clang: warning: argument unused during compilation: '-fslp-vectorize-aggressive'
try.c: try-anything.c:110:19: warning: if statement has empty body [-Wempty-body]
try.c: ;
try.c: ^
try.c: 1 warning generated.
try.c: try-anything.c:110:19: warning: if statement has empty body [-Wempty-body]
try.c: ;
try.c: ^
try.c: 1 warning generated.

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -O3 -fwrapv -mavx2 -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer ref