Test results for amd64, speed2supercop, crypto_sign/3icp

[Page version: 20241023 21:37:24]

Measurements for amd64, speed2supercop, crypto_sign Test results for amd64, speed2supercop, crypto_sign Test results for crypto_sign/3icp
Computer: speed2supercop
Microarchitecture: amd64; Haswell+AES (306c3)
Architecture: amd64
CPU ID: GenuineIntel-000306c3-1fc9cbf5
SUPERCOP version: 20241022
Operation: crypto_sign
Primitive: 3icp
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
62742057951 8 44878140 832 2112T:refg++ -march=native -mtune=native -O -fwrapv -fPIC -fPIE -gdwarf-4 -Wall2024101420241011

Test failure


error 111
crypto_sign_open returns nonzero

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

Test failure


error 142
Alarm clock

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

Compiler output


ThreeIC_p-test.cpp: In file included from ThreeIC_p-test.cpp:16:
ThreeIC_p-test.cpp: In file included from ./ThreeIC_p.h:5:
ThreeIC_p-test.cpp: In file included from ./bqas.h:79:
ThreeIC_p-test.cpp: ./transpose8.h:38:2: error: ISO C++17 does not allow 'register' storage class specifier [-Wregister]
ThreeIC_p-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];
ThreeIC_p-test.cpp:         ^~~~~~~~~
ThreeIC_p-test.cpp: ./transpose8.h:38:2: error: ISO C++17 does not allow 'register' storage class specifier [-Wregister]
ThreeIC_p-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];
ThreeIC_p-test.cpp:         ^~~~~~~~~
ThreeIC_p-test.cpp: ./transpose8.h:38:2: error: ISO C++17 does not allow 'register' storage class specifier [-Wregister]
ThreeIC_p-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];
ThreeIC_p-test.cpp:         ^~~~~~~~~
ThreeIC_p-test.cpp: ./transpose8.h:38:2: error: ISO C++17 does not allow 'register' storage class specifier [-Wregister]
ThreeIC_p-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];
ThreeIC_p-test.cpp:         ^~~~~~~~~
ThreeIC_p-test.cpp: ./transpose8.h:38:2: error: ISO C++17 does not allow 'register' storage class specifier [-Wregister]
ThreeIC_p-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];
ThreeIC_p-test.cpp:         ^~~~~~~~~
ThreeIC_p-test.cpp: ./transpose8.h:38:2: error: ISO C++17 does not allow 'register' storage class specifier [-Wregister]
ThreeIC_p-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];
ThreeIC_p-test.cpp:         ^~~~~~~~~
ThreeIC_p-test.cpp: ./transpose8.h:38:2: error: ISO C++17 does not allow 'register' storage class specifier [-Wregister]
ThreeIC_p-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];
ThreeIC_p-test.cpp:         ^~~~~~~~~
ThreeIC_p-test.cpp: ./transpose8.h:38:2: error: ISO C++17 does not allow 'register' storage class specifier [-Wregister]
ThreeIC_p-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_16.0.6_(27+b1))
T:refclang++ -march=native -O3 -fwrapv -Qunused-arguments -fPIC -fPIE -gdwarf-4 -Wall (Debian_Clang_16.0.6_(27+b1))
T:refclang++ -march=native -O -fwrapv -Qunused-arguments -fPIC -fPIE -gdwarf-4 -Wall (Debian_Clang_16.0.6_(27+b1))
T:refclang++ -march=native -Os -fwrapv -Qunused-arguments -fPIC -fPIE -gdwarf-4 -Wall

Compiler output


ThreeIC_p-test.cpp: In file included from gfv.h:4,
ThreeIC_p-test.cpp:                  from bqas.h:5,
ThreeIC_p-test.cpp:                  from ThreeIC_p.h:5,
ThreeIC_p-test.cpp:                  from ThreeIC_p-test.cpp:16:
ThreeIC_p-test.cpp: gf.h:14:21: warning: template-id not allowed for constructor in C++20 [-Wtemplate-id-cdtor]
ThreeIC_p-test.cpp:    14 |         inline gf<p>(){}
ThreeIC_p-test.cpp:       |                     ^
ThreeIC_p-test.cpp: gf.h:14:21: note: remove the '< >'
ThreeIC_p-test.cpp: gf.h:15:21: warning: template-id not allowed for constructor in C++20 [-Wtemplate-id-cdtor]
ThreeIC_p-test.cpp:    15 |         inline gf<p>(const gf<p>& a):v(a.v){}
ThreeIC_p-test.cpp:       |                     ^
ThreeIC_p-test.cpp: gf.h:15:21: note: remove the '< >'
ThreeIC_p-test.cpp: gf.h:16:21: warning: template-id not allowed for constructor in C++20 [-Wtemplate-id-cdtor]
ThreeIC_p-test.cpp:    16 |         inline gf<p>(const short &a):v(a){}
ThreeIC_p-test.cpp:       |                     ^
ThreeIC_p-test.cpp: gf.h:16:21: note: remove the '< >'
ThreeIC_p-test.cpp: gfv.h:10:22: warning: template-id not allowed for constructor in C++20 [-Wtemplate-id-cdtor]
ThreeIC_p-test.cpp:    10 |         inline gfv<p>(){}
ThreeIC_p-test.cpp:       |                      ^
ThreeIC_p-test.cpp: gfv.h:10:22: note: remove the '< >'
ThreeIC_p-test.cpp: gfv.h:11:22: warning: template-id not allowed for constructor in C++20 [-Wtemplate-id-cdtor]
ThreeIC_p-test.cpp:    11 |         inline gfv<p>(const gfv<p>& a):v(a.v){}
ThreeIC_p-test.cpp:       |                      ^
ThreeIC_p-test.cpp: gfv.h:11:22: note: remove the '< >'
ThreeIC_p-test.cpp: gfv.h:12:22: warning: template-id not allowed for constructor in C++20 [-Wtemplate-id-cdtor]
ThreeIC_p-test.cpp: ...
usehash.cpp: usehash.cpp: In function 'int crypto_sign_3icp_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_3icp_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: 4, namely:
ImplementationCompiler
T:refg++ -march=native -mtune=native -O2 -fwrapv -fPIC -fPIE -gdwarf-4 -Wall (14.2.0)
T:refg++ -march=native -mtune=native -O3 -fwrapv -fPIC -fPIE -gdwarf-4 -Wall (14.2.0)
T:refg++ -march=native -mtune=native -O -fwrapv -fPIC -fPIE -gdwarf-4 -Wall (14.2.0)
T:refg++ -march=native -mtune=native -Os -fwrapv -fPIC -fPIE -gdwarf-4 -Wall (14.2.0)