Implementation notes: amd64, h4e350, crypto_core/aes256decrypt

Computer: h4e350
Architecture: amd64
CPU ID: AuthenticAMD-00500f10-178bfbff
SUPERCOP version: 20141014
Operation: crypto_core
Primitive: aes256decrypt
TimeImplementationCompilerBenchmark dateSUPERCOP version
2520opensslgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer2014052620140525
2520opensslgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer2014052620140525
2520opensslgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer2014052620140525
2520opensslgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer2014052620140525
2520opensslgcc -m64 -march=barcelona -O3 -fomit-frame-pointer2014052620140525
2520opensslgcc -m64 -march=k8 -O3 -fomit-frame-pointer2014052620140525
2520opensslgcc -march=k8 -O3 -fomit-frame-pointer2014052620140525
2523opensslclang -O3 -fomit-frame-pointer2014071220140622
2523opensslclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer2014101420141014
2523opensslclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer2014101420141014
2523opensslclang -O3 -fwrapv -mavx2 -fomit-frame-pointer2014071220140622
2523opensslclang -O3 -fwrapv -mavx2 -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer2014071220140622
2523opensslgcc -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -O3 -fomit-frame-pointer2014052620140525
2523opensslgcc -fno-schedule-insns -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -fno-schedule-insns -O3 -fomit-frame-pointer2014052620140525
2523opensslgcc -funroll-loops -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -funroll-loops -O3 -fomit-frame-pointer2014052620140525
2523opensslgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -funroll-loops -m64 -O3 -fomit-frame-pointer2014052620140525
2523opensslgcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -m64 -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -m64 -march=barcelona -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -m64 -march=core2 -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -m64 -march=core2 -O3 -fomit-frame-pointer2014052620140525
2523opensslgcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -m64 -march=corei7 -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -m64 -march=k8 -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2014052620140525
2523opensslgcc -m64 -march=nocona -O3 -fomit-frame-pointer2014052620140525
2523opensslgcc -march=barcelona -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -march=k8 -O2 -fomit-frame-pointer2014052620140525
2523opensslgcc -march=nocona -O2 -fomit-frame-pointer2014052620140525
2526opensslgcc -O -fomit-frame-pointer2014052620140525
2526opensslgcc -fno-schedule-insns -O -fomit-frame-pointer2014052620140525
2526opensslgcc -funroll-loops -O -fomit-frame-pointer2014052620140525
2526opensslgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2014052620140525
2526opensslgcc -funroll-loops -m64 -O -fomit-frame-pointer2014052620140525
2526opensslgcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer2014052620140525
2526opensslgcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer2014052620140525
2526opensslgcc -funroll-loops -march=barcelona -O -fomit-frame-pointer2014052620140525
2526opensslgcc -funroll-loops -march=k8 -O -fomit-frame-pointer2014052620140525
2526opensslgcc -funroll-loops -march=nocona -O -fomit-frame-pointer2014052620140525
2526opensslgcc -m64 -O -fomit-frame-pointer2014052620140525
2526opensslgcc -m64 -march=barcelona -O -fomit-frame-pointer2014052620140525
2526opensslgcc -m64 -march=core2 -O -fomit-frame-pointer2014052620140525
2526opensslgcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer2014052620140525
2526opensslgcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer2014052620140525
2526opensslgcc -m64 -march=corei7 -O -fomit-frame-pointer2014052620140525
2526opensslgcc -m64 -march=k8 -O -fomit-frame-pointer2014052620140525
2526opensslgcc -m64 -march=nocona -O -fomit-frame-pointer2014052620140525
2526opensslgcc -march=barcelona -O -fomit-frame-pointer2014052620140525
2526opensslgcc -march=k8 -O -fomit-frame-pointer2014052620140525
2526opensslgcc -march=nocona -O -fomit-frame-pointer2014052620140525
2529opensslgcc -march=barcelona -O3 -fomit-frame-pointer2014052620140525
2532opensslgcc -funroll-loops -m64 -O2 -fomit-frame-pointer2014052620140525
2532opensslgcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2014052620140525
2532opensslgcc -m64 -march=nocona -O2 -fomit-frame-pointer2014052620140525
2535opensslgcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer2014052620140525
2538opensslgcc -m64 -O3 -fomit-frame-pointer2014052620140525
2538opensslgcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer2014052620140525
2550opensslgcc -march=nocona -O3 -fomit-frame-pointer2014052620140525
2553opensslgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer2014052620140525
2553opensslgcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer2014052620140525
2553opensslgcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer2014052620140525
2562opensslgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer2014052620140525
2565opensslcc2014052620140525
2565opensslgcc2014052620140525
2565opensslgcc -funroll-loops2014052620140525
2586opensslgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2014052620140525
2637opensslgcc -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -fno-schedule-insns -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -funroll-loops -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -funroll-loops -m64 -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -funroll-loops -march=k8 -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -m64 -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -m64 -march=barcelona -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -m64 -march=core2 -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -m64 -march=corei7 -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -m64 -march=k8 -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -m64 -march=nocona -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -march=barcelona -Os -fomit-frame-pointer2014052620140525
2637opensslgcc -march=k8 -Os -fomit-frame-pointer2014052620140525
2649opensslgcc -march=nocona -Os -fomit-frame-pointer2014052620140525
2652opensslgcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer2014052620140525
2652opensslgcc -funroll-loops -march=nocona -Os -fomit-frame-pointer2014052620140525
2667opensslgcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2014052620140525
840315refgcc -m64 -march=nocona -O3 -fomit-frame-pointer2014052620140525
840318refgcc -march=nocona -O3 -fomit-frame-pointer2014052620140525
842484refgcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer2014052620140525
842493refgcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer2014052620140525
857493refgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2014052620140525
857499refgcc -funroll-loops -O3 -fomit-frame-pointer2014052620140525
857499refgcc -funroll-loops -m64 -O3 -fomit-frame-pointer2014052620140525
866892refgcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer2014052620140525
866913refgcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer2014052620140525
866931refgcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer2014052620140525
866949refgcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer2014052620140525
884100refgcc -m64 -march=core2 -O3 -fomit-frame-pointer2014052620140525
884931refgcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2014052620140525
884952refgcc -m64 -march=barcelona -O3 -fomit-frame-pointer2014052620140525
884952refgcc -march=barcelona -O3 -fomit-frame-pointer2014052620140525
885462refgcc -m64 -march=k8 -O3 -fomit-frame-pointer2014052620140525
885483refgcc -march=k8 -O3 -fomit-frame-pointer2014052620140525
889341refgcc -fno-schedule-insns -O3 -fomit-frame-pointer2014052620140525
889353refgcc -m64 -O3 -fomit-frame-pointer2014052620140525
889356refgcc -O3 -fomit-frame-pointer2014052620140525
1007889refgcc -funroll-loops -march=nocona -O -fomit-frame-pointer2014052620140525
1007892refgcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer2014052620140525
1008159refgcc -funroll-loops -O -fomit-frame-pointer2014052620140525
1008252refgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2014052620140525
1008270refgcc -funroll-loops -m64 -O -fomit-frame-pointer2014052620140525
1013088refgcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer2014052620140525
1013094refgcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer2014052620140525
1020462refgcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer2014052620140525
1020555refgcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer2014052620140525
1021002refgcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer2014052620140525
1021047refgcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer2014052620140525
1022922refgcc -funroll-loops -m64 -O2 -fomit-frame-pointer2014052620140525
1023063refgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2014052620140525
1023333refgcc -funroll-loops -O2 -fomit-frame-pointer2014052620140525
1058268refclang -O3 -fwrapv -mavx2 -fomit-frame-pointer2014071220140622
1061295refgcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer2014052620140525
1061328refgcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer2014052620140525
1061334refgcc -funroll-loops -march=barcelona -O -fomit-frame-pointer2014052620140525
1061349refgcc -funroll-loops -march=k8 -O -fomit-frame-pointer2014052620140525
1064250refclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer2014101420141014
1064268refclang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer2014101420141014
1064268refclang -O3 -fwrapv -mavx2 -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer2014071220140622
1087596refclang -O3 -fomit-frame-pointer2014071220140622
1960245refgcc -m64 -march=nocona -O -fomit-frame-pointer2014052620140525
1960278refgcc -march=nocona -O -fomit-frame-pointer2014052620140525
1960476refgcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer2014052620140525
1960506refgcc -m64 -O -fomit-frame-pointer2014052620140525
1961112refgcc -O -fomit-frame-pointer2014052620140525
1961124refgcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer2014052620140525
1961145refgcc -m64 -march=core2 -O -fomit-frame-pointer2014052620140525
1961169refgcc -m64 -march=corei7 -O -fomit-frame-pointer2014052620140525
1961175refgcc -fno-schedule-insns -O -fomit-frame-pointer2014052620140525
1966536refgcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2014052620140525
1966566refgcc -m64 -march=corei7 -O2 -fomit-frame-pointer2014052620140525
1966569refgcc -m64 -march=core2 -O2 -fomit-frame-pointer2014052620140525
1966596refgcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer2014052620140525
1974423refgcc -m64 -O2 -fomit-frame-pointer2014052620140525
1974429refgcc -fno-schedule-insns -O2 -fomit-frame-pointer2014052620140525
1974486refgcc -O2 -fomit-frame-pointer2014052620140525
1983372refgcc -march=nocona -O2 -fomit-frame-pointer2014052620140525
2007990refgcc -m64 -march=nocona -O2 -fomit-frame-pointer2014052620140525
2014992refgcc -m64 -march=barcelona -O2 -fomit-frame-pointer2014052620140525
2014995refgcc -march=barcelona -O2 -fomit-frame-pointer2014052620140525
2015397refgcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2014052620140525
2066217refgcc -march=barcelona -O -fomit-frame-pointer2014052620140525
2066226refgcc -m64 -march=native -mtune=native -O -fomit-frame-pointer2014052620140525
2066253refgcc -m64 -march=barcelona -O -fomit-frame-pointer2014052620140525
2093733refgcc -march=k8 -O -fomit-frame-pointer2014052620140525
2160870refgcc -m64 -march=k8 -O -fomit-frame-pointer2014052620140525
2180514refgcc -march=k8 -O2 -fomit-frame-pointer2014052620140525
2180661refgcc -m64 -march=k8 -O2 -fomit-frame-pointer2014052620140525
2461764refgcc -m64 -march=nocona -Os -fomit-frame-pointer2014052620140525
2461782refgcc -march=nocona -Os -fomit-frame-pointer2014052620140525
2466498refgcc -m64 -march=core2 -Os -fomit-frame-pointer2014052620140525
2466513refgcc -m64 -march=k8 -Os -fomit-frame-pointer2014052620140525
2466522refgcc -m64 -march=corei7 -Os -fomit-frame-pointer2014052620140525
2466528refgcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer2014052620140525
2466546refgcc -fno-schedule-insns -Os -fomit-frame-pointer2014052620140525
2466558refgcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer2014052620140525
2466561refgcc -march=barcelona -Os -fomit-frame-pointer2014052620140525
2466567refgcc -Os -fomit-frame-pointer2014052620140525
2466588refgcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer2014052620140525
2466597refgcc -march=k8 -Os -fomit-frame-pointer2014052620140525
2466627refgcc -m64 -march=barcelona -Os -fomit-frame-pointer2014052620140525
2466735refgcc -m64 -Os -fomit-frame-pointer2014052620140525
2780313refgcc -funroll-loops -march=nocona -Os -fomit-frame-pointer2014052620140525
2780694refgcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer2014052620140525
2801628refgcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer2014052620140525
2801895refgcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer2014052620140525
2802303refgcc -funroll-loops -march=k8 -Os -fomit-frame-pointer2014052620140525
2803293refgcc -funroll-loops -m64 -Os -fomit-frame-pointer2014052620140525
2803362refgcc -funroll-loops -Os -fomit-frame-pointer2014052620140525
2803530refgcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2014052620140525
2803662refgcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer2014052620140525
8212614refgcc2014052620140525
8212956refgcc -funroll-loops2014052620140525
8213127refcc2014052620140525

Compiler output

Implementation: crypto_core/aes256decrypt/openssl
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 openssl ref

Compiler output

Implementation: crypto_core/aes256decrypt/openssl
Compiler: clang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer
core.c: clang: warning: argument unused during compilation: '-mcpu=core-avx2'
core.c: clang: warning: argument unused during compilation: '-mavx2'
core.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: 2, namely:
CompilerImplementations
clang -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer openssl ref

Compiler output

Implementation: crypto_core/aes256decrypt/openssl
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
core.c: clang: warning: argument unused during compilation: '-mcpu=core-avx2'
core.c: clang: warning: argument unused during compilation: '-mavx2'
core.c: clang: warning: argument unused during compilation: '-mpclmul'
core.c: clang: warning: argument unused during compilation: '-fpolly'
core.c: clang: warning: argument unused during compilation: '-fvectorize'
core.c: clang: warning: argument unused during compilation: '-fslp-vectorize'
core.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: 2, 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 openssl ref

Compiler output

Implementation: crypto_core/aes256decrypt/openssl
Compiler: clang -O3 -fwrapv -mavx2 -fomit-frame-pointer
core.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: 2, namely:
CompilerImplementations
clang -O3 -fwrapv -mavx2 -fomit-frame-pointer openssl ref

Compiler output

Implementation: crypto_core/aes256decrypt/openssl
Compiler: clang -O3 -fwrapv -mavx2 -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer
core.c: clang: warning: argument unused during compilation: '-mavx2'
core.c: clang: warning: argument unused during compilation: '-fpolly'
core.c: clang: warning: argument unused during compilation: '-fvectorize'
core.c: clang: warning: argument unused during compilation: '-fslp-vectorize'
core.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: 2, namely:
CompilerImplementations
clang -O3 -fwrapv -mavx2 -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer openssl ref