Implementation notes: amd64, speed2supercop, crypto_aead/twine80n6clocv1

Computer: speed2supercop
Microarchitecture: amd64; Haswell+AES (306c3)
Architecture: amd64
CPU ID: GenuineIntel-000306c3-1fc9cbf5
SUPERCOP version: 20240625
Operation: crypto_aead
Primitive: twine80n6clocv1
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
6274888105 0 28823908 760 1216T:refgcc_-march=native_-mtune=native_-O3_-fwrapv_-fPIC_-fPIE_-gdwarf-4_-Wall2024070320240625
6349406919 0 28820756 760 1216T:refgcc_-march=native_-mtune=native_-O2_-fwrapv_-fPIC_-fPIE_-gdwarf-4_-Wall2024070320240625
6386326460 0 28819995 752 1216T:refgcc_-march=native_-mtune=native_-O_-fwrapv_-fPIC_-fPIE_-gdwarf-4_-Wall2024070320240625
17946885798 0 28818135 736 1184T:refgcc_-march=native_-mtune=native_-Os_-fwrapv_-fPIC_-fPIE_-gdwarf-4_-Wall2024070320240625

Compiler output


cloc.c: cloc.c:64:3: error: call to undeclared function 'pstate2'; ISO C99 and later do not support implicit function declarations [-Wimplicit-function-declaration]
cloc.c:                 pstate2("After xoring associated data:", state);
cloc.c:                 ^
cloc.c: cloc.c:64:3: note: did you mean 'pstate'?
cloc.c: ./cloc.h:91:6: note: 'pstate' declared here
cloc.c: void pstate(const unsigned char* st, int len);
cloc.c:      ^
cloc.c: cloc.c:72:3: error: call to undeclared function 'pstate2'; ISO C99 and later do not support implicit function declarations [-Wimplicit-function-declaration]
cloc.c:                 pstate2("After processing last partial associated data block:", state);
cloc.c:                 ^
cloc.c: cloc.c:93:2: error: call to undeclared function 'pstate2'; ISO C99 and later do not support implicit function declarations [-Wimplicit-function-declaration]
cloc.c:         pstate2("After applying f1/f2 to state:", state);
cloc.c:         ^
cloc.c: cloc.c:133:4: error: call to undeclared function 'pstate2'; ISO C99 and later do not support implicit function declarations [-Wimplicit-function-declaration]
cloc.c:                         pstate2("After xoring message block:", es);
cloc.c:                         ^
cloc.c: cloc.c:138:4: error: call to undeclared function 'pstate2'; ISO C99 and later do not support implicit function declarations [-Wimplicit-function-declaration]
cloc.c:                         pstate2("After xoring ciphertext block:", es);
cloc.c:                         ^
cloc.c: cloc.c:145:3: error: call to undeclared function 'pstate2'; ISO C99 and later do not support implicit function declarations [-Wimplicit-function-declaration]
cloc.c:                 pstate2("After applying fix1:", es);
cloc.c:                 ^
cloc.c: cloc.c:154:3: error: call to undeclared function 'pstate2'; ISO C99 and later do not support implicit function declarations [-Wimplicit-function-declaration]
cloc.c:                 pstate2("After xoring last partial message block:", es);
cloc.c:                 ^
cloc.c: ...

Number of similar (implementation,compiler) pairs: 5, 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 (Debian_Clang_16.0.6_(27+b1))
T:refclang -mcpu=native -O3 -fwrapv -Qunused-arguments -fPIC -fPIE -gdwarf-4 -Wall (Debian_Clang_16.0.6_(27+b1))

Compiler output


cloc.c: cloc.c: In function 'process_ad':
cloc.c: cloc.c:64:17: warning: implicit declaration of function 'pstate2'; did you mean 'pstate'? [-Wimplicit-function-declaration]
cloc.c:    64 |                 pstate2("After xoring associated data:", state);
cloc.c:       |                 ^~~~~~~
cloc.c:       |                 pstate
encrypt.c: encrypt.c: In function 'crypto_aead_twine80n6clocv1_ref_timingleaks_decrypt':
encrypt.c: encrypt.c:71:5: warning: this 'for' clause does not guard... [-Wmisleading-indentation]
encrypt.c:    71 |     for(i = 0; i < CRYPTO_ABYTES; i++)
encrypt.c:       |     ^~~
encrypt.c: encrypt.c:76:9: note: ...this statement, but the latter is misleadingly indented as if it were guarded by the 'for'
encrypt.c:    76 |         return RETURN_SUCCESS;
encrypt.c:       |         ^~~~~~
twine.c: twine.c: In function 'Keyschedule':
twine.c: twine.c:451:17: warning: 'Keyschedule128' reading 32 bytes from a region of size 16 [-Wstringop-overread]
twine.c:   451 |                 Keyschedule128(sk);
twine.c:       |                 ^~~~~~~~~~~~~~~~~~
twine.c: twine.c:451:17: note: referencing argument 1 of type 'const uint8[32]' {aka 'const unsigned char[32]'}
twine.c: twine.c:317:6: note: in a call to function 'Keyschedule128'
twine.c:   317 | void Keyschedule128(const uint8 sk[128/4])
twine.c:       |      ^~~~~~~~~~~~~~

Number of similar (implementation,compiler) pairs: 4, namely:
ImplementationCompiler
T:refgcc -march=native -mtune=native -O2 -fwrapv -fPIC -fPIE -gdwarf-4 -Wall (13.3.0)
T:refgcc -march=native -mtune=native -O3 -fwrapv -fPIC -fPIE -gdwarf-4 -Wall (13.3.0)
T:refgcc -march=native -mtune=native -O -fwrapv -fPIC -fPIE -gdwarf-4 -Wall (13.3.0)
T:refgcc -march=native -mtune=native -Os -fwrapv -fPIC -fPIE -gdwarf-4 -Wall (13.3.0)