Implementation notes: mipso32, h1mips, crypto_dh/claus

Computer: h1mips
Architecture: mipso32
CPU ID: unknown CPU ID
SUPERCOP version: 20140622
Operation: crypto_dh
Primitive: claus
TimeImplementationCompilerBenchmark dateSUPERCOP version
198244676opensslgcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer2014060520140525
198253700opensslgcc -fno-schedule-insns -O2 -fomit-frame-pointer2014060520140525
198261244opensslgcc -funroll-loops2014060520140525
198263136opensslgcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer2014060520140525
198263676opensslgcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer2014060520140525
198264296opensslgcc -fno-schedule-insns -O -fomit-frame-pointer2014060520140525
198269254opensslgcc -funroll-loops -mabi=32 -O3 -fomit-frame-pointer2014060520140525
198270248opensslcc2014060520140525
198273252opensslgcc -funroll-loops -O2 -fomit-frame-pointer2014060520140525
198273364opensslgcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer2014060520140525
198276348opensslgcc -fno-schedule-insns -Os -fomit-frame-pointer2014060520140525
198279080opensslgcc -funroll-loops -O -fomit-frame-pointer2014060520140525
198280792opensslgcc -funroll-loops -Os -fomit-frame-pointer2014060520140525
198282248opensslgcc -O -fomit-frame-pointer2014060520140525
198283106opensslgcc -funroll-loops -O3 -fomit-frame-pointer2014060520140525
198284464opensslgcc -funroll-loops -mabi=32 -O -fomit-frame-pointer2014060520140525
198284908opensslgcc -mabi=32 -Os -fomit-frame-pointer2014060520140525
198285984opensslgcc -O2 -fomit-frame-pointer2014060520140525
198286020opensslgcc -mabi=32 -O3 -fomit-frame-pointer2014060520140525
198291080opensslgcc -Os -fomit-frame-pointer2014060520140525
198291636opensslgcc -funroll-loops -mabi=32 -O2 -fomit-frame-pointer2014060520140525
198295456opensslgcc -mabi=32 -O2 -fomit-frame-pointer2014060520140525
198295796opensslgcc -O3 -fomit-frame-pointer2014060520140525
198306176opensslgcc -funroll-loops -mabi=32 -Os -fomit-frame-pointer2014060520140525
198309872opensslgcc2014060520140525
198312256opensslgcc -mabi=32 -O -fomit-frame-pointer2014060520140525
198333648opensslgcc -fno-schedule-insns -O3 -fomit-frame-pointer2014060520140525

Compiler output

Implementation: crypto_dh/claus/openssl
Compiler: clang -O3 -fomit-frame-pointer
keypair.c: clang: warning: unknown platform, assuming -mfloat-abi=soft
keypair.c: In file included from keypair.c:2:
keypair.c: In file included from /usr/include/openssl/bn.h:77:
keypair.c: In file included from /usr/include/stdio.h:36:
keypair.c: /usr/include/bits/types.h:129:3: error: #error
keypair.c: # error
keypair.c: ^
keypair.c: /usr/include/bits/types.h:134:1: error: unknown type name '__STD_TYPE'
keypair.c: __STD_TYPE __DEV_T_TYPE __dev_t; /* Type of device numbers. */
keypair.c: ^
keypair.c: /usr/include/bits/types.h:134:25: error: invalid token after top level declarator
keypair.c: __STD_TYPE __DEV_T_TYPE __dev_t; /* Type of device numbers. */
keypair.c: ^
keypair.c: /usr/include/bits/types.h:135:1: error: unknown type name '__STD_TYPE'
keypair.c: __STD_TYPE __UID_T_TYPE __uid_t; /* Type of user identifications. */
keypair.c: ^
keypair.c: /usr/include/bits/types.h:135:12: error: expected identifier or '('
keypair.c: __STD_TYPE __UID_T_TYPE __uid_t; /* Type of user identifications. */
keypair.c: ^
keypair.c: In file included from keypair.c:2:
keypair.c: In file included from /usr/include/openssl/bn.h:77:
keypair.c: In file included from /usr/include/stdio.h:36:
keypair.c: In file included from /usr/include/bits/types.h:131:
keypair.c: /usr/include/bits/typesizes.h:31:23: note: instantiated from:
keypair.c: #define __UID_T_TYPE __U32_TYPE
keypair.c: ...

Number of similar (compiler,implementation) pairs: 15, namely:
CompilerImplementations
clang -O3 -fomit-frame-pointer openssl
clang -O3 -fwrapv -march=armv7-a -mfloat-abi=hard -mfpu=neon -fomit-frame-pointer openssl
clang -O3 -fwrapv -march=armv7-a -mfloat-abi=hard -mfpu=neon -fomit-frame-pointer -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive openssl
clang -O3 -fwrapv -march=armv7-a -mfloat-abi=hard -mfpu=vfpv3-d16 -fomit-frame-pointer openssl
clang -O3 -fwrapv -march=armv7-a -mfloat-abi=hard -mfpu=vfpv3-d16 -fomit-frame-pointer -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive openssl
clang -O3 -fwrapv -march=armv7-a -mfloat-abi=softfp -mfpu=neon -fomit-frame-pointer openssl
clang -O3 -fwrapv -march=armv7-a -mfloat-abi=softfp -mfpu=neon -fomit-frame-pointer -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive openssl
clang -O3 -fwrapv -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -fomit-frame-pointer openssl
clang -O3 -fwrapv -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -fomit-frame-pointer -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive openssl
clang -O3 -fwrapv -march=native -fomit-frame-pointer openssl
clang -O3 -fwrapv -march=native -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer openssl
clang -O3 -fwrapv -mavx2 -fomit-frame-pointer openssl
clang -O3 -fwrapv -mavx2 -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer openssl
clang -O3 -fwrapv -mavx -fomit-frame-pointer openssl
clang -O3 -fwrapv -mavx -fpolly -funroll-loops -fvectorize -fslp-vectorize -fslp-vectorize-aggressive -fomit-frame-pointer openssl

Compiler output

Implementation: crypto_dh/claus/gmp
Compiler: g++
keypair.cpp: keypair.cpp:1:19: error: gmpxx.h: No such file or directory
keypair.cpp: keypair.cpp: In function 'int crypto_dh_claus_gmp_keypair(unsigned char*, unsigned char*)':
keypair.cpp: keypair.cpp:17: error: 'mpz_class' was not declared in this scope
keypair.cpp: keypair.cpp:17: error: expected ';' before 'p'
keypair.cpp: keypair.cpp:18: error: expected ';' before 'a'
keypair.cpp: keypair.cpp:19: error: expected ';' before 'base'
keypair.cpp: keypair.cpp:20: error: expected ';' before 'result'
keypair.cpp: keypair.cpp:21: error: 'a' was not declared in this scope
keypair.cpp: keypair.cpp:21: error: 'mpz_import' was not declared in this scope
keypair.cpp: keypair.cpp:22: error: 'p' was not declared in this scope
keypair.cpp: keypair.cpp:23: error: 'base' was not declared in this scope
keypair.cpp: keypair.cpp:24: error: 'result' was not declared in this scope
keypair.cpp: keypair.cpp:24: error: 'mpz_powm' was not declared in this scope
keypair.cpp: keypair.cpp:25: error: 'mpz_sizeinbase' was not declared in this scope
keypair.cpp: keypair.cpp:26: error: 'mpz_export' was not declared in this scope

Number of similar (compiler,implementation) pairs: 13, namely:
CompilerImplementations
g++ gmp
g++ -O2 -fomit-frame-pointer gmp
g++ -O3 -fomit-frame-pointer gmp
g++ -O -fomit-frame-pointer gmp
g++ -Os -fomit-frame-pointer gmp
g++ -fno-schedule-insns -O2 -fomit-frame-pointer gmp
g++ -fno-schedule-insns -O3 -fomit-frame-pointer gmp
g++ -fno-schedule-insns -O -fomit-frame-pointer gmp
g++ -fno-schedule-insns -Os -fomit-frame-pointer gmp
g++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer gmp
g++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer gmp
g++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer gmp
g++ -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer gmp

Compiler output

Implementation: crypto_dh/claus/ntl
Compiler: g++
keypair.cpp: keypair.cpp:1:20: error: NTL/ZZ.h: No such file or directory
keypair.cpp: keypair.cpp:2: error: 'NTL' is not a namespace-name
keypair.cpp: keypair.cpp:2: error: expected namespace-name before ';' token
keypair.cpp: keypair.cpp: In function 'int crypto_dh_claus_ntl_keypair(unsigned char*, unsigned char*)':
keypair.cpp: keypair.cpp:18: error: 'ZZ' was not declared in this scope
keypair.cpp: keypair.cpp:18: error: expected ';' before 'a'
keypair.cpp: keypair.cpp:19: error: expected ';' before 'p'
keypair.cpp: keypair.cpp:20: error: expected ';' before 'base'
keypair.cpp: keypair.cpp:21: error: expected ';' before 'result'
keypair.cpp: keypair.cpp:22: error: 'base' was not declared in this scope
keypair.cpp: keypair.cpp:23: error: 'a' was not declared in this scope
keypair.cpp: keypair.cpp:23: error: 'ZZFromBytes' was not declared in this scope
keypair.cpp: keypair.cpp:24: error: 'p' was not declared in this scope
keypair.cpp: keypair.cpp:24: error: 'conv' was not declared in this scope
keypair.cpp: keypair.cpp:25: error: 'result' was not declared in this scope
keypair.cpp: keypair.cpp:25: error: 'PowerMod' was not declared in this scope
keypair.cpp: keypair.cpp:26: error: 'BytesFromZZ' was not declared in this scope

Number of similar (compiler,implementation) pairs: 13, namely:
CompilerImplementations
g++ ntl
g++ -O2 -fomit-frame-pointer ntl
g++ -O3 -fomit-frame-pointer ntl
g++ -O -fomit-frame-pointer ntl
g++ -Os -fomit-frame-pointer ntl
g++ -fno-schedule-insns -O2 -fomit-frame-pointer ntl
g++ -fno-schedule-insns -O3 -fomit-frame-pointer ntl
g++ -fno-schedule-insns -O -fomit-frame-pointer ntl
g++ -fno-schedule-insns -Os -fomit-frame-pointer ntl
g++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer ntl
g++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer ntl
g++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer ntl
g++ -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer ntl

Compiler output

Implementation: crypto_dh/claus/cryptopp
Compiler: g++
keypair.cpp: keypair.cpp:1:25: error: cryptopp/dh.h: No such file or directory
keypair.cpp: keypair.cpp:8: error: 'CryptoPP' is not a namespace-name
keypair.cpp: keypair.cpp:8: error: expected namespace-name before ';' token
keypair.cpp: keypair.cpp: In function 'int crypto_dh_claus_cryptopp_keypair(unsigned char*, unsigned char*)':
keypair.cpp: keypair.cpp:16: error: 'Integer' does not name a type
keypair.cpp: keypair.cpp:17: error: 'Integer' does not name a type
keypair.cpp: keypair.cpp:18: error: 'Integer' was not declared in this scope
keypair.cpp: keypair.cpp:18: error: expected ';' before 'a'
keypair.cpp: keypair.cpp:19: error: expected ';' before 'result'
keypair.cpp: keypair.cpp:20: error: 'result' was not declared in this scope

Number of similar (compiler,implementation) pairs: 13, namely:
CompilerImplementations
g++ cryptopp
g++ -O2 -fomit-frame-pointer cryptopp
g++ -O3 -fomit-frame-pointer cryptopp
g++ -O -fomit-frame-pointer cryptopp
g++ -Os -fomit-frame-pointer cryptopp
g++ -fno-schedule-insns -O2 -fomit-frame-pointer cryptopp
g++ -fno-schedule-insns -O3 -fomit-frame-pointer cryptopp
g++ -fno-schedule-insns -O -fomit-frame-pointer cryptopp
g++ -fno-schedule-insns -Os -fomit-frame-pointer cryptopp
g++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer cryptopp
g++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer cryptopp
g++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer cryptopp
g++ -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer cryptopp