Implementation notes: amd64, oki, crypto_verify/8

Computer: oki
Architecture: amd64
CPU ID: GenuineIntel-00050654-bfebfbff
SUPERCOP version: 20181123
Operation: crypto_verify
Primitive: 8
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
26? ? ?? ? ?refgcc_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-fno-schedule-insns_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-fno-schedule-insns_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-fno-schedule-insns_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-fno-schedule-insns_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-fno-schedule-insns_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-fno-schedule-insns_-Os_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-m64_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-m64_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-m64_-Os_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=barcelona_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=barcelona_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=barcelona_-Os_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=k8_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=k8_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=k8_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=nocona_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=nocona_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=nocona_-Os_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-march=barcelona_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-march=barcelona_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-march=barcelona_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-march=k8_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-march=k8_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-march=k8_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-march=nocona_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-march=nocona_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-funroll-loops_-march=nocona_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=barcelona_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=barcelona_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=barcelona_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core-avx-i_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core-avx-i_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core-avx-i_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core-avx2_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core-avx2_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core-avx2_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core2_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core2_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core2_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core2_-msse4.1_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core2_-msse4.1_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core2_-msse4_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core2_-msse4_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=core2_-msse4_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=corei7-avx_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=corei7-avx_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=corei7-avx_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=corei7_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=corei7_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=corei7_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=k8_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=k8_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=k8_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=native_-mtune=native_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=native_-mtune=native_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=native_-mtune=native_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=nocona_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=nocona_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-m64_-march=nocona_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-march=barcelona_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-march=barcelona_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-march=barcelona_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-march=k8_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-march=k8_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-march=k8_-O_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-march=native_-mtune=native_-O2_-fomit-frame-pointer_-fwrapv2018112720181123
26? ? ?? ? ?refgcc_-march=native_-mtune=native_-O3_-fomit-frame-pointer_-fwrapv2018112720181123
26? ? ?? ? ?refgcc_-march=native_-mtune=native_-O_-fomit-frame-pointer_-fwrapv2018112720181123
26? ? ?? ? ?refgcc_-march=nocona_-O2_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-march=nocona_-O3_-fomit-frame-pointer2018112720181123
26? ? ?? ? ?refgcc_-march=nocona_-O_-fomit-frame-pointer2018112720181123
28? ? ?? ? ?refclang_-O3_-fomit-frame-pointer_-Qunused-arguments2018112720181123
28? ? ?? ? ?refclang_-O3_-fwrapv_-march=x86-64_-mcpu=core-avx2_-mavx2_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2018112720181123
28? ? ?? ? ?refclang_-O3_-fwrapv_-mavx2_-fomit-frame-pointer_-Qunused-arguments2018112720181123
28? ? ?? ? ?refclang_-O3_-fwrapv_-mavx_-fomit-frame-pointer_-Qunused-arguments2018112720181123
28? ? ?? ? ?refclang_-O3_-fwrapv_-mavx_-maes_-mpclmul_-fomit-frame-pointer_-Qunused-arguments2018112720181123
28? ? ?? ? ?refclang_-mcpu=cortex-a8_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2018112720181123
28? ? ?? ? ?refclang_-mcpu=native_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2018112720181123
28? ? ?? ? ?refgcc_-funroll-loops_-Os_-fomit-frame-pointer2018112720181123
28? ? ?? ? ?refgcc_-funroll-loops_-m64_-O_-fomit-frame-pointer2018112720181123
28? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=barcelona_-O_-fomit-frame-pointer2018112720181123
28? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=k8_-Os_-fomit-frame-pointer2018112720181123
28? ? ?? ? ?refgcc_-funroll-loops_-m64_-march=nocona_-O_-fomit-frame-pointer2018112720181123
28? ? ?? ? ?refgcc_-funroll-loops_-march=barcelona_-Os_-fomit-frame-pointer2018112720181123
28? ? ?? ? ?refgcc_-funroll-loops_-march=k8_-Os_-fomit-frame-pointer2018112720181123
28? ? ?? ? ?refgcc_-funroll-loops_-march=nocona_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refclang_-mcpu=cortex-a9_-mfpu=neon_-O3_-fomit-frame-pointer_-fwrapv_-Qunused-arguments2018112720181123
30? ? ?? ? ?refgcc_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-fno-schedule-insns_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-funroll-loops_-fno-schedule-insns_-O3_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-m64_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-m64_-march=barcelona_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-m64_-march=core-avx-i_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-m64_-march=core-avx2_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-m64_-march=core2_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-m64_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-m64_-march=core2_-msse4_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-m64_-march=corei7-avx_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-m64_-march=corei7_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-m64_-march=k8_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-m64_-march=native_-mtune=native_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-m64_-march=nocona_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-march=barcelona_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-march=k8_-Os_-fomit-frame-pointer2018112720181123
30? ? ?? ? ?refgcc_-march=native_-mtune=native_-Os_-fomit-frame-pointer_-fwrapv2018112720181123
30? ? ?? ? ?refgcc_-march=nocona_-Os_-fomit-frame-pointer2018112720181123
40? ? ?? ? ?refgcc2018112720181123
40? ? ?? ? ?refgcc_-funroll-loops2018112720181123
42? ? ?? ? ?refcc2018112720181123

Compiler output

Implementation: crypto_verify/8/ref
Compiler: clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
try.c: fatal error: error in backend: Cannot select: 0x29a5fb0: v4i64 = X86ISD::VTRUNC 0x29a5de0
try.c: 0x29a5de0: v16i32 = vselect 0x29a2a20, 0x292e890, 0x29a5cb0
try.c: 0x29a2a20: v4i1 = X86ISD::PCMPGTM 0x298e890, 0x2923790
try.c: 0x298e890: v4i64 = X86ISD::VBROADCAST 0x2923b20
try.c: 0x2923b20: i64,ch = load<LD8[%uglygep72]> 0x2888dd0, 0x29450b0, undef:i64
try.c: 0x29450b0: i64 = add 0x298f770, 0x291f680
try.c: 0x298f770: i64 = X86ISD::Wrapper TargetGlobalAddress:i64<[64 x i64]* @cycles> 0
try.c: 0x2983450: i64 = TargetGlobalAddress<[64 x i64]* @cycles> 0
try.c: 0x291f680: i64 = shl 0x2982c00, Constant:i8<3>
try.c: 0x2982c00: i64,ch = CopyFromReg 0x2888dd0, Register:i64 %vreg50
try.c: 0x298fc30: i64 = Register %vreg50
try.c: 0x2936af0: i8 = Constant<3>
try.c: 0x298cf00: i64 = undef
try.c: 0x2923790: v4i64,ch = CopyFromReg 0x2888dd0, Register:v4i64 %vreg13
try.c: 0x293a370: v4i64 = Register %vreg13
try.c: 0x292e890: v16i32 = X86ISD::VBROADCAST 0x2982e60
try.c: 0x2982e60: i32,ch = load<LD4[ConstantPool]> 0x2888dd0, 0x29a5920, undef:i64
try.c: 0x29a5920: i64 = X86ISD::Wrapper TargetConstantPool:i64<i32 1> 0
try.c: 0x2925550: i64 = TargetConstantPool<i32 1> 0
try.c: 0x298cf00: i64 = undef
try.c: 0x29a5cb0: v16i32 = BUILD_VECTOR Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>
try.c: 0x29a5b80: i32 = Constant<0>
try.c: 0x29a5b80: i32 = Constant<0>
try.c: 0x29a5b80: i32 = Constant<0>
try.c: 0x29a5b80: i32 = Constant<0>
try.c: ...

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments ref

Compiler output

Implementation: crypto_verify/8/ref
Compiler: clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
try.c: fatal error: error in backend: Cannot select: 0x1721fc0: v4i64 = X86ISD::VTRUNC 0x1721df0
try.c: 0x1721df0: v16i32 = vselect 0x1728bf0, 0x16a30b0, 0x1721cc0
try.c: 0x1728bf0: v4i1 = X86ISD::PCMPGTM 0x170c8c0, 0x16a4f90
try.c: 0x170c8c0: v4i64 = X86ISD::VBROADCAST 0x16a5320
try.c: 0x16a5320: i64,ch = load<LD8[%uglygep72]> 0x1606dd0, 0x16ec160, undef:i64
try.c: 0x16ec160: i64 = add 0x170d7a0, 0x169f8a0
try.c: 0x170d7a0: i64 = X86ISD::Wrapper TargetGlobalAddress:i64<[64 x i64]* @cycles> 0
try.c: 0x16fb650: i64 = TargetGlobalAddress<[64 x i64]* @cycles> 0
try.c: 0x169f8a0: i64 = shl 0x16fae00, Constant:i8<3>
try.c: 0x16fae00: i64,ch = CopyFromReg 0x1606dd0, Register:i64 %vreg50
try.c: 0x170dc60: i64 = Register %vreg50
try.c: 0x1688a00: i8 = Constant<3>
try.c: 0x170af30: i64 = undef
try.c: 0x16a4f90: v4i64,ch = CopyFromReg 0x1606dd0, Register:v4i64 %vreg13
try.c: 0x16b9020: v4i64 = Register %vreg13
try.c: 0x16a30b0: v16i32 = X86ISD::VBROADCAST 0x16fb060
try.c: 0x16fb060: i32,ch = load<LD4[ConstantPool]> 0x1606dd0, 0x1721930, undef:i64
try.c: 0x1721930: i64 = X86ISD::Wrapper TargetConstantPool:i64<i32 1> 0
try.c: 0x16b6b40: i64 = TargetConstantPool<i32 1> 0
try.c: 0x170af30: i64 = undef
try.c: 0x1721cc0: v16i32 = BUILD_VECTOR Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>, Constant:i32<0>
try.c: 0x1721b90: i32 = Constant<0>
try.c: 0x1721b90: i32 = Constant<0>
try.c: 0x1721b90: i32 = Constant<0>
try.c: 0x1721b90: i32 = Constant<0>
try.c: ...

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref