Implementation notes: amd64, mangetsu, crypto_stream/aes192ctr

Computer: mangetsu
Architecture: amd64
CPU ID: GenuineIntel-000206a7-bfebfbff
SUPERCOP version: 20141014
Operation: crypto_stream
Primitive: aes192ctr
TimeImplementationCompilerBenchmark dateSUPERCOP version
4336cryptoppg++ -m64 -march=corei7 -O2 -fomit-frame-pointer2014091420140907
4340cryptoppg++ -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer2014091420140907
4344cryptoppg++ -m64 -O2 -fomit-frame-pointer2014091420140907
4356cryptoppg++ -O2 -fomit-frame-pointer2014091420140907
4356cryptoppg++ -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2014091420140907
4360cryptoppg++ -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2014091420140907
4364cryptoppg++ -march=k8 -O2 -fomit-frame-pointer2014091420140907
4372cryptoppg++ -m64 -march=barcelona -O3 -fomit-frame-pointer2014091420140907
4392cryptoppg++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2014091420140907
4392cryptoppg++ -m64 -march=nocona -O -fomit-frame-pointer2014091420140907
4396cryptoppg++ -m64 -march=corei7-avx -O3 -fomit-frame-pointer2014091420140907
4404cryptoppg++ -m64 -march=barcelona -O -fomit-frame-pointer2014091420140907
4404cryptoppg++ -m64 -march=k8 -O3 -fomit-frame-pointer2014091420140907
4408cryptoppg++ -m64 -march=core-avx-i -O2 -fomit-frame-pointer2014091420140907
4408cryptoppg++ -m64 -march=core-avx-i -O3 -fomit-frame-pointer2014091420140907
4408cryptoppg++ -m64 -march=core2 -O2 -fomit-frame-pointer2014091420140907
4408cryptoppg++ -m64 -march=k8 -O2 -fomit-frame-pointer2014091420140907
4408cryptoppg++ -m64 -march=nocona -O3 -fomit-frame-pointer2014091420140907
4408cryptoppg++ -march=nocona -O -fomit-frame-pointer2014091420140907
4412cryptoppclang++ -O3 -fwrapv -mavx -fomit-frame-pointer2014091420140907
4412cryptoppg++ -march=barcelona -O2 -fomit-frame-pointer2014091420140907
4412cryptoppg++ -march=k8 -O3 -fomit-frame-pointer2014091420140907
4416cryptoppg++ -m64 -march=k8 -O -fomit-frame-pointer2014091420140907
4424cryptoppg++ -march=nocona -O3 -fomit-frame-pointer2014091420140907
4428cryptoppclang++ -O3 -fomit-frame-pointer2014091420140907
4432cryptoppclang++ -O3 -fwrapv -mavx -maes -mpclmul -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer2014101820141014
4448cryptoppg++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2014091420140907
4456cryptoppg++ -m64 -march=core-avx-i -O -fomit-frame-pointer2014091420140907
4456cryptoppg++ -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer2014091420140907
4460cryptoppg++ -march=barcelona -O -fomit-frame-pointer2014091420140907
4464cryptoppclang++ -O3 -fwrapv -mavx -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer2014091420140907
4464cryptoppg++ -fno-schedule-insns -O -fomit-frame-pointer2014091420140907
4468cryptoppg++ -m64 -O -fomit-frame-pointer2014091420140907
4472cryptoppg++ -m64 -march=corei7-avx -O -fomit-frame-pointer2014091420140907
4472cryptoppg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2014091420140907
4472cryptoppg++ -march=k8 -O -fomit-frame-pointer2014091420140907
4476cryptoppg++ -O -fomit-frame-pointer2014091420140907
4476cryptoppg++ -m64 -march=corei7 -O -fomit-frame-pointer2014091420140907
4480cryptoppclang++ -O3 -fwrapv -march=native -fomit-frame-pointer2014091420140907
4480cryptoppg++ -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2014091420140907
4484cryptoppclang++ -O3 -fwrapv -march=native -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer2014091420140907
4484cryptoppclang++ -O3 -fwrapv -mavx2 -fomit-frame-pointer2014091420140907
4484cryptoppg++ -march=barcelona -O3 -fomit-frame-pointer2014091420140907
4488cryptoppg++ -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer2014091420140907
4492cryptoppclang++ -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer2014101820141014
4492cryptoppg++ -m64 -march=barcelona -O2 -fomit-frame-pointer2014091420140907
4492cryptoppg++ -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer2014091420140907
4492cryptoppg++ -m64 -march=corei7-avx -O2 -fomit-frame-pointer2014091420140907
4496cryptoppg++ -m64 -march=core2 -O3 -fomit-frame-pointer2014091420140907
4512cryptoppg++ -m64 -Os -fomit-frame-pointer2014091420140907
4512cryptoppg++ -m64 -march=corei7 -O3 -fomit-frame-pointer2014091420140907
4516cryptoppg++ -m64 -march=core2 -msse4 -Os -fomit-frame-pointer2014091420140907
4528cryptoppg++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2014091420140907
4532cryptoppg++ -m64 -march=native -mtune=native -O -fomit-frame-pointer2014091420140907
4536cryptoppg++ -Os -fomit-frame-pointer2014091420140907
4544cryptoppg++ -fno-schedule-insns -O3 -fomit-frame-pointer2014091420140907
4548cryptoppclang++ -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer2014101820141014
4552cryptoppg++ -march=barcelona -Os -fomit-frame-pointer2014091420140907
4556cryptoppg++ -march=nocona -O2 -fomit-frame-pointer2014091420140907
4556cryptoppg++ -march=nocona -Os -fomit-frame-pointer2014091420140907
4568cryptoppg++ -m64 -march=core2 -Os -fomit-frame-pointer2014091420140907
4568cryptoppg++ -march=k8 -Os -fomit-frame-pointer2014091420140907
4572cryptoppg++ -m64 -march=barcelona -Os -fomit-frame-pointer2014091420140907
4572cryptoppg++ -m64 -march=nocona -O2 -fomit-frame-pointer2014091420140907
4576cryptoppg++ -m64 -O3 -fomit-frame-pointer2014091420140907
4576cryptoppg++ -m64 -march=nocona -Os -fomit-frame-pointer2014091420140907
4580cryptoppg++ -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer2014091420140907
4596cryptoppg++ -fno-schedule-insns -Os -fomit-frame-pointer2014091420140907
4596cryptoppg++ -m64 -march=core2 -msse4 -O -fomit-frame-pointer2014091420140907
4608cryptoppg++ -O3 -fomit-frame-pointer2014091420140907
4624cryptoppg++ -m64 -march=core-avx-i -Os -fomit-frame-pointer2014091420140907
4624cryptoppg++ -m64 -march=corei7 -Os -fomit-frame-pointer2014091420140907
4644cryptoppg++ -m64 -march=corei7-avx -Os -fomit-frame-pointer2014091420140907
4664cryptoppg++ -m64 -march=native -mtune=native -Os -fomit-frame-pointer2014091420140907
4672cryptoppg++ -m64 -march=core2 -O -fomit-frame-pointer2014091420140907
4728cryptoppg++ -m64 -march=k8 -Os -fomit-frame-pointer2014091420140907
4752cryptoppg++ -fno-schedule-insns -O2 -fomit-frame-pointer2014091420140907
6280cryptoppg++2014091420140907

Test failure

Implementation: crypto_stream/aes192ctr/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/aes192ctr/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/aes.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/rijndael.h:7:
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/aes.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/rijndael.h:7:
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/aes192ctr/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/aes.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/rijndael.h:7:
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/aes.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20140907/supercop-data/mangetsu/amd64/include/cryptopp/rijndael.h:7:
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/aes192ctr/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/aes.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/rijndael.h:7:
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/aes.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/rijndael.h:7:
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/aes192ctr/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/aes.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/rijndael.h:7:
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/aes.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/rijndael.h:7:
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/aes192ctr/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/aes.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/rijndael.h:7:
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/aes.h:4:
stream.cpp: In file included from /home/benchmark/supercop-20141014/supercop-data/mangetsu/amd64/include/cryptopp/rijndael.h:7:
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