Implementation notes: amd64, katana, crypto_dh/gls1271

Computer: katana
Architecture: amd64
CPU ID: GenuineIntel-000006f6-bfebfbff
SUPERCOP version: 20170105
Operation: crypto_dh
Primitive: gls1271
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
894288? ? ?? ? ?ref4gcc_-funroll-loops_-march=k8_-O2_-fomit-frame-pointer2016103020161009
895320? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-march=barcelona_-O2_-fomit-frame-pointer2016103020161009
895952? ? ?? ? ?ref4gcc_-march=k8_-O3_-fomit-frame-pointer2016103020161009
896184? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-O2_-fomit-frame-pointer2016103020161009
897088? ? ?? ? ?ref4gcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2016103020161009
897096? ? ?? ? ?ref4gcc_-m64_-march=k8_-O3_-fomit-frame-pointer2016103020161009
897520? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-march=k8_-O2_-fomit-frame-pointer2016103020161009
897712? ? ?? ? ?ref4gcc_-funroll-loops_-march=barcelona_-O2_-fomit-frame-pointer2016103020161009
900728? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-march=k8_-O3_-fomit-frame-pointer2016103020161009
901144? ? ?? ? ?ref4gcc_-funroll-loops_-march=k8_-O3_-fomit-frame-pointer2016103020161009
902064? ? ?? ? ?ref4gcc_-m64_-march=core2_-msse4_-O2_-fomit-frame-pointer2016103020161009
902208? ? ?? ? ?ref4gcc_-m64_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2016103020161009
902720? ? ?? ? ?ref4gcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2016103020161009
902968? ? ?? ? ?ref4gcc_-O3_-fomit-frame-pointer2016103020161009
903296? ? ?? ? ?ref4gcc_-m64_-march=native_-mtune=native_-O2_-fomit-frame-pointer2016103020161009
904264? ? ?? ? ?ref4gcc_-funroll-loops_-march=nocona_-O2_-fomit-frame-pointer2016103020161009
905024? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-march=nocona_-O2_-fomit-frame-pointer2016103020161009
905120? ? ?? ? ?ref4gcc_-m64_-march=native_-mtune=native_-O3_-fomit-frame-pointer2016103020161009
905768? ? ?? ? ?ref4gcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2016103020161009
906712? ? ?? ? ?ref4gcc_-march=nocona_-O3_-fomit-frame-pointer2016103020161009
906912? ? ?? ? ?ref4gcc_-march=k8_-O2_-fomit-frame-pointer2016103020161009
906968? ? ?? ? ?ref4gcc_-funroll-loops_-O3_-fomit-frame-pointer2016103020161009
907016? ? ?? ? ?ref4gcc_-m64_-march=k8_-O2_-fomit-frame-pointer2016103020161009
907072? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-O3_-fomit-frame-pointer2016103020161009
908512? ? ?? ? ?ref4gcc_-O2_-fomit-frame-pointer2016103020161009
908800? ? ?? ? ?ref4gcc_-m64_-march=barcelona_-O2_-fomit-frame-pointer2016103020161009
910840? ? ?? ? ?ref4gcc_-m64_-march=barcelona_-O3_-fomit-frame-pointer2016103020161009
910944? ? ?? ? ?ref4gcc_-march=nocona_-O2_-fomit-frame-pointer2016103020161009
911256? ? ?? ? ?ref4gcc_-m64_-march=nocona_-O2_-fomit-frame-pointer2016103020161009
911488? ? ?? ? ?ref4gcc_-m64_-march=corei7_-O2_-fomit-frame-pointer2016103020161009
912192? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-march=barcelona_-O3_-fomit-frame-pointer2016103020161009
915880? ? ?? ? ?ref4gcc_-march=barcelona_-O3_-fomit-frame-pointer2016103020161009
916056? ? ?? ? ?ref4gcc_-march=barcelona_-O2_-fomit-frame-pointer2016103020161009
918752? ? ?? ? ?ref4gcc_-m64_-march=core2_-O3_-fomit-frame-pointer2016103020161009
924264? ? ?? ? ?ref4gcc_-m64_-O2_-fomit-frame-pointer2016103020161009
926488? ? ?? ? ?ref4gcc_-m64_-march=core2_-O2_-fomit-frame-pointer2016103020161009
927840? ? ?? ? ?ref4gcc_-m64_-O3_-fomit-frame-pointer2016103020161009
929032? ? ?? ? ?ref4gcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2016103020161009
929400? ? ?? ? ?ref4gcc_-march=native_-mtune=native_-O3_-fomit-frame-pointer_-fwrapv2016103020161009
929976? ? ?? ? ?ref4gcc_-funroll-loops_-O2_-fomit-frame-pointer2016103020161009
932368? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-march=nocona_-O3_-fomit-frame-pointer2016103020161009
935160? ? ?? ? ?ref4gcc_-m64_-march=nocona_-O3_-fomit-frame-pointer2016103020161009
935640? ? ?? ? ?ref4gcc_-funroll-loops_-march=barcelona_-O3_-fomit-frame-pointer2016103020161009
939424? ? ?? ? ?ref4gcc_-m64_-march=core2_-msse4_-O_-fomit-frame-pointer2016103020161009
940728? ? ?? ? ?ref4gcc_-march=native_-mtune=native_-O2_-fomit-frame-pointer_-fwrapv2016103020161009
942056? ? ?? ? ?ref4gcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2016103020161009
942136? ? ?? ? ?ref4gcc_-funroll-loops_-march=nocona_-O3_-fomit-frame-pointer2016103020161009
942368? ? ?? ? ?ref4gcc_-m64_-march=barcelona_-O_-fomit-frame-pointer2016103020161009
942592? ? ?? ? ?ref4gcc_-march=native_-mtune=native_-O_-fomit-frame-pointer_-fwrapv2016103020161009
942608? ? ?? ? ?ref4gcc_-m64_-march=k8_-O_-fomit-frame-pointer2016103020161009
942832? ? ?? ? ?ref4gcc_-funroll-loops_-O_-fomit-frame-pointer2016103020161009
943096? ? ?? ? ?ref4gcc_-march=barcelona_-O_-fomit-frame-pointer2016103020161009
943184? ? ?? ? ?ref4gcc_-funroll-loops_-march=nocona_-O_-fomit-frame-pointer2016103020161009
944208? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-march=nocona_-O_-fomit-frame-pointer2016103020161009
944864? ? ?? ? ?ref4gcc_-march=k8_-O_-fomit-frame-pointer2016103020161009
945136? ? ?? ? ?ref4gcc_-m64_-O_-fomit-frame-pointer2016103020161009
947096? ? ?? ? ?ref4gcc_-funroll-loops_-march=k8_-O_-fomit-frame-pointer2016103020161009
947296? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-march=k8_-O_-fomit-frame-pointer2016103020161009
947832? ? ?? ? ?ref4gcc_-m64_-march=nocona_-O_-fomit-frame-pointer2016103020161009
948712? ? ?? ? ?ref4gcc_-m64_-march=core2_-msse4.1_-O_-fomit-frame-pointer2016103020161009
950688? ? ?? ? ?ref4gcc_-funroll-loops_-march=barcelona_-O_-fomit-frame-pointer2016103020161009
954472? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-O_-fomit-frame-pointer2016103020161009
954784? ? ?? ? ?ref4gcc_-m64_-march=corei7_-O_-fomit-frame-pointer2016103020161009
963080? ? ?? ? ?ref4gcc_-m64_-march=core2_-O_-fomit-frame-pointer2016103020161009
965008? ? ?? ? ?ref4gcc_-march=nocona_-O_-fomit-frame-pointer2016103020161009
972536? ? ?? ? ?ref4gcc_-O_-fomit-frame-pointer2016103020161009
972736? ? ?? ? ?ref4gcc_-fno-schedule-insns_-O_-fomit-frame-pointer2016103020161009
980432? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-march=barcelona_-O_-fomit-frame-pointer2016103020161009
998192? ? ?? ? ?ref4gcc_-m64_-march=native_-mtune=native_-O_-fomit-frame-pointer2016103020161009
1033056? ? ?? ? ?ref4gcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2016103020161009
1035384? ? ?? ? ?ref4gcc_-funroll-loops_-Os_-fomit-frame-pointer2016103020161009
1036168? ? ?? ? ?ref4gcc_-funroll-loops_-march=barcelona_-Os_-fomit-frame-pointer2016103020161009
1037336? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-march=barcelona_-Os_-fomit-frame-pointer2016103020161009
1038840? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-Os_-fomit-frame-pointer2016103020161009
1040024? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-march=k8_-Os_-fomit-frame-pointer2016103020161009
1040480? ? ?? ? ?ref4gcc_-funroll-loops_-m64_-march=nocona_-Os_-fomit-frame-pointer2016103020161009
1041600? ? ?? ? ?ref4gcc_-Os_-fomit-frame-pointer2016103020161009
1042408? ? ?? ? ?ref4gcc_-funroll-loops_-march=nocona_-Os_-fomit-frame-pointer2016103020161009
1042760? ? ?? ? ?ref4gcc_-m64_-march=nocona_-Os_-fomit-frame-pointer2016103020161009
1044008? ? ?? ? ?ref4gcc_-m64_-Os_-fomit-frame-pointer2016103020161009
1044064? ? ?? ? ?ref4gcc_-m64_-march=k8_-Os_-fomit-frame-pointer2016103020161009
1044104? ? ?? ? ?ref4gcc_-m64_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2016103020161009
1044144? ? ?? ? ?ref4gcc_-march=barcelona_-Os_-fomit-frame-pointer2016103020161009
1044744? ? ?? ? ?ref4gcc_-m64_-march=barcelona_-Os_-fomit-frame-pointer2016103020161009
1045136? ? ?? ? ?ref4gcc_-march=k8_-Os_-fomit-frame-pointer2016103020161009
1045528? ? ?? ? ?ref4gcc_-m64_-march=native_-mtune=native_-Os_-fomit-frame-pointer2016103020161009
1047984? ? ?? ? ?ref4gcc_-funroll-loops_-march=k8_-Os_-fomit-frame-pointer2016103020161009
1048704? ? ?? ? ?ref4gcc_-m64_-march=core2_-Os_-fomit-frame-pointer2016103020161009
1050592? ? ?? ? ?ref4gcc_-march=nocona_-Os_-fomit-frame-pointer2016103020161009
1055872? ? ?? ? ?ref4gcc_-march=native_-mtune=native_-Os_-fomit-frame-pointer_-fwrapv2016103020161009
1057064? ? ?? ? ?ref4gcc_-m64_-march=core2_-msse4_-Os_-fomit-frame-pointer2016103020161009
1072400? ? ?? ? ?ref4gcc_-m64_-march=corei7_-Os_-fomit-frame-pointer2016103020161009
1080664? ? ?? ? ?ref4gcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2016103020161009

Compiler output

Implementation: crypto_dh/gls1271/ref4
Compiler: cc
gls1271.c: gls1271.c: In function 'crypto_dh_gls1271_ref4_keypair':
gls1271.c: gls1271.c:385:2: warning: implicit declaration of function 'ecn2_brick_init' [-Wimplicit-function-declaration]
gls1271.c: ecn2_brick_init(&binst,prom,A,B,p,6,128);
gls1271.c: ^
gls1271.c: gls1271.c:391:5: warning: implicit declaration of function 'randombytes' [-Wimplicit-function-declaration]
gls1271.c: randombytes(sk,32);
gls1271.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_div2_i':
mrecn2.c: mrecn2.c:20:2: warning: implicit declaration of function 'moddiv2' [-Wimplicit-function-declaration]
mrecn2.c: moddiv2(w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_tim2_i':
mrecn2.c: mrecn2.c:32:2: warning: implicit declaration of function 'modtim2' [-Wimplicit-function-declaration]
mrecn2.c: modtim2(w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_tim3_i':
mrecn2.c: mrecn2.c:44:2: warning: implicit declaration of function 'modtim3' [-Wimplicit-function-declaration]
mrecn2.c: modtim3(w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_add_i':
mrecn2.c: mrecn2.c:70:5: warning: implicit declaration of function 'modadd' [-Wimplicit-function-declaration]
mrecn2.c: modadd(x->a->w,y->a->w,w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_sub_i':
mrecn2.c: mrecn2.c:81:5: warning: implicit declaration of function 'modsub' [-Wimplicit-function-declaration]
mrecn2.c: modsub(x->a->w,y->a->w,w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_timesi_i':
mrecn2.c: mrecn2.c:96:2: warning: implicit declaration of function 'modneg' [-Wimplicit-function-declaration]
mrecn2.c: modneg(u->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_imul_i':
mrecn2.c: ...
mrmonty.c: mrmonty.c: In function 'nres_negate':
mrmonty.c: mrmonty.c:752:2: warning: implicit declaration of function 'modneg' [-Wimplicit-function-declaration]
mrmonty.c: modneg(w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c: In function 'nres_modadd':
mrmonty.c: mrmonty.c:901:2: warning: implicit declaration of function 'modadd' [-Wimplicit-function-declaration]
mrmonty.c: modadd(x->w,y->w,w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c: In function 'nres_modsub':
mrmonty.c: mrmonty.c:935:2: warning: implicit declaration of function 'modsub' [-Wimplicit-function-declaration]
mrmonty.c: modsub(x->w,y->w,w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c: In function 'nres_modmult':
mrmonty.c: mrmonty.c:1075:16: warning: implicit declaration of function 'modsqr' [-Wimplicit-function-declaration]
mrmonty.c: if (x==y) modsqr(x->w,w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c:1076:16: warning: implicit declaration of function 'modmult' [-Wimplicit-function-declaration]
mrmonty.c: else modmult(x->w,y->w,w->w);
mrmonty.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_sub':
mrzzn2.c: mrzzn2.c:37:5: warning: implicit declaration of function 'modsub' [-Wimplicit-function-declaration]
mrzzn2.c: modsub(x->a->w,y->a->w,w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_add':
mrzzn2.c: mrzzn2.c:59:5: warning: implicit declaration of function 'modadd' [-Wimplicit-function-declaration]
mrzzn2.c: modadd(x->a->w,y->a->w,w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_negate':
mrzzn2.c: mrzzn2.c:174:2: warning: implicit declaration of function 'modneg' [-Wimplicit-function-declaration]
mrzzn2.c: modneg(w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_div2':
mrzzn2.c: mrzzn2.c:319:2: warning: implicit declaration of function 'moddiv2' [-Wimplicit-function-declaration]
mrzzn2.c: moddiv2(w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_sqr':
mrzzn2.c: mrzzn2.c:514:2: warning: implicit declaration of function 'modmult' [-Wimplicit-function-declaration]
mrzzn2.c: modmult(x->a->w,x->b->w,w->b->w);
mrzzn2.c: ^
try.c: crypto_dh_gls1271.a(mrecn2.o): In function `ecn2_psi':
try.c: mrecn2.c:(.text+0x...): undefined reference to `zzn2_conj_i'
try.c: mrecn2.c:(.text+0x...): undefined reference to `zzn2_conj_i'
try.c: mrecn2.c:(.text+0x...): undefined reference to `zzn2_conj_i'
try.c: collect2: error: ld returned 1 exit status

Number of similar (compiler,implementation) pairs: 3, namely:
CompilerImplementations
cc ref4
gcc ref4
gcc -funroll-loops ref4

Compiler output

Implementation: crypto_dh/gls1271/ref4
Compiler: clang -O3 -fomit-frame-pointer -Qunused-arguments
gls1271.c: gls1271.c:385:2: warning: implicit declaration of function 'ecn2_brick_init' is invalid in C99 [-Wimplicit-function-declaration]
gls1271.c: ecn2_brick_init(&binst,prom,A,B,p,6,128);
gls1271.c: ^
gls1271.c: gls1271.c:391:5: warning: implicit declaration of function 'randombytes' is invalid in C99 [-Wimplicit-function-declaration]
gls1271.c: randombytes(sk,32);
gls1271.c: ^
gls1271.c: gls1271.c:395:22: warning: passing 'unsigned char *' to parameter of type 'const char *' converts between pointers to integer types with different sign [-Wpointer-sign]
gls1271.c: bytes_to_big(mip,16,sk,a[0]);
gls1271.c: ^~
gls1271.c: ./miracl.h:842:50: note: passing argument to parameter here
gls1271.c: extern void bytes_to_big(_MIPT_ int,const char *,big);
gls1271.c: ^
gls1271.c: gls1271.c:396:22: warning: passing 'unsigned char *' to parameter of type 'const char *' converts between pointers to integer types with different sign [-Wpointer-sign]
gls1271.c: bytes_to_big(mip,16,&sk[16],a[1]);
gls1271.c: ^~~~~~~
gls1271.c: ./miracl.h:842:50: note: passing argument to parameter here
gls1271.c: extern void bytes_to_big(_MIPT_ int,const char *,big);
gls1271.c: ^
gls1271.c: gls1271.c:400:29: warning: passing 'unsigned char *' to parameter of type 'char *' converts between pointers to integer types with different sign [-Wpointer-sign]
gls1271.c: big_to_bytes(mip,16,x.a,pk,TRUE);
gls1271.c: ^~
gls1271.c: ./miracl.h:843:48: note: passing argument to parameter here
gls1271.c: extern int big_to_bytes(_MIPT_ int,big,char *,BOOL);
gls1271.c: ^
gls1271.c: gls1271.c:401:29: warning: passing 'unsigned char *' to parameter of type 'char *' converts between pointers to integer types with different sign [-Wpointer-sign]
gls1271.c: ...

Number of similar (compiler,implementation) pairs: 6, namely:
CompilerImplementations
clang -O3 -fomit-frame-pointer -Qunused-arguments ref4
clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments ref4
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref4
clang -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref4
clang -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref4
clang -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref4

Compiler output

Implementation: crypto_dh/gls1271/ref4
Compiler: gcc -O2 -fomit-frame-pointer
gls1271.c: gls1271.c: In function 'crypto_dh_gls1271_ref4_keypair':
gls1271.c: gls1271.c:385:2: warning: implicit declaration of function 'ecn2_brick_init' [-Wimplicit-function-declaration]
gls1271.c: ecn2_brick_init(&binst,prom,A,B,p,6,128);
gls1271.c: ^
gls1271.c: gls1271.c:391:5: warning: implicit declaration of function 'randombytes' [-Wimplicit-function-declaration]
gls1271.c: randombytes(sk,32);
gls1271.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_div2_i':
mrecn2.c: mrecn2.c:20:2: warning: implicit declaration of function 'moddiv2' [-Wimplicit-function-declaration]
mrecn2.c: moddiv2(w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_tim2_i':
mrecn2.c: mrecn2.c:32:2: warning: implicit declaration of function 'modtim2' [-Wimplicit-function-declaration]
mrecn2.c: modtim2(w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_tim3_i':
mrecn2.c: mrecn2.c:44:2: warning: implicit declaration of function 'modtim3' [-Wimplicit-function-declaration]
mrecn2.c: modtim3(w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_add_i':
mrecn2.c: mrecn2.c:70:5: warning: implicit declaration of function 'modadd' [-Wimplicit-function-declaration]
mrecn2.c: modadd(x->a->w,y->a->w,w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_sub_i':
mrecn2.c: mrecn2.c:81:5: warning: implicit declaration of function 'modsub' [-Wimplicit-function-declaration]
mrecn2.c: modsub(x->a->w,y->a->w,w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_timesi_i':
mrecn2.c: mrecn2.c:96:2: warning: implicit declaration of function 'modneg' [-Wimplicit-function-declaration]
mrecn2.c: modneg(u->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_imul_i':
mrecn2.c: ...
mrmonty.c: mrmonty.c: In function 'nres_negate':
mrmonty.c: mrmonty.c:752:2: warning: implicit declaration of function 'modneg' [-Wimplicit-function-declaration]
mrmonty.c: modneg(w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c: In function 'nres_modadd':
mrmonty.c: mrmonty.c:901:2: warning: implicit declaration of function 'modadd' [-Wimplicit-function-declaration]
mrmonty.c: modadd(x->w,y->w,w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c: In function 'nres_modsub':
mrmonty.c: mrmonty.c:935:2: warning: implicit declaration of function 'modsub' [-Wimplicit-function-declaration]
mrmonty.c: modsub(x->w,y->w,w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c: In function 'nres_modmult':
mrmonty.c: mrmonty.c:1075:16: warning: implicit declaration of function 'modsqr' [-Wimplicit-function-declaration]
mrmonty.c: if (x==y) modsqr(x->w,w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c:1076:16: warning: implicit declaration of function 'modmult' [-Wimplicit-function-declaration]
mrmonty.c: else modmult(x->w,y->w,w->w);
mrmonty.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_sub':
mrzzn2.c: mrzzn2.c:37:5: warning: implicit declaration of function 'modsub' [-Wimplicit-function-declaration]
mrzzn2.c: modsub(x->a->w,y->a->w,w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_add':
mrzzn2.c: mrzzn2.c:59:5: warning: implicit declaration of function 'modadd' [-Wimplicit-function-declaration]
mrzzn2.c: modadd(x->a->w,y->a->w,w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_negate':
mrzzn2.c: mrzzn2.c:174:2: warning: implicit declaration of function 'modneg' [-Wimplicit-function-declaration]
mrzzn2.c: modneg(w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_div2':
mrzzn2.c: mrzzn2.c:319:2: warning: implicit declaration of function 'moddiv2' [-Wimplicit-function-declaration]
mrzzn2.c: moddiv2(w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_sqr':
mrzzn2.c: mrzzn2.c:514:2: warning: implicit declaration of function 'modmult' [-Wimplicit-function-declaration]
mrzzn2.c: modmult(x->a->w,x->b->w,w->b->w);
mrzzn2.c: ^

Number of similar (compiler,implementation) pairs: 89, namely:
CompilerImplementations
gcc -O2 -fomit-frame-pointer ref4
gcc -O3 -fomit-frame-pointer ref4
gcc -O -fomit-frame-pointer ref4
gcc -Os -fomit-frame-pointer ref4
gcc -fno-schedule-insns -O2 -fomit-frame-pointer ref4
gcc -fno-schedule-insns -O3 -fomit-frame-pointer ref4
gcc -fno-schedule-insns -O -fomit-frame-pointer ref4
gcc -fno-schedule-insns -Os -fomit-frame-pointer ref4
gcc -funroll-loops -O2 -fomit-frame-pointer ref4
gcc -funroll-loops -O3 -fomit-frame-pointer ref4
gcc -funroll-loops -O -fomit-frame-pointer ref4
gcc -funroll-loops -Os -fomit-frame-pointer ref4
gcc -funroll-loops -fno-schedule-insns -O2 -fomit-frame-pointer ref4
gcc -funroll-loops -fno-schedule-insns -O3 -fomit-frame-pointer ref4
gcc -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer ref4
gcc -funroll-loops -fno-schedule-insns -Os -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -O2 -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -O3 -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -O -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -Os -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -march=barcelona -O2 -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -march=barcelona -O3 -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -march=barcelona -O -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -march=barcelona -Os -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -march=k8 -O2 -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -march=k8 -O3 -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -march=k8 -O -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -march=k8 -Os -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -march=nocona -O2 -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -march=nocona -O3 -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -march=nocona -O -fomit-frame-pointer ref4
gcc -funroll-loops -m64 -march=nocona -Os -fomit-frame-pointer ref4
gcc -funroll-loops -march=barcelona -O2 -fomit-frame-pointer ref4
gcc -funroll-loops -march=barcelona -O3 -fomit-frame-pointer ref4
gcc -funroll-loops -march=barcelona -O -fomit-frame-pointer ref4
gcc -funroll-loops -march=barcelona -Os -fomit-frame-pointer ref4
gcc -funroll-loops -march=k8 -O2 -fomit-frame-pointer ref4
gcc -funroll-loops -march=k8 -O3 -fomit-frame-pointer ref4
gcc -funroll-loops -march=k8 -O -fomit-frame-pointer ref4
gcc -funroll-loops -march=k8 -Os -fomit-frame-pointer ref4
gcc -funroll-loops -march=nocona -O2 -fomit-frame-pointer ref4
gcc -funroll-loops -march=nocona -O3 -fomit-frame-pointer ref4
gcc -funroll-loops -march=nocona -O -fomit-frame-pointer ref4
gcc -funroll-loops -march=nocona -Os -fomit-frame-pointer ref4
gcc -m64 -O2 -fomit-frame-pointer ref4
gcc -m64 -O3 -fomit-frame-pointer ref4
gcc -m64 -O -fomit-frame-pointer ref4
gcc -m64 -Os -fomit-frame-pointer ref4
gcc -m64 -march=core2 -O2 -fomit-frame-pointer ref4
gcc -m64 -march=core2 -O3 -fomit-frame-pointer ref4
gcc -m64 -march=core2 -O -fomit-frame-pointer ref4
gcc -m64 -march=core2 -Os -fomit-frame-pointer ref4
gcc -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer ref4
gcc -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer ref4
gcc -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer ref4
gcc -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer ref4
gcc -m64 -march=core2 -msse4 -O -fomit-frame-pointer ref4
gcc -m64 -march=core2 -msse4 -Os -fomit-frame-pointer ref4
gcc -m64 -march=corei7 -O2 -fomit-frame-pointer ref4
gcc -m64 -march=corei7 -O -fomit-frame-pointer ref4
gcc -m64 -march=corei7 -Os -fomit-frame-pointer ref4
gcc -m64 -march=k8 -O2 -fomit-frame-pointer ref4
gcc -m64 -march=k8 -O3 -fomit-frame-pointer ref4
gcc -m64 -march=k8 -O -fomit-frame-pointer ref4
gcc -m64 -march=k8 -Os -fomit-frame-pointer ref4
gcc -m64 -march=native -mtune=native -O2 -fomit-frame-pointer ref4
gcc -m64 -march=native -mtune=native -O3 -fomit-frame-pointer ref4
gcc -m64 -march=native -mtune=native -O -fomit-frame-pointer ref4
gcc -m64 -march=native -mtune=native -Os -fomit-frame-pointer ref4
gcc -m64 -march=nocona -O2 -fomit-frame-pointer ref4
gcc -m64 -march=nocona -O3 -fomit-frame-pointer ref4
gcc -m64 -march=nocona -O -fomit-frame-pointer ref4
gcc -m64 -march=nocona -Os -fomit-frame-pointer ref4
gcc -march=barcelona -O2 -fomit-frame-pointer ref4
gcc -march=barcelona -O3 -fomit-frame-pointer ref4
gcc -march=barcelona -O -fomit-frame-pointer ref4
gcc -march=barcelona -Os -fomit-frame-pointer ref4
gcc -march=k8 -O2 -fomit-frame-pointer ref4
gcc -march=k8 -O3 -fomit-frame-pointer ref4
gcc -march=k8 -O -fomit-frame-pointer ref4
gcc -march=k8 -Os -fomit-frame-pointer ref4
gcc -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv ref4
gcc -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv ref4
gcc -march=native -mtune=native -O -fomit-frame-pointer -fwrapv ref4
gcc -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv ref4
gcc -march=nocona -O2 -fomit-frame-pointer ref4
gcc -march=nocona -O3 -fomit-frame-pointer ref4
gcc -march=nocona -O -fomit-frame-pointer ref4
gcc -march=nocona -Os -fomit-frame-pointer ref4

Compiler output

Implementation: crypto_dh/gls1271/ref4
Compiler: gcc -m64 -march=barcelona -O2 -fomit-frame-pointer
gls1271.c: gls1271.c: In function 'crypto_dh_gls1271_ref4_keypair':
gls1271.c: gls1271.c:385:2: warning: implicit declaration of function 'ecn2_brick_init' [-Wimplicit-function-declaration]
gls1271.c: ecn2_brick_init(&binst,prom,A,B,p,6,128);
gls1271.c: ^
gls1271.c: gls1271.c:391:5: warning: implicit declaration of function 'randombytes' [-Wimplicit-function-declaration]
gls1271.c: randombytes(sk,32);
gls1271.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_div2_i':
mrecn2.c: mrecn2.c:20:2: warning: implicit declaration of function 'moddiv2' [-Wimplicit-function-declaration]
mrecn2.c: moddiv2(w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_tim2_i':
mrecn2.c: mrecn2.c:32:2: warning: implicit declaration of function 'modtim2' [-Wimplicit-function-declaration]
mrecn2.c: modtim2(w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_tim3_i':
mrecn2.c: mrecn2.c:44:2: warning: implicit declaration of function 'modtim3' [-Wimplicit-function-declaration]
mrecn2.c: modtim3(w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_add_i':
mrecn2.c: mrecn2.c:70:5: warning: implicit declaration of function 'modadd' [-Wimplicit-function-declaration]
mrecn2.c: modadd(x->a->w,y->a->w,w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_sub_i':
mrecn2.c: mrecn2.c:81:5: warning: implicit declaration of function 'modsub' [-Wimplicit-function-declaration]
mrecn2.c: modsub(x->a->w,y->a->w,w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_timesi_i':
mrecn2.c: mrecn2.c:96:2: warning: implicit declaration of function 'modneg' [-Wimplicit-function-declaration]
mrecn2.c: modneg(u->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_imul_i':
mrecn2.c: ...
mrmonty.c: mrmonty.c: In function 'nres_negate':
mrmonty.c: mrmonty.c:752:2: warning: implicit declaration of function 'modneg' [-Wimplicit-function-declaration]
mrmonty.c: modneg(w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c: In function 'nres_modadd':
mrmonty.c: mrmonty.c:901:2: warning: implicit declaration of function 'modadd' [-Wimplicit-function-declaration]
mrmonty.c: modadd(x->w,y->w,w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c: In function 'nres_modsub':
mrmonty.c: mrmonty.c:935:2: warning: implicit declaration of function 'modsub' [-Wimplicit-function-declaration]
mrmonty.c: modsub(x->w,y->w,w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c: In function 'nres_modmult':
mrmonty.c: mrmonty.c:1075:16: warning: implicit declaration of function 'modsqr' [-Wimplicit-function-declaration]
mrmonty.c: if (x==y) modsqr(x->w,w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c:1076:16: warning: implicit declaration of function 'modmult' [-Wimplicit-function-declaration]
mrmonty.c: else modmult(x->w,y->w,w->w);
mrmonty.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_sub':
mrzzn2.c: mrzzn2.c:37:5: warning: implicit declaration of function 'modsub' [-Wimplicit-function-declaration]
mrzzn2.c: modsub(x->a->w,y->a->w,w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_add':
mrzzn2.c: mrzzn2.c:59:5: warning: implicit declaration of function 'modadd' [-Wimplicit-function-declaration]
mrzzn2.c: modadd(x->a->w,y->a->w,w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_negate':
mrzzn2.c: mrzzn2.c:174:2: warning: implicit declaration of function 'modneg' [-Wimplicit-function-declaration]
mrzzn2.c: modneg(w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_div2':
mrzzn2.c: mrzzn2.c:319:2: warning: implicit declaration of function 'moddiv2' [-Wimplicit-function-declaration]
mrzzn2.c: moddiv2(w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_sqr':
mrzzn2.c: mrzzn2.c:514:2: warning: implicit declaration of function 'modmult' [-Wimplicit-function-declaration]
mrzzn2.c: modmult(x->a->w,x->b->w,w->b->w);
mrzzn2.c: ^
gls1271.c: gls1271.c: In function 'crypto_dh_gls1271_ref4_keypair':
gls1271.c: gls1271.c:385:2: warning: implicit declaration of function 'ecn2_brick_init' [-Wimplicit-function-declaration]
gls1271.c: ecn2_brick_init(&binst,prom,A,B,p,6,128);
gls1271.c: ^
gls1271.c: gls1271.c:391:5: warning: implicit declaration of function 'randombytes' [-Wimplicit-function-declaration]
gls1271.c: randombytes(sk,32);
gls1271.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_div2_i':
mrecn2.c: mrecn2.c:20:2: warning: implicit declaration of function 'moddiv2' [-Wimplicit-function-declaration]
mrecn2.c: moddiv2(w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_tim2_i':
mrecn2.c: mrecn2.c:32:2: warning: implicit declaration of function 'modtim2' [-Wimplicit-function-declaration]
mrecn2.c: modtim2(w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_tim3_i':
mrecn2.c: mrecn2.c:44:2: warning: implicit declaration of function 'modtim3' [-Wimplicit-function-declaration]
mrecn2.c: modtim3(w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_add_i':
mrecn2.c: mrecn2.c:70:5: warning: implicit declaration of function 'modadd' [-Wimplicit-function-declaration]
mrecn2.c: modadd(x->a->w,y->a->w,w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_sub_i':
mrecn2.c: mrecn2.c:81:5: warning: implicit declaration of function 'modsub' [-Wimplicit-function-declaration]
mrecn2.c: modsub(x->a->w,y->a->w,w->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_timesi_i':
mrecn2.c: mrecn2.c:96:2: warning: implicit declaration of function 'modneg' [-Wimplicit-function-declaration]
mrecn2.c: modneg(u->a->w);
mrecn2.c: ^
mrecn2.c: mrecn2.c: In function 'zzn2_imul_i':
mrecn2.c: ...
mrmonty.c: mrmonty.c: In function 'nres_negate':
mrmonty.c: mrmonty.c:752:2: warning: implicit declaration of function 'modneg' [-Wimplicit-function-declaration]
mrmonty.c: modneg(w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c: In function 'nres_modadd':
mrmonty.c: mrmonty.c:901:2: warning: implicit declaration of function 'modadd' [-Wimplicit-function-declaration]
mrmonty.c: modadd(x->w,y->w,w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c: In function 'nres_modsub':
mrmonty.c: mrmonty.c:935:2: warning: implicit declaration of function 'modsub' [-Wimplicit-function-declaration]
mrmonty.c: modsub(x->w,y->w,w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c: In function 'nres_modmult':
mrmonty.c: mrmonty.c:1075:16: warning: implicit declaration of function 'modsqr' [-Wimplicit-function-declaration]
mrmonty.c: if (x==y) modsqr(x->w,w->w);
mrmonty.c: ^
mrmonty.c: mrmonty.c:1076:16: warning: implicit declaration of function 'modmult' [-Wimplicit-function-declaration]
mrmonty.c: else modmult(x->w,y->w,w->w);
mrmonty.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_sub':
mrzzn2.c: mrzzn2.c:37:5: warning: implicit declaration of function 'modsub' [-Wimplicit-function-declaration]
mrzzn2.c: modsub(x->a->w,y->a->w,w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_add':
mrzzn2.c: mrzzn2.c:59:5: warning: implicit declaration of function 'modadd' [-Wimplicit-function-declaration]
mrzzn2.c: modadd(x->a->w,y->a->w,w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_negate':
mrzzn2.c: mrzzn2.c:174:2: warning: implicit declaration of function 'modneg' [-Wimplicit-function-declaration]
mrzzn2.c: modneg(w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_div2':
mrzzn2.c: mrzzn2.c:319:2: warning: implicit declaration of function 'moddiv2' [-Wimplicit-function-declaration]
mrzzn2.c: moddiv2(w->a->w);
mrzzn2.c: ^
mrzzn2.c: mrzzn2.c: In function 'zzn2_sqr':
mrzzn2.c: mrzzn2.c:514:2: warning: implicit declaration of function 'modmult' [-Wimplicit-function-declaration]
mrzzn2.c: modmult(x->a->w,x->b->w,w->b->w);
mrzzn2.c: ^

Number of similar (compiler,implementation) pairs: 4, namely:
CompilerImplementations
gcc -m64 -march=barcelona -O2 -fomit-frame-pointer ref4
gcc -m64 -march=barcelona -O3 -fomit-frame-pointer ref4
gcc -m64 -march=barcelona -O -fomit-frame-pointer ref4
gcc -m64 -march=barcelona -Os -fomit-frame-pointer ref4