Implementation notes: amd64, kizomba, crypto_sign/rainbowbinary16242020

Computer: kizomba
Architecture: amd64
CPU ID: GenuineIntel-000906e9-bfebfbff
SUPERCOP version: 20171218
Operation: crypto_sign
Primitive: rainbowbinary16242020
TimeImplementationCompilerBenchmark dateSUPERCOP version
67615refclang++ -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments2017111020171020
68565refclang++ -O3 -fwrapv -mavx -fomit-frame-pointer -Qunused-arguments2017111020171020
68893refclang++ -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments2017111020171020
70218refclang++ -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2017111020171020
71153refclang++ -O3 -fwrapv -mavx -maes -mpclmul -fomit-frame-pointer -Qunused-arguments2017111020171020
71774refg++ -m64 -march=core-avx2 -O3 -fomit-frame-pointer2017111020171020
71851refclang++ -O3 -fwrapv -mavx2 -fomit-frame-pointer -Qunused-arguments2017111020171020
72119refg++ -m64 -march=core-avx-i -O3 -fomit-frame-pointer2017111020171020
72990refg++ -m64 -march=native -mtune=native -O3 -fomit-frame-pointer2017111020171020
73659refg++ -m64 -march=corei7 -O3 -fomit-frame-pointer2017111020171020
75193refg++ -m64 -march=corei7-avx -O3 -fomit-frame-pointer2017111020171020
75260refg++ -m64 -march=core2 -msse4 -O3 -fomit-frame-pointer2017111020171020
75688refg++ -m64 -march=core2 -O3 -fomit-frame-pointer2017111020171020
76732refg++ -m64 -march=core2 -msse4.1 -O3 -fomit-frame-pointer2017111020171020
77121refg++ -march=native -mtune=native -O3 -fomit-frame-pointer -fwrapv2017111020171020
87333refg++ -m64 -march=corei7 -O2 -fomit-frame-pointer2017111020171020
88843refg++ -m64 -march=corei7-avx -O2 -fomit-frame-pointer2017111020171020
89468refg++ -m64 -march=core-avx2 -O2 -fomit-frame-pointer2017111020171020
89764refg++ -m64 -march=core2 -msse4 -O2 -fomit-frame-pointer2017111020171020
89910refg++ -m64 -march=core-avx-i -O2 -fomit-frame-pointer2017111020171020
89990refg++ -m64 -march=core2 -msse4.1 -O2 -fomit-frame-pointer2017111020171020
90069refg++ -m64 -march=core2 -O2 -fomit-frame-pointer2017111020171020
90463refg++ -m64 -march=native -mtune=native -O2 -fomit-frame-pointer2017111020171020
91012refg++ -march=native -mtune=native -O2 -fomit-frame-pointer -fwrapv2017111020171020
93726refg++ -m64 -march=corei7 -O -fomit-frame-pointer2017111020171020
94036refg++ -m64 -march=corei7-avx -O -fomit-frame-pointer2017111020171020
94780refg++ -m64 -march=core2 -msse4 -O -fomit-frame-pointer2017111020171020
94990refg++ -march=native -mtune=native -O -fomit-frame-pointer -fwrapv2017111020171020
95156refg++ -m64 -march=core2 -msse4.1 -O -fomit-frame-pointer2017111020171020
95351refg++ -m64 -march=core2 -O -fomit-frame-pointer2017111020171020
98856refg++ -m64 -march=native -mtune=native -O -fomit-frame-pointer2017111020171020
100103refg++ -m64 -march=core-avx2 -O -fomit-frame-pointer2017111020171020
100829refg++ -m64 -march=core-avx-i -O -fomit-frame-pointer2017111020171020
161639refg++ -march=native -mtune=native -Os -fomit-frame-pointer -fwrapv2017111020171020
161873refg++ -m64 -march=core2 -msse4 -Os -fomit-frame-pointer2017111020171020
163500refg++ -m64 -march=core2 -msse4.1 -Os -fomit-frame-pointer2017111020171020
164276refg++ -m64 -march=native -mtune=native -Os -fomit-frame-pointer2017111020171020
166159refg++ -m64 -march=corei7 -Os -fomit-frame-pointer2017111020171020
167274refg++ -m64 -march=core2 -Os -fomit-frame-pointer2017111020171020
171648refg++ -m64 -march=corei7-avx -Os -fomit-frame-pointer2017111020171020
172382refg++ -m64 -march=core-avx-i -Os -fomit-frame-pointer2017111020171020
174641refg++ -m64 -march=core-avx2 -Os -fomit-frame-pointer2017111020171020

Compiler output

Implementation: crypto_sign/rainbowbinary16242020/ref
Compiler: clang++ -O3 -fomit-frame-pointer -Qunused-arguments
rainbow-test.cpp: In file included from rainbow-test.cpp:1:
rainbow-test.cpp: ./gf.h:171:46: warning: while loop has empty body [-Wempty-body]
rainbow-test.cpp: if( M==n_read ) { while( ttt.set(fp)==16 ) ; break; }
rainbow-test.cpp: ^
rainbow-test.cpp: ./gf.h:171:46: note: put the semicolon on a separate line to silence this warning
rainbow-test.cpp: In file included from rainbow-test.cpp:1:
rainbow-test.cpp: In file included from ./gf.h:181:
rainbow-test.cpp: ./gf16.h:321:9: error: always_inline function '_mm_shuffle_epi8' requires target feature 'ssse3', but would be inlined into function '_mul' that is compiled without support for 'ssse3'
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: fatal error: error in backend: Cannot select: 0x4313570: v16i8 = X86ISD::PSHUFB 0x4312db0, 0x4339680
rainbow-test.cpp: 0x4312db0: v16i8 = bitcast 0x42f4aa0
rainbow-test.cpp: 0x42f4aa0: v2i64,ch = loadgt;)(noalias=gt;,gt;,gt;)>gt; 0x417fff0, 0x4338e30, undef:i64
rainbow-test.cpp: 0x4338e30: i64 = add 0x4339f70, 0x433ba30
rainbow-test.cpp: 0x4339f70: i64 = X86ISD::Wrapper TargetGlobalAddress:i64gt;]* @_ZL8GFV16Mul>gt; 0
rainbow-test.cpp: 0x433c7e0: i64 = TargetGlobalAddressgt;]* @_ZL8GFV16Mul>gt; 0
rainbow-test.cpp: 0x433ba30: i64 = shl 0x4339420, Constant:i8gt;
rainbow-test.cpp: 0x4339420: i64,ch = loadgt;)(noalias=gt;,gt;,gt;), zext from i8>gt; 0x417fff0, 0x42f4840, undef:i64
rainbow-test.cpp: 0x42f4840: i64 = or 0x43459d0, 0x42f45e0
rainbow-test.cpp: 0x43459d0: i64 = add FrameIndex:i64gt;, 0x4338d00
rainbow-test.cpp: 0x4312ee0: i64 = FrameIndexgt;
rainbow-test.cpp: 0x4338d00: i64 = and 0x4344200, Constant:i64gt;
rainbow-test.cpp: 0x4344200: i64,ch = CopyFromReg 0x417fff0, Register:i64 %vreg3
rainbow-test.cpp:
rainbow-test.cpp: 0x433b900: i64 = Constantgt;
rainbow-test.cpp: ...

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

Compiler output

Implementation: crypto_sign/rainbowbinary16242020/ref
Compiler: clang++ -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments
rainbow-test.cpp: In file included from rainbow-test.cpp:1:
rainbow-test.cpp: ./gf.h:171:46: warning: while loop has empty body [-Wempty-body]
rainbow-test.cpp: if( M==n_read ) { while( ttt.set(fp)==16 ) ; break; }
rainbow-test.cpp: ^
rainbow-test.cpp: ./gf.h:171:46: note: put the semicolon on a separate line to silence this warning
rainbow-test.cpp: 1 warning generated.

Number of similar (compiler,implementation) pairs: 6, namely:
CompilerImplementations
clang++ -O3 -fwrapv -march=native -fomit-frame-pointer -Qunused-arguments ref
clang++ -O3 -fwrapv -march=x86-64 -mcpu=core-avx2 -mavx2 -maes -mpclmul -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++ -march=native -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref

Compiler output

Implementation: crypto_sign/rainbowbinary16242020/ref
Compiler: clang++ -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
rainbow-test.cpp: In file included from rainbow-test.cpp:1:
rainbow-test.cpp: ./gf.h:171:46: warning: while loop has empty body [-Wempty-body]
rainbow-test.cpp: if( M==n_read ) { while( ttt.set(fp)==16 ) ; break; }
rainbow-test.cpp: ^
rainbow-test.cpp: ./gf.h:171:46: note: put the semicolon on a separate line to silence this warning
rainbow-test.cpp: In file included from rainbow-test.cpp:1:
rainbow-test.cpp: In file included from ./gf.h:181:
rainbow-test.cpp: ./gf16.h:321:9: error: always_inline function '_mm_shuffle_epi8' requires target feature 'ssse3', but would be inlined into function '_mul' that is compiled without support for 'ssse3'
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: fatal error: error in backend: Cannot select: 0x3d22330: v16i8 = X86ISD::PSHUFB 0x3d21b70, 0x3d23b90
rainbow-test.cpp: 0x3d21b70: v16i8 = bitcast 0x3d031d0
rainbow-test.cpp: 0x3d031d0: v2i64,ch = loadgt;)(noalias=gt;,gt;,gt;)>gt; 0x3b6a050, 0x3d23340, undef:i64
rainbow-test.cpp: 0x3d23340: i64 = add 0x3d24480, 0x3d25f40
rainbow-test.cpp: 0x3d24480: i64 = X86ISD::Wrapper TargetGlobalAddress:i64gt;]* @_ZL8GFV16Mul>gt; 0
rainbow-test.cpp: 0x3d26cf0: i64 = TargetGlobalAddressgt;]* @_ZL8GFV16Mul>gt; 0
rainbow-test.cpp: 0x3d25f40: i64 = shl 0x3d23930, Constant:i8gt;
rainbow-test.cpp: 0x3d23930: i64,ch = loadgt;)(noalias=gt;,gt;,gt;), zext from i8>gt; 0x3b6a050, 0x3d02f70, undef:i64
rainbow-test.cpp: 0x3d02f70: i64 = or 0x3d2fee0, 0x3d02d10
rainbow-test.cpp: 0x3d2fee0: i64 = add FrameIndex:i64gt;, 0x3d23210
rainbow-test.cpp: 0x3d21ca0: i64 = FrameIndexgt;
rainbow-test.cpp: 0x3d23210: i64 = and 0x3d2e710, Constant:i64gt;
rainbow-test.cpp: 0x3d2e710: i64,ch = CopyFromReg 0x3b6a050, Register:i64 %vreg3
rainbow-test.cpp:
rainbow-test.cpp: 0x3d25e10: i64 = Constantgt;
rainbow-test.cpp: ...

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang++ -mcpu=cortex-a8 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref

Compiler output

Implementation: crypto_sign/rainbowbinary16242020/ref
Compiler: clang++ -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
rainbow-test.cpp: In file included from rainbow-test.cpp:1:
rainbow-test.cpp: ./gf.h:171:46: warning: while loop has empty body [-Wempty-body]
rainbow-test.cpp: if( M==n_read ) { while( ttt.set(fp)==16 ) ; break; }
rainbow-test.cpp: ^
rainbow-test.cpp: ./gf.h:171:46: note: put the semicolon on a separate line to silence this warning
rainbow-test.cpp: In file included from rainbow-test.cpp:1:
rainbow-test.cpp: In file included from ./gf.h:181:
rainbow-test.cpp: ./gf16.h:321:9: error: always_inline function '_mm_shuffle_epi8' requires target feature 'ssse3', but would be inlined into function '_mul' that is compiled without support for 'ssse3'
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: fatal error: error in backend: Cannot select: 0x40f7bc0: v16i8 = X86ISD::PSHUFB 0x40f7400, 0x40f9420
rainbow-test.cpp: 0x40f7400: v16i8 = bitcast 0x3fb24e0
rainbow-test.cpp: 0x3fb24e0: v2i64,ch = loadgt;)(noalias=gt;,gt;,gt;)>gt; 0x3f3f090, 0x40f8bd0, undef:i64
rainbow-test.cpp: 0x40f8bd0: i64 = add 0x40f9d10, 0x40fb7d0
rainbow-test.cpp: 0x40f9d10: i64 = X86ISD::Wrapper TargetGlobalAddress:i64gt;]* @_ZL8GFV16Mul>gt; 0
rainbow-test.cpp: 0x40fc580: i64 = TargetGlobalAddressgt;]* @_ZL8GFV16Mul>gt; 0
rainbow-test.cpp: 0x40fb7d0: i64 = shl 0x40f91c0, Constant:i8gt;
rainbow-test.cpp: 0x40f91c0: i64,ch = loadgt;)(noalias=gt;,gt;,gt;), zext from i8>gt; 0x3f3f090, 0x3fb2280, undef:i64
rainbow-test.cpp: 0x3fb2280: i64 = or 0x4105770, 0x3fb2020
rainbow-test.cpp: 0x4105770: i64 = add FrameIndex:i64gt;, 0x40f8aa0
rainbow-test.cpp: 0x40f7530: i64 = FrameIndexgt;
rainbow-test.cpp: 0x40f8aa0: i64 = and 0x4103fa0, Constant:i64gt;
rainbow-test.cpp: 0x4103fa0: i64,ch = CopyFromReg 0x3f3f090, Register:i64 %vreg3
rainbow-test.cpp:
rainbow-test.cpp: 0x40fb6a0: i64 = Constantgt;
rainbow-test.cpp: ...

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
clang++ -mcpu=cortex-a9 -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments ref

Compiler output

Implementation: crypto_sign/rainbowbinary16242020/ref
Compiler: clang++ -mcpu=native -mfpu=neon -O3 -fomit-frame-pointer -fwrapv -Qunused-arguments
rainbow-test.cpp: In file included from rainbow-test.cpp:1:
rainbow-test.cpp: ./gf.h:171:46: warning: while loop has empty body [-Wempty-body]
rainbow-test.cpp: if( M==n_read ) { while( ttt.set(fp)==16 ) ; break; }
rainbow-test.cpp: ^
rainbow-test.cpp: ./gf.h:171:46: note: put the semicolon on a separate line to silence this warning
rainbow-test.cpp: In file included from rainbow-test.cpp:1:
rainbow-test.cpp: In file included from ./gf.h:181:
rainbow-test.cpp: ./gf16.h:321:9: error: always_inline function '_mm_shuffle_epi8' requires target feature 'ssse3', but would be inlined into function '_mul' that is compiled without support for 'ssse3'
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: fatal error: error in backend: Cannot select: 0x24ac9e0: v16i8 = X86ISD::PSHUFB 0x24ac220, 0x24ae240
rainbow-test.cpp: 0x24ac220: v16i8 = bitcast 0x24b35d0
rainbow-test.cpp: 0x24b35d0: v2i64,ch = loadgt;)(noalias=gt;,gt;,gt;)>gt; 0x232f0e0, 0x24ad9f0, undef:i64
rainbow-test.cpp: 0x24ad9f0: i64 = add 0x24e1c70, 0x24e3730
rainbow-test.cpp: 0x24e1c70: i64 = X86ISD::Wrapper TargetGlobalAddress:i64gt;]* @_ZL8GFV16Mul>gt; 0
rainbow-test.cpp: 0x24e44e0: i64 = TargetGlobalAddressgt;]* @_ZL8GFV16Mul>gt; 0
rainbow-test.cpp: 0x24e3730: i64 = shl 0x24adfe0, Constant:i8gt;
rainbow-test.cpp: 0x24adfe0: i64,ch = loadgt;)(noalias=gt;,gt;,gt;), zext from i8>gt; 0x232f0e0, 0x24b3370, undef:i64
rainbow-test.cpp: 0x24b3370: i64 = or 0x24f6020, 0x24b3110
rainbow-test.cpp: 0x24f6020: i64 = add FrameIndex:i64gt;, 0x24ad8c0
rainbow-test.cpp: 0x24ac350: i64 = FrameIndexgt;
rainbow-test.cpp: 0x24ad8c0: i64 = and 0x24ebf00, Constant:i64gt;
rainbow-test.cpp: 0x24ebf00: i64,ch = CopyFromReg 0x232f0e0, Register:i64 %vreg3
rainbow-test.cpp:
rainbow-test.cpp: 0x24e3600: i64 = Constantgt;
rainbow-test.cpp: ...

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

Compiler output

Implementation: crypto_sign/rainbowbinary16242020/ref
Compiler: g++
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h: In function 'const gfv_unitgt; _mul(const gfv_unitgt;&, const gfgt;&) [with unsigned int p = 16u]':
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '__m128i _mm_shuffle_epi8(__m128i, __m128i)': target specific option mismatch
rainbow-test.cpp: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf.h:181:0,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: gf16.h:321:25: error: called from here
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
g++ ref

Compiler output

Implementation: crypto_sign/rainbowbinary16242020/ref
Compiler: g++ -O2 -fomit-frame-pointer
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h: In function 'const gfv_unitgt; _mul(const gfv_unitgt;&, const gfgt;&) [with unsigned int p = 16u]':
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '__m128i _mm_shuffle_epi8(__m128i, __m128i)': target specific option mismatch
rainbow-test.cpp: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf.h:181:0,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: gf16.h:321:25: error: called from here
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '__m128i _mm_shuffle_epi8(__m128i, __m128i)': target specific option mismatch
rainbow-test.cpp: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf.h:181:0,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: gf16.h:321:25: error: called from here
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: ...

Number of similar (compiler,implementation) pairs: 27, namely:
CompilerImplementations
g++ -O2 -fomit-frame-pointer ref
g++ -O3 -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 -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 -Os -fomit-frame-pointer ref
g++ -m64 -O2 -fomit-frame-pointer ref
g++ -m64 -O3 -fomit-frame-pointer ref
g++ -m64 -Os -fomit-frame-pointer ref
g++ -m64 -march=k8 -O2 -fomit-frame-pointer ref
g++ -m64 -march=k8 -O3 -fomit-frame-pointer ref
g++ -m64 -march=k8 -Os -fomit-frame-pointer ref
g++ -m64 -march=nocona -O2 -fomit-frame-pointer ref
g++ -m64 -march=nocona -O3 -fomit-frame-pointer ref
g++ -m64 -march=nocona -Os -fomit-frame-pointer ref
g++ -march=barcelona -O2 -fomit-frame-pointer ref
g++ -march=barcelona -O3 -fomit-frame-pointer ref
g++ -march=barcelona -Os -fomit-frame-pointer ref
g++ -march=k8 -O2 -fomit-frame-pointer ref
g++ -march=k8 -O3 -fomit-frame-pointer ref
g++ -march=k8 -Os -fomit-frame-pointer ref
g++ -march=nocona -O2 -fomit-frame-pointer ref
g++ -march=nocona -O3 -fomit-frame-pointer ref
g++ -march=nocona -Os -fomit-frame-pointer ref

Compiler output

Implementation: crypto_sign/rainbowbinary16242020/ref
Compiler: g++ -O -fomit-frame-pointer
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h: In function 'const gfv_unitgt; _mul(const gfv_unitgt;&, const gfgt;&) [with unsigned int p = 16u]':
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '__m128i _mm_shuffle_epi8(__m128i, __m128i)': target specific option mismatch
rainbow-test.cpp: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf.h:181:0,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: gf16.h:321:25: error: called from here
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '__m128i _mm_shuffle_epi8(__m128i, __m128i)': target specific option mismatch
rainbow-test.cpp: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf.h:181:0,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: gf16.h:321:25: error: called from here
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^

Number of similar (compiler,implementation) pairs: 9, namely:
CompilerImplementations
g++ -O -fomit-frame-pointer ref
g++ -fno-schedule-insns -O -fomit-frame-pointer ref
g++ -funroll-loops -fno-schedule-insns -O -fomit-frame-pointer ref
g++ -m64 -O -fomit-frame-pointer ref
g++ -m64 -march=k8 -O -fomit-frame-pointer ref
g++ -m64 -march=nocona -O -fomit-frame-pointer ref
g++ -march=barcelona -O -fomit-frame-pointer ref
g++ -march=k8 -O -fomit-frame-pointer ref
g++ -march=nocona -O -fomit-frame-pointer ref

Compiler output

Implementation: crypto_sign/rainbowbinary16242020/ref
Compiler: g++ -m64 -march=barcelona -O2 -fomit-frame-pointer
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h: In function 'const gfv_unitgt; _mul(const gfv_unitgt;&, const gfgt;&) [with unsigned int p = 16u]':
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '__m128i _mm_shuffle_epi8(__m128i, __m128i)': target specific option mismatch
rainbow-test.cpp: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf.h:181:0,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: gf16.h:321:25: error: called from here
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '__m128i _mm_shuffle_epi8(__m128i, __m128i)': target specific option mismatch
rainbow-test.cpp: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf.h:181:0,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: gf16.h:321:25: error: called from here
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: ...
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h: In function 'const gfv_unitgt; _mul(const gfv_unitgt;&, const gfgt;&) [with unsigned int p = 16u]':
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '__m128i _mm_shuffle_epi8(__m128i, __m128i)': target specific option mismatch
rainbow-test.cpp: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf.h:181:0,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: gf16.h:321:25: error: called from here
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '__m128i _mm_shuffle_epi8(__m128i, __m128i)': target specific option mismatch
rainbow-test.cpp: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf.h:181:0,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: gf16.h:321:25: error: called from here
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: ...

Number of similar (compiler,implementation) pairs: 3, namely:
CompilerImplementations
g++ -m64 -march=barcelona -O2 -fomit-frame-pointer ref
g++ -m64 -march=barcelona -O3 -fomit-frame-pointer ref
g++ -m64 -march=barcelona -Os -fomit-frame-pointer ref

Compiler output

Implementation: crypto_sign/rainbowbinary16242020/ref
Compiler: g++ -m64 -march=barcelona -O -fomit-frame-pointer
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h: In function 'const gfv_unitgt; _mul(const gfv_unitgt;&, const gfgt;&) [with unsigned int p = 16u]':
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '__m128i _mm_shuffle_epi8(__m128i, __m128i)': target specific option mismatch
rainbow-test.cpp: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf.h:181:0,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: gf16.h:321:25: error: called from here
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '__m128i _mm_shuffle_epi8(__m128i, __m128i)': target specific option mismatch
rainbow-test.cpp: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf.h:181:0,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: gf16.h:321:25: error: called from here
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h: In function 'const gfv_unitgt; _mul(const gfv_unitgt;&, const gfgt;&) [with unsigned int p = 16u]':
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '__m128i _mm_shuffle_epi8(__m128i, __m128i)': target specific option mismatch
rainbow-test.cpp: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf.h:181:0,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: gf16.h:321:25: error: called from here
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf16.h:4:0,
rainbow-test.cpp: from gf.h:181,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: /usr/lib/gcc/x86_64-linux-gnu/5/include/tmmintrin.h:136:1: error: inlining failed in call to always_inline '__m128i _mm_shuffle_epi8(__m128i, __m128i)': target specific option mismatch
rainbow-test.cpp: _mm_shuffle_epi8 (__m128i __X, __m128i __Y)
rainbow-test.cpp: ^
rainbow-test.cpp: In file included from gf.h:181:0,
rainbow-test.cpp: from rainbow-test.cpp:1:
rainbow-test.cpp: gf16.h:321:25: error: called from here
rainbow-test.cpp: return _mm_shuffle_epi8(multable(b.v), a.v);
rainbow-test.cpp: ^

Number of similar (compiler,implementation) pairs: 1, namely:
CompilerImplementations
g++ -m64 -march=barcelona -O -fomit-frame-pointer ref