Implementation notes: aarch64, rockpi4, crypto_stream/ocelot2

Computer: rockpi4
Architecture: aarch64
CPU ID: unknown CPU ID
SUPERCOP version: 20190816
Operation: crypto_stream
Primitive: ocelot2

Compiler output

Implementation: ref
Security model: unknown
Compiler: clang++ -O3 -fomit-frame-pointer -Qunused-arguments
Counter.cpp: Counter.cpp:11:10: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
Counter.cpp: for (register int i = 0; i < _size; i++)
Counter.cpp: ^~~~~~~~~
Counter.cpp: Counter.cpp:27:10: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
Counter.cpp: for (register int i = 0; i < _size4; i++,pbytes++)
Counter.cpp: ^~~~~~~~~
Counter.cpp: 2 warnings generated.
Ocelot2.cpp: In file included from Ocelot2.cpp:3:
Ocelot2.cpp: ./Ocelot2.h:118:14: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
Ocelot2.cpp: for (register int i = 0; i < n; i++)
Ocelot2.cpp: ^~~~~~~~~
Ocelot2.cpp: ./Ocelot2.h:126:14: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
Ocelot2.cpp: for (register int i = 0; i < n; i++)
Ocelot2.cpp: ^~~~~~~~~
Ocelot2.cpp: ./Ocelot2.h:143:9: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
Ocelot2.cpp: register BYTE *p1, *p2;
Ocelot2.cpp: ^~~~~~~~~
Ocelot2.cpp: ./Ocelot2.h:143:9: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
Ocelot2.cpp: register BYTE *p1, *p2;
Ocelot2.cpp: ^~~~~~~~~
Ocelot2.cpp: ./Ocelot2.h:144:9: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
Ocelot2.cpp: register BYTE temp, v1, v2;
Ocelot2.cpp: ^~~~~~~~~
Ocelot2.cpp: ./Ocelot2.h:144:9: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
Ocelot2.cpp: register BYTE temp, v1, v2;
Ocelot2.cpp: ^~~~~~~~~
Ocelot2.cpp: ./Ocelot2.h:144:9: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
Ocelot2.cpp: register BYTE temp, v1, v2;
Ocelot2.cpp: ^~~~~~~~~
Ocelot2.cpp: ./Ocelot2.h:163:9: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
Ocelot2.cpp: register BYTE *p1, *p2;
Ocelot2.cpp: ^~~~~~~~~
Ocelot2.cpp: ...
stream.cpp: In file included from stream.cpp:3:
stream.cpp: ./Ocelot2.h:118:14: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
stream.cpp: for (register int i = 0; i < n; i++)
stream.cpp: ^~~~~~~~~
stream.cpp: ./Ocelot2.h:126:14: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
stream.cpp: for (register int i = 0; i < n; i++)
stream.cpp: ^~~~~~~~~
stream.cpp: ./Ocelot2.h:143:9: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
stream.cpp: register BYTE *p1, *p2;
stream.cpp: ^~~~~~~~~
stream.cpp: ./Ocelot2.h:143:9: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
stream.cpp: register BYTE *p1, *p2;
stream.cpp: ^~~~~~~~~
stream.cpp: ./Ocelot2.h:144:9: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
stream.cpp: register BYTE temp, v1, v2;
stream.cpp: ^~~~~~~~~
stream.cpp: ./Ocelot2.h:144:9: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
stream.cpp: register BYTE temp, v1, v2;
stream.cpp: ^~~~~~~~~
stream.cpp: ./Ocelot2.h:144:9: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
stream.cpp: register BYTE temp, v1, v2;
stream.cpp: ^~~~~~~~~
stream.cpp: ./Ocelot2.h:163:9: warning: 'register' storage class specifier is deprecated and incompatible with C++17 [-Wdeprecated-register]
stream.cpp: register BYTE *p1, *p2;
stream.cpp: ^~~~~~~~~
stream.cpp: ...

Number of similar (compiler,implementation) pairs: 5, namely:
CompilerImplementations
clang++ -O3 -fomit-frame-pointer -Qunused-arguments ref
clang++ -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments ref
clang++ -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments ref
clang++ -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments ref
clang++ -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref

Compiler output

Implementation: ref
Security model: unknown
Compiler: g++
stream.cpp: stream.cpp: In function 'int crypto_stream_ocelot2_ref(unsigned char*, long long unsigned int, const unsigned char*, const unsigned char*)':
stream.cpp: stream.cpp:12:18: error: 'crypto_stream_ocelot1_ref_KEYBYTES' was not declared in this scope
stream.cpp: Ocelot2 prng(k, crypto_stream_ocelot1_ref_KEYBYTES, Ocelot2::OCELOTSize32);
stream.cpp: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
stream.cpp: stream.cpp:12:18: note: suggested alternative: 'crypto_stream_ocelot2_ref_KEYBYTES'
stream.cpp: Ocelot2 prng(k, crypto_stream_ocelot1_ref_KEYBYTES, Ocelot2::OCELOTSize32);
stream.cpp: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
stream.cpp: crypto_stream_ocelot2_ref_KEYBYTES
stream.cpp: stream.cpp: In function 'int crypto_stream_ocelot2_ref_xor(unsigned char*, const unsigned char*, long long unsigned int, const unsigned char*, const unsigned char*)':
stream.cpp: stream.cpp:29:18: error: 'crypto_stream_ocelot1_ref_KEYBYTES' was not declared in this scope
stream.cpp: Ocelot2 prng(k, crypto_stream_ocelot1_ref_KEYBYTES, Ocelot2::OCELOTSize32);
stream.cpp: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
stream.cpp: stream.cpp:29:18: note: suggested alternative: 'crypto_stream_ocelot2_ref_KEYBYTES'
stream.cpp: Ocelot2 prng(k, crypto_stream_ocelot1_ref_KEYBYTES, Ocelot2::OCELOTSize32);
stream.cpp: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
stream.cpp: crypto_stream_ocelot2_ref_KEYBYTES

Number of similar (compiler,implementation) pairs: 17, namely:
CompilerImplementations
g++ ref
g++ -O2 -fomit-frame-pointer ref
g++ -O3 -fomit-frame-pointer ref
g++ -O -fomit-frame-pointer ref
g++ -Os -fomit-frame-pointer ref
g++ -fno-schedule-insns -O2 -fomit-frame-pointer ref
g++ -fno-schedule-insns -O3 -fomit-frame-pointer ref
g++ -fno-schedule-insns -O -fomit-frame-pointer ref
g++ -fno-schedule-insns -Os -fomit-frame-pointer ref
g++ -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer ref
g++ -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer ref
g++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer ref
g++ -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer ref
g++ -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv ref
g++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv ref
g++ -march=native -mtune=native -O -fomit-frame-pointer -fwrapv ref
g++ -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv ref