Test results for amd64, trident, crypto_sign/rainbow6440

[Page version: 20241027 17:25:10]

Measurements for amd64, trident, crypto_sign Test results for amd64, trident, crypto_sign Test results for crypto_sign/rainbow6440
Computer: trident
Microarchitecture: amd64; Core 2 65nm (6fb)
Architecture: amd64
CPU ID: GenuineIntel-000006fb-bfebfbff
SUPERCOP version: 20241022
Operation: crypto_sign
Primitive: rainbow6440
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
26338717761 0 036443 852 1816T:refg++ -march=native -mtune=native -O -fwrapv -fPIC -fPIE -gdwarf-4 -Wall2024071420240625

Compiler output


rainbow_w-test.cpp: In file included from rainbow_w-test.cpp:6:
rainbow_w-test.cpp: In file included from ./rainbow_w.h:7:
rainbow_w-test.cpp: In file included from ./bqas.h:79:
rainbow_w-test.cpp: ./transpose8.h:38:2: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
rainbow_w-test.cpp:         register __m128i a=s[0],b=s[1],c=s[2],d=s[3],e=s[4],f=s[5],g=s[6],h=s[7];
rainbow_w-test.cpp:         ^~~~~~~~~
rainbow_w-test.cpp: ./transpose8.h:38:2: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
rainbow_w-test.cpp:         register __m128i a=s[0],b=s[1],c=s[2],d=s[3],e=s[4],f=s[5],g=s[6],h=s[7];
rainbow_w-test.cpp:         ^~~~~~~~~
rainbow_w-test.cpp: ./transpose8.h:38:2: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
rainbow_w-test.cpp:         register __m128i a=s[0],b=s[1],c=s[2],d=s[3],e=s[4],f=s[5],g=s[6],h=s[7];
rainbow_w-test.cpp:         ^~~~~~~~~
rainbow_w-test.cpp: ./transpose8.h:38:2: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
rainbow_w-test.cpp:         register __m128i a=s[0],b=s[1],c=s[2],d=s[3],e=s[4],f=s[5],g=s[6],h=s[7];
rainbow_w-test.cpp:         ^~~~~~~~~
rainbow_w-test.cpp: ./transpose8.h:38:2: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
rainbow_w-test.cpp:         register __m128i a=s[0],b=s[1],c=s[2],d=s[3],e=s[4],f=s[5],g=s[6],h=s[7];
rainbow_w-test.cpp:         ^~~~~~~~~
rainbow_w-test.cpp: ./transpose8.h:38:2: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
rainbow_w-test.cpp:         register __m128i a=s[0],b=s[1],c=s[2],d=s[3],e=s[4],f=s[5],g=s[6],h=s[7];
rainbow_w-test.cpp:         ^~~~~~~~~
rainbow_w-test.cpp: ./transpose8.h:38:2: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
rainbow_w-test.cpp:         register __m128i a=s[0],b=s[1],c=s[2],d=s[3],e=s[4],f=s[5],g=s[6],h=s[7];
rainbow_w-test.cpp:         ^~~~~~~~~
rainbow_w-test.cpp: ./transpose8.h:38:2: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
rainbow_w-test.cpp: ...

Number of similar (implementation,compiler) pairs: 4, namely:
ImplementationCompiler
T:refclang++ -march=native -O2 -fwrapv -Qunused-arguments -fPIC -fPIE -gdwarf-4 -Wall (Debian_Clang_11.0.1)
T:refclang++ -march=native -O3 -fwrapv -Qunused-arguments -fPIC -fPIE -gdwarf-4 -Wall (Debian_Clang_11.0.1)
T:refclang++ -march=native -O -fwrapv -Qunused-arguments -fPIC -fPIE -gdwarf-4 -Wall
T:refclang++ -march=native -Os -fwrapv -Qunused-arguments -fPIC -fPIE -gdwarf-4 -Wall (Debian_Clang_11.0.1)

Compiler output


rainbow_w-test.cpp: In file included from rainbow_w-test.cpp:6:
rainbow_w-test.cpp: rainbow_w.h: In instantiation of 'static int rainbow_w_64_40<p>::pri_map(VEC<p, 64>*, const uint8*, const VEC<p, 40>*) [with unsigned int p = 31; uint8 = unsigned char]':
rainbow_w-test.cpp: rainbow_w-test.cpp:68:7:   required from here
rainbow_w-test.cpp: rainbow_w.h:558:8: warning: 'void* memcpy(void*, const void*, size_t)' writing to an object of type 'struct MLPS<31, 64, 64>' with no trivial copy-assignment; use copy-assignment or copy-initialization instead [-Wclass-memaccess]
rainbow_w-test.cpp:   558 |  memcpy( & s_inv , pri_key , sizeof(MLPS<p,l_msg,l_msg>) );
rainbow_w-test.cpp:       |  ~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
rainbow_w-test.cpp: In file included from rainbow_w.h:7,
rainbow_w-test.cpp:                  from rainbow_w-test.cpp:6:
rainbow_w-test.cpp: bqas.h:32:54: note: 'struct MLPS<31, 64, 64>' declared here
rainbow_w-test.cpp:    32 | template <unsigned p, unsigned m, unsigned n> struct MLPS : public VEC<p, m>{
rainbow_w-test.cpp:       |                                                      ^~~~
rainbow_w-test.cpp: In file included from rainbow_w-test.cpp:6:
rainbow_w-test.cpp: rainbow_w.h:559:8: warning: 'void* memcpy(void*, const void*, size_t)' writing to an object of type 'struct MLPS<31, 40, 40>' with no trivial copy-assignment; use copy-assignment or copy-initialization instead [-Wclass-memaccess]
rainbow_w-test.cpp:   559 |  memcpy( & t_inv , pri_key + sizeof(MLPS<p,l_msg,l_msg>) , sizeof(MLPS<p,l_sec,l_sec>) );
rainbow_w-test.cpp:       |  ~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
rainbow_w-test.cpp: In file included from rainbow_w.h:7,
rainbow_w-test.cpp:                  from rainbow_w-test.cpp:6:
rainbow_w-test.cpp: bqas.h:32:54: note: 'struct MLPS<31, 40, 40>' declared here
rainbow_w-test.cpp:    32 | template <unsigned p, unsigned m, unsigned n> struct MLPS : public VEC<p, m>{
rainbow_w-test.cpp:       |                                                      ^~~~
rainbow_w-test.cpp: In file included from rainbow_w-test.cpp:6:
rainbow_w-test.cpp: rainbow_w.h: In instantiation of 'static void rainbow_w_64_40<p>::pub_map(VEC<p, 40>*, const uint8*, const VEC<p, 64>*) [with unsigned int p = 31; uint8 = unsigned char]':
rainbow_w-test.cpp: rainbow_w-test.cpp:123:7:   required from here
rainbow_w-test.cpp: rainbow_w.h:549:8: warning: 'void* memcpy(void*, const void*, size_t)' writing to an object of type 'struct MQPSv3<31, 40, 64>' with no trivial copy-assignment; use copy-assignment or copy-initialization instead [-Wclass-memaccess]
rainbow_w-test.cpp:   549 |  memcpy( &poly , pub_key , sizeof( poly ));
rainbow_w-test.cpp: ...

Number of similar (implementation,compiler) pairs: 3, namely:
ImplementationCompiler
T:refg++ -march=native -mtune=native -O2 -fwrapv -fPIC -fPIE -gdwarf-4 -Wall (10.2.1_20210110)
T:refg++ -march=native -mtune=native -O3 -fwrapv -fPIC -fPIE -gdwarf-4 -Wall (10.2.1_20210110)
T:refg++ -march=native -mtune=native -Os -fwrapv -fPIC -fPIE -gdwarf-4 -Wall (10.2.1_20210110)

Compiler output


rainbow_w-test.cpp: In file included from rainbow_w-test.cpp:6:
rainbow_w-test.cpp: rainbow_w.h: In instantiation of 'static int rainbow_w_64_40<p>::pri_map(VEC<p, 64>*, const uint8*, const VEC<p, 40>*) [with unsigned int p = 31; uint8 = unsigned char]':
rainbow_w-test.cpp: rainbow_w-test.cpp:68:7:   required from here
rainbow_w-test.cpp: rainbow_w.h:558:8: warning: 'void* memcpy(void*, const void*, size_t)' writing to an object of type 'struct MLPS<31, 64, 64>' with no trivial copy-assignment; use copy-assignment or copy-initialization instead [-Wclass-memaccess]
rainbow_w-test.cpp:   558 |  memcpy( & s_inv , pri_key , sizeof(MLPS<p,l_msg,l_msg>) );
rainbow_w-test.cpp:       |  ~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
rainbow_w-test.cpp: In file included from rainbow_w.h:7,
rainbow_w-test.cpp:                  from rainbow_w-test.cpp:6:
rainbow_w-test.cpp: bqas.h:32:54: note: 'struct MLPS<31, 64, 64>' declared here
rainbow_w-test.cpp:    32 | template <unsigned p, unsigned m, unsigned n> struct MLPS : public VEC<p, m>{
rainbow_w-test.cpp:       |                                                      ^~~~
rainbow_w-test.cpp: In file included from rainbow_w-test.cpp:6:
rainbow_w-test.cpp: rainbow_w.h:559:8: warning: 'void* memcpy(void*, const void*, size_t)' writing to an object of type 'struct MLPS<31, 40, 40>' with no trivial copy-assignment; use copy-assignment or copy-initialization instead [-Wclass-memaccess]
rainbow_w-test.cpp:   559 |  memcpy( & t_inv , pri_key + sizeof(MLPS<p,l_msg,l_msg>) , sizeof(MLPS<p,l_sec,l_sec>) );
rainbow_w-test.cpp:       |  ~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
rainbow_w-test.cpp: In file included from rainbow_w.h:7,
rainbow_w-test.cpp:                  from rainbow_w-test.cpp:6:
rainbow_w-test.cpp: bqas.h:32:54: note: 'struct MLPS<31, 40, 40>' declared here
rainbow_w-test.cpp:    32 | template <unsigned p, unsigned m, unsigned n> struct MLPS : public VEC<p, m>{
rainbow_w-test.cpp:       |                                                      ^~~~
rainbow_w-test.cpp: In file included from rainbow_w-test.cpp:6:
rainbow_w-test.cpp: rainbow_w.h: In instantiation of 'static void rainbow_w_64_40<p>::pub_map(VEC<p, 40>*, const uint8*, const VEC<p, 64>*) [with unsigned int p = 31; uint8 = unsigned char]':
rainbow_w-test.cpp: rainbow_w-test.cpp:123:7:   required from here
rainbow_w-test.cpp: rainbow_w.h:549:8: warning: 'void* memcpy(void*, const void*, size_t)' writing to an object of type 'struct MQPSv3<31, 40, 64>' with no trivial copy-assignment; use copy-assignment or copy-initialization instead [-Wclass-memaccess]
rainbow_w-test.cpp:   549 |  memcpy( &poly , pub_key , sizeof( poly ));
rainbow_w-test.cpp: ...
usehash.cpp: usehash.cpp: In function 'int crypto_sign_rainbow6440_ref_timingleaks(unsigned char*, long long unsigned int*, const unsigned char*, long long unsigned int, const unsigned char*)':
usehash.cpp: usehash.cpp:39:16: warning: comparison of integer expressions of different signedness: 'int' and 'long long unsigned int' [-Wsign-compare]
usehash.cpp:    39 |   for (i = 0;i < mlen;++i) {
usehash.cpp:       |              ~~^~~~~~
usehash.cpp: usehash.cpp: In function 'int crypto_sign_rainbow6440_ref_timingleaks_open(unsigned char*, long long unsigned int*, const unsigned char*, long long unsigned int, const unsigned char*)':
usehash.cpp: usehash.cpp:59:30: warning: comparison of integer expressions of different signedness: 'int' and 'long long unsigned int' [-Wsign-compare]
usehash.cpp:    59 |   for (i = SIGNATURE_BYTES;i < smlen;++i) m[i - SIGNATURE_BYTES] = sm[i];
usehash.cpp:       |                            ~~^~~~~~~

Number of similar (implementation,compiler) pairs: 1, namely:
ImplementationCompiler
T:refg++ -march=native -mtune=native -O -fwrapv -fPIC -fPIE -gdwarf-4 -Wall (10.2.1_20210110)