Implementation notes: amd64, mangetsu, crypto_stream/panama

Computer: mangetsu
Architecture: amd64
CPU ID: GenuineIntel-000206a7-bfebfbff
SUPERCOP version: 20141014
Operation: crypto_stream
Primitive: panama
TimeImplementationCompilerBenchmark dateSUPERCOP version
6320cryptoppg++ -O2 -fomit-frame-pointer2014091420140907
6320cryptoppg++ -fno-schedule-insns -O3 -fomit-frame-pointer2014091420140907
6320cryptoppg++ -m64 -march=corei7 -O3 -fomit-frame-pointer2014091420140907
6324cryptoppg++ -m64 -O2 -fomit-frame-pointer2014091420140907
6324cryptoppg++ -m64 -march=core2 -O2 -fomit-frame-pointer2014091420140907
6324cryptoppg++ -m64 -march=core2 -O3 -fomit-frame-pointer2014091420140907
6324cryptoppg++ -m64 -march=corei7 -O2 -fomit-frame-pointer2014091420140907
6332cryptoppg++ -m64 -O3 -fomit-frame-pointer2014091420140907
6336cryptoppg++ -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2014091420140907
6340cryptoppg++ -m64 -march=k8 -O3 -fomit-frame-pointer2014091420140907
6344cryptoppclang++ -O3 -fwrapv -mavx -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer2014091420140907
6344cryptoppg++ -m64 -march=core-avx-i -O3 -fomit-frame-pointer2014091420140907
6352cryptoppclang++ -O3 -fwrapv -march=native -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer2014091420140907
6352cryptoppg++ -O3 -fomit-frame-pointer2014091420140907
6352cryptoppg++ -m64 -march=barcelona -O -fomit-frame-pointer2014091420140907
6352cryptoppg++ -m64 -march=k8 -O2 -fomit-frame-pointer2014091420140907
6352cryptoppg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2014091420140907
6356cryptoppclang++ -O3 -fwrapv -mavx -maes -mpclmul -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer2014101820141014
6356cryptoppg++ -m64 -march=k8 -O -fomit-frame-pointer2014091420140907
6360cryptoppg++ -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer2014091420140907
6360cryptoppg++ -march=k8 -O3 -fomit-frame-pointer2014091420140907
6368cryptoppg++ -march=nocona -O -fomit-frame-pointer2014091420140907
6400cryptoppg++ -m64 -march=nocona -O3 -fomit-frame-pointer2014091420140907
6408cryptoppg++ -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer2014091420140907
6412cryptoppg++ -march=nocona -O3 -fomit-frame-pointer2014091420140907
6424cryptoppg++ -march=k8 -O -fomit-frame-pointer2014091420140907
6460cryptoppg++ -fno-schedule-insns -O2 -fomit-frame-pointer2014091420140907
6460cryptoppg++ -march=barcelona -O -fomit-frame-pointer2014091420140907
6476cryptoppg++ -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer2014091420140907
6476cryptoppg++ -march=k8 -O2 -fomit-frame-pointer2014091420140907
6480cryptoppg++ -m64 -march=corei7-avx -O3 -fomit-frame-pointer2014091420140907
6496cryptoppg++ -m64 -march=barcelona -O2 -fomit-frame-pointer2014091420140907
6496cryptoppg++ -m64 -march=core2 -O -fomit-frame-pointer2014091420140907
6496cryptoppg++ -m64 -march=nocona -O -fomit-frame-pointer2014091420140907
6500cryptoppclang++ -O3 -fwrapv -march=native -fomit-frame-pointer2014091420140907
6504cryptoppg++ -O -fomit-frame-pointer2014091420140907
6504cryptoppg++ -m64 -march=core2 -msse4 -O -fomit-frame-pointer2014091420140907
6508cryptoppg++ -m64 -march=native -mtune=native -O -fomit-frame-pointer2014091420140907
6516cryptoppclang++ -O3 -fomit-frame-pointer2014091420140907
6516cryptoppg++ -fno-schedule-insns -O -fomit-frame-pointer2014091420140907
6516cryptoppg++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2014091420140907
6516cryptoppg++ -m64 -march=corei7-avx -O -fomit-frame-pointer2014091420140907
6520cryptoppg++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2014091420140907
6524cryptoppclang++ -O3 -fwrapv -mavx -fomit-frame-pointer2014091420140907
6532cryptoppg++ -march=barcelona -O2 -fomit-frame-pointer2014091420140907
6536cryptoppg++ -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer2014091420140907
6544cryptoppg++ -m64 -march=core-avx-i -O2 -fomit-frame-pointer2014091420140907
6544cryptoppg++ -m64 -march=core-avx-i -O -fomit-frame-pointer2014091420140907
6552cryptoppg++ -march=barcelona -O3 -fomit-frame-pointer2014091420140907
6560cryptoppg++ -m64 -march=corei7-avx -O2 -fomit-frame-pointer2014091420140907
6564cryptoppg++ -m64 -march=corei7 -O -fomit-frame-pointer2014091420140907
6572cryptoppg++ -m64 -O -fomit-frame-pointer2014091420140907
6572cryptoppg++ -march=nocona -O2 -fomit-frame-pointer2014091420140907
6576cryptoppg++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2014091420140907
6580cryptoppg++ -m64 -march=nocona -O2 -fomit-frame-pointer2014091420140907
6588cryptoppclang++ -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer2014101820141014
6596cryptoppg++ -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2014091420140907
6640cryptoppclang++ -O3 -fwrapv -mavx2 -fomit-frame-pointer2014091420140907
6640cryptoppg++ -march=nocona -Os -fomit-frame-pointer2014091420140907
6648cryptoppg++ -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2014091420140907
6648cryptoppg++ -m64 -march=nocona -Os -fomit-frame-pointer2014091420140907
6652cryptoppclang++ -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer2014101820141014
6656cryptoppg++ -Os -fomit-frame-pointer2014091420140907
6672cryptoppg++ -m64 -march=corei7-avx -Os -fomit-frame-pointer2014091420140907
6676cryptoppg++ -m64 -march=core-avx-i -Os -fomit-frame-pointer2014091420140907
6676cryptoppg++ -m64 -march=k8 -Os -fomit-frame-pointer2014091420140907
6680cryptoppg++ -m64 -Os -fomit-frame-pointer2014091420140907
6688cryptoppg++ -march=barcelona -Os -fomit-frame-pointer2014091420140907
6696cryptoppg++ -m64 -march=native -mtune=native -Os -fomit-frame-pointer2014091420140907
6700cryptoppg++ -fno-schedule-insns -Os -fomit-frame-pointer2014091420140907
6704cryptoppg++ -m64 -march=barcelona -O3 -fomit-frame-pointer2014091420140907
6712cryptoppg++ -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer2014091420140907
6744cryptoppg++ -m64 -march=barcelona -Os -fomit-frame-pointer2014091420140907
6796cryptoppg++ -m64 -march=corei7 -Os -fomit-frame-pointer2014091420140907
6808cryptoppg++ -march=k8 -Os -fomit-frame-pointer2014091420140907
6852cryptoppg++ -m64 -march=core2 -msse4 -Os -fomit-frame-pointer2014091420140907
6872cryptoppg++ -m64 -march=core2 -Os -fomit-frame-pointer2014091420140907
7572cryptoppg++2014091420140907

Test failure

Implementation: crypto_stream/panama/cryptopp
Compiler: g++ -m64 -march=core-avx2 -O2 -fomit-frame-pointer
error 111

Number of similar (compiler,implementation) pairs: 3, namely:
CompilerImplementations
g++ -m64 -march=core-avx2 -O2 -fomit-frame-pointer cryptopp
g++ -m64 -march=core-avx2 -O -fomit-frame-pointer cryptopp
g++ -m64 -march=core-avx2 -Os -fomit-frame-pointer cryptopp

Compiler output

Implementation: crypto_stream/panama/cryptopp
Compiler: clang++ -O3 -fomit-frame-pointer
stream.cpp: In file included from stream.cpp:1:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/panama.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/strciphr.h:31:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/seckey.h:9:
stream.cpp: /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/misc.h:414:8: warning: comparison of unsigned expression stream.cpp: if (a stream.cpp: ~ ^ ~
stream.cpp: /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/simple.h:35:110: note: in instantiation of function template specialization 'CryptoPP::IntToStringgt;' requested here
stream.cpp: explicit InvalidKeyLength(const std::string &algorithm, size_t length) : InvalidArgument(algorithm + ": " + IntToString(length) + " is not a valid key length") {}
stream.cpp: ^
stream.cpp: In file included from stream.cpp:1:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/panama.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/strciphr.h:31:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/seckey.h:9:
stream.cpp: /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/misc.h:414:8: warning: comparison of unsigned expression stream.cpp: if (a stream.cpp: ~ ^ ~
stream.cpp: /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/simple.h:42:113: note: in instantiation of function template specialization 'CryptoPP::IntToStringgt;' requested here
stream.cpp: explicit InvalidRounds(const std::string &algorithm, unsigned int rounds) : InvalidArgument(algorithm + ": " + IntToString(rounds) + " is not a valid number of rounds") {}
stream.cpp: ^
stream.cpp: 2 warnings generated.

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
clang++ -O3 -fomit-frame-pointer cryptopp
clang++ -O3 -fwrapv -march=native -fomit-frame-pointer cryptopp
clang++ -O3 -fwrapv -mavx2 -fomit-frame-pointer cryptopp
clang++ -O3 -fwrapv -mavx -fomit-frame-pointer cryptopp

Compiler output

Implementation: crypto_stream/panama/cryptopp
Compiler: clang++ -O3 -fwrapv -march=native -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer
stream.cpp: clang-3.3: warning: argument unused during compilation: '-fpolly'
stream.cpp: In file included from stream.cpp:1:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/panama.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/strciphr.h:31:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/seckey.h:9:
stream.cpp: /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/misc.h:414:8: warning: comparison of unsigned expression stream.cpp: if (a stream.cpp: ~ ^ ~
stream.cpp: /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/simple.h:35:110: note: in instantiation of function template specialization 'CryptoPP::IntToStringgt;' requested here
stream.cpp: explicit InvalidKeyLength(const std::string &algorithm, size_t length) : InvalidArgument(algorithm + ": " + IntToString(length) + " is not a valid key length") {}
stream.cpp: ^
stream.cpp: In file included from stream.cpp:1:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/panama.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/strciphr.h:31:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/seckey.h:9:
stream.cpp: /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/misc.h:414:8: warning: comparison of unsigned expression stream.cpp: if (a stream.cpp: ~ ^ ~
stream.cpp: /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/simple.h:42:113: note: in instantiation of function template specialization 'CryptoPP::IntToStringgt;' requested here
stream.cpp: explicit InvalidRounds(const std::string &algorithm, unsigned int rounds) : InvalidArgument(algorithm + ": " + IntToString(rounds) + " is not a valid number of rounds") {}
stream.cpp: ^
stream.cpp: 2 warnings generated.

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

Compiler output

Implementation: crypto_stream/panama/cryptopp
Compiler: clang++ -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer
stream.cpp: clang-3.3: warning: argument unused during compilation: '-mcpu=core-avx2'
stream.cpp: In file included from stream.cpp:1:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/panama.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/strciphr.h:31:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/seckey.h:9:
stream.cpp: /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/misc.h:414:8: warning: comparison of unsigned expression stream.cpp: if (a stream.cpp: ~ ^ ~
stream.cpp: /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/simple.h:35:110: note: in instantiation of function template specialization 'CryptoPP::IntToStringgt;' requested here
stream.cpp: explicit InvalidKeyLength(const std::string &algorithm, size_t length) : InvalidArgument(algorithm + ": " + IntToString(length) + " is not a valid key length") {}
stream.cpp: ^
stream.cpp: In file included from stream.cpp:1:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/panama.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/strciphr.h:31:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/seckey.h:9:
stream.cpp: /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/misc.h:414:8: warning: comparison of unsigned expression stream.cpp: if (a stream.cpp: ~ ^ ~
stream.cpp: /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/simple.h:42:113: note: in instantiation of function template specialization 'CryptoPP::IntToStringgt;' requested here
stream.cpp: explicit InvalidRounds(const std::string &algorithm, unsigned int rounds) : InvalidArgument(algorithm + ": " + IntToString(rounds) + " is not a valid number of rounds") {}
stream.cpp: ^
stream.cpp: 2 warnings 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 cryptopp

Compiler output

Implementation: crypto_stream/panama/cryptopp
Compiler: clang++ -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer
stream.cpp: In file included from stream.cpp:1:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/panama.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/strciphr.h:31:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/seckey.h:9:
stream.cpp: /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/misc.h:414:8: warning: comparison of unsigned expression stream.cpp: if (a stream.cpp: ~ ^ ~
stream.cpp: /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/simple.h:35:110: note: in instantiation of function template specialization 'CryptoPP::IntToStringgt;' requested here
stream.cpp: explicit InvalidKeyLength(const std::string &algorithm, size_t length) : InvalidArgument(algorithm + ": " + IntToString(length) + " is not a valid key length") {}
stream.cpp: ^
stream.cpp: In file included from stream.cpp:1:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/panama.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/strciphr.h:31:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/seckey.h:9:
stream.cpp: /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/misc.h:414:8: warning: comparison of unsigned expression stream.cpp: if (a stream.cpp: ~ ^ ~
stream.cpp: /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/simple.h:42:113: note: in instantiation of function template specialization 'CryptoPP::IntToStringgt;' requested here
stream.cpp: explicit InvalidRounds(const std::string &algorithm, unsigned int rounds) : InvalidArgument(algorithm + ": " + IntToString(rounds) + " is not a valid number of rounds") {}
stream.cpp: ^
stream.cpp: 2 warnings generated.

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang++ -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer cryptopp

Compiler output

Implementation: crypto_stream/panama/cryptopp
Compiler: clang++ -O3 -fwrapv -mavx -maes -mpclmul -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer
stream.cpp: clang-3.3: warning: argument unused during compilation: '-fpolly'
stream.cpp: In file included from stream.cpp:1:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/panama.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/strciphr.h:31:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/seckey.h:9:
stream.cpp: /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/misc.h:414:8: warning: comparison of unsigned expression stream.cpp: if (a stream.cpp: ~ ^ ~
stream.cpp: /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/simple.h:35:110: note: in instantiation of function template specialization 'CryptoPP::IntToStringgt;' requested here
stream.cpp: explicit InvalidKeyLength(const std::string &algorithm, size_t length) : InvalidArgument(algorithm + ": " + IntToString(length) + " is not a valid key length") {}
stream.cpp: ^
stream.cpp: In file included from stream.cpp:1:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/panama.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/strciphr.h:31:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/seckey.h:9:
stream.cpp: /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/misc.h:414:8: warning: comparison of unsigned expression stream.cpp: if (a stream.cpp: ~ ^ ~
stream.cpp: /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/simple.h:42:113: note: in instantiation of function template specialization 'CryptoPP::IntToStringgt;' requested here
stream.cpp: explicit InvalidRounds(const std::string &algorithm, unsigned int rounds) : InvalidArgument(algorithm + ": " + IntToString(rounds) + " is not a valid number of rounds") {}
stream.cpp: ^
stream.cpp: 2 warnings generated.

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang++ -O3 -fwrapv -mavx -maes -mpclmul -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer cryptopp