Implementation notes: x86, gpu, crypto_decode/256x2

Computer: gpu
Architecture: x86
CPU ID: GenuineIntel-000206d7-bfebfbff
SUPERCOP version: 20190816
Operation: crypto_decode
Primitive: 256x2
TimeObject sizeTest sizeImplementationCompilerBenchmark dateSUPERCOP version
108085 0 010376 384 736refgcc_-funroll-loops_-m32_-march=i386_-Os_-fomit-frame-pointer2019082020190816
1395294 0 015189 396 736refgcc_-funroll-loops_-m32_-march=k6_-O2_-fomit-frame-pointer2019082020190816
1456295 0 015713 396 736refgcc_-funroll-loops_-m32_-march=pentium4_-O3_-fomit-frame-pointer2019082020190816
1479326 0 015216 392 736refgcc_-funroll-loops_-m32_-march=pentium3_-O2_-fomit-frame-pointer2019082020190816
1488111 0 011645 396 736refgcc_-m32_-O2_-fomit-frame-pointer2019082020190816
1520294 0 016242 400 736refgcc_-funroll-loops_-m32_-march=k6_-O3_-fomit-frame-pointer2019082020190816
1536299 0 017205 396 736refgcc_-funroll-loops_-m32_-march=k8_-O3_-fomit-frame-pointer2019082020190816
1539107 0 011364 392 736refgcc_-m32_-march=pentium4_-O2_-fomit-frame-pointer2019082020190816
1566315 0 017769 396 736refgcc_-funroll-loops_-m32_-march=barcelona_-O3_-fomit-frame-pointer2019082020190816
1569299 0 015213 396 736refgcc_-funroll-loops_-m32_-march=athlon_-O2_-fomit-frame-pointer2019082020190816
1584313 0 015301 396 736refgcc_-funroll-loops_-m32_-march=athlon_-O_-fomit-frame-pointer2019082020190816
1587294 0 015189 396 736refgcc_-funroll-loops_-m32_-march=k6-3_-O2_-fomit-frame-pointer2019082020190816
1596305 0 015297 396 736refgcc_-funroll-loops_-m32_-march=k6-2_-O_-fomit-frame-pointer2019082020190816
1599111 0 014562 400 736refgcc_-m32_-march=native_-mtune=native_-O3_-fomit-frame-pointer2019082020190816
1620294 0 015189 396 736refgcc_-funroll-loops_-m32_-march=k6-2_-O2_-fomit-frame-pointer2019082020190816
1620105 0 011176 392 736refgcc_-m32_-march=i386_-O2_-fomit-frame-pointer2019082020190816
1623109 0 011620 392 736refgcc_-m32_-march=pentiumpro_-O2_-fomit-frame-pointer2019082020190816
1624305 0 015297 396 736refgcc_-funroll-loops_-m32_-march=k6_-O_-fomit-frame-pointer2019082020190816
1640108 0 011156 392 736refgcc_-m32_-march=i386_-O_-fomit-frame-pointer2019082020190816
1650313 0 015496 392 736refgcc_-funroll-loops_-m32_-march=k8_-O_-fomit-frame-pointer2019082020190816
1652299 0 016322 400 736refgcc_-funroll-loops_-m32_-O3_-fomit-frame-pointer2019082020190816
1653323 0 015472 392 736refgcc_-funroll-loops_-m32_-march=pentiumpro_-O_-fomit-frame-pointer2019082020190816
1668323 0 015472 392 736refgcc_-funroll-loops_-m32_-march=pentium2_-O_-fomit-frame-pointer2019082020190816
1668250 0 015113 396 736refgcc_-m32_-march=barcelona_-O3_-fomit-frame-pointer2019082020190816
1672305 0 015297 396 736refgcc_-funroll-loops_-m32_-march=k6-3_-O_-fomit-frame-pointer2019082020190816
1676299 0 016686 400 736refgcc_-funroll-loops_-m32_-march=athlon_-O3_-fomit-frame-pointer2019082020190816
1677295 0 015028 392 736refgcc_-funroll-loops_-m32_-march=pentium4_-O2_-fomit-frame-pointer2019082020190816
168485 0 010328 384 736refgcc_-m32_-march=pentium2_-Os_-fomit-frame-pointer2019082020190816
1698109 0 014222 400 736refgcc_-m32_-march=athlon_-O3_-fomit-frame-pointer2019082020190816
1708315 0 015776 392 736refgcc_-funroll-loops_-m32_-march=barcelona_-O2_-fomit-frame-pointer2019082020190816
1712294 0 016850 400 736refgcc_-funroll-loops_-m32_-march=k6-3_-O3_-fomit-frame-pointer2019082020190816
1719111 0 011665 396 736refgcc_-m32_-march=core-avx-i_-O2_-fomit-frame-pointer2019082020190816
1720107 0 014033 396 736refgcc_-m32_-march=nocona_-O3_-fomit-frame-pointer2019082020190816
1725325 0 015628 392 736refgcc_-funroll-loops_-m32_-march=prescott_-O_-fomit-frame-pointer2019082020190816
1728313 0 015488 392 736refgcc_-funroll-loops_-m32_-march=barcelona_-O_-fomit-frame-pointer2019082020190816
1732323 0 015472 392 736refgcc_-funroll-loops_-m32_-march=pentium3_-O_-fomit-frame-pointer2019082020190816
174085 0 010408 384 736refgcc_-funroll-loops_-m32_-march=prescott_-Os_-fomit-frame-pointer2019082020190816
1748313 0 015277 396 736refgcc_-funroll-loops_-m32_-O_-fomit-frame-pointer2019082020190816
1752112 0 014609 396 736refgcc_-m32_-march=pentium_-O3_-fomit-frame-pointer2019082020190816
1755111 0 014294 400 736refgcc_-m32_-march=core2_-msse4_-O3_-fomit-frame-pointer2019082020190816
1755111 0 011665 396 736refgcc_-m32_-march=native_-mtune=native_-O2_-fomit-frame-pointer2019082020190816
1758326 0 017124 392 736refgcc_-funroll-loops_-m32_-march=pentium2_-O3_-fomit-frame-pointer2019082020190816
1764374 0 015568 392 736refgcc_-funroll-loops_-m32_-march=i486_-O2_-fomit-frame-pointer2019082020190816
1768105 0 013032 392 736refgcc_-m32_-march=i386_-O3_-fomit-frame-pointer2019082020190816
1776111 0 014306 400 736refgcc_-m32_-march=core2_-O3_-fomit-frame-pointer2019082020190816
178285 0 010408 384 736refgcc_-m32_-march=core2_-msse4_-Os_-fomit-frame-pointer2019082020190816
1785110 0 011345 396 736refgcc_-m32_-march=corei7_-O_-fomit-frame-pointer2019082020190816
1788111 0 011857 396 736refgcc_-m32_-march=k6_-O2_-fomit-frame-pointer2019082020190816
1792326 0 017124 392 736refgcc_-funroll-loops_-m32_-march=pentiumpro_-O3_-fomit-frame-pointer2019082020190816
1794326 0 015216 392 736refgcc_-funroll-loops_-m32_-march=pentium2_-O2_-fomit-frame-pointer2019082020190816
179785 0 010392 384 736refgcc_-m32_-march=i386_-Os_-fomit-frame-pointer2019082020190816
1804299 0 015261 396 736refgcc_-funroll-loops_-m32_-O2_-fomit-frame-pointer2019082020190816
1820323 0 015592 392 736refgcc_-funroll-loops_-m32_-march=pentium-m_-O_-fomit-frame-pointer2019082020190816
1820323 0 015176 392 736refgcc_-funroll-loops_-m32_-march=prescott_-O2_-fomit-frame-pointer2019082020190816
1820111 0 014658 400 736refgcc_-m32_-march=k6_-O3_-fomit-frame-pointer2019082020190816
1827374 0 016485 396 736refgcc_-funroll-loops_-m32_-march=pentium-mmx_-O3_-fomit-frame-pointer2019082020190816
1828299 0 015160 392 736refgcc_-funroll-loops_-m32_-march=k8_-O2_-fomit-frame-pointer2019082020190816
1832216 0 011388 392 736refgcc_-m32_-march=barcelona_-O_-fomit-frame-pointer2019082020190816
1844294 0 016850 400 736refgcc_-funroll-loops_-m32_-march=k6-2_-O3_-fomit-frame-pointer2019082020190816
1844326 0 017332 392 736refgcc_-funroll-loops_-m32_-march=pentium3_-O3_-fomit-frame-pointer2019082020190816
1848313 0 015596 392 736refgcc_-funroll-loops_-m32_-march=pentium4_-O_-fomit-frame-pointer2019082020190816
1848111 0 011697 396 736refgcc_-m32_-march=core2_-O2_-fomit-frame-pointer2019082020190816
1851107 0 013981 396 736refgcc_-m32_-march=pentium4_-O3_-fomit-frame-pointer2019082020190816
1856110 0 011345 396 736refgcc_-m32_-march=corei7-avx_-O_-fomit-frame-pointer2019082020190816
1856111 0 014850 400 736refgcc_-m32_-march=k6-2_-O3_-fomit-frame-pointer2019082020190816
1860107 0 014033 396 736refgcc_-m32_-march=prescott_-O3_-fomit-frame-pointer2019082020190816
186485 0 010360 384 736refgcc_-funroll-loops_-m32_-march=pentium_-Os_-fomit-frame-pointer2019082020190816
1876323 0 015176 392 736refgcc_-funroll-loops_-m32_-march=nocona_-O2_-fomit-frame-pointer2019082020190816
1888110 0 011345 396 736refgcc_-m32_-march=core2_-msse4.1_-O_-fomit-frame-pointer2019082020190816
1892109 0 011437 396 736refgcc_-m32_-march=k6-3_-O_-fomit-frame-pointer2019082020190816
1896326 0 015216 392 736refgcc_-funroll-loops_-m32_-march=pentiumpro_-O2_-fomit-frame-pointer2019082020190816
1896108 0 011328 392 736refgcc_-m32_-march=pentium2_-O_-fomit-frame-pointer2019082020190816
1896108 0 011328 392 736refgcc_-m32_-march=pentiumpro_-O_-fomit-frame-pointer2019082020190816
1916326 0 014796 392 736refgcc_-funroll-loops_-m32_-march=i386_-O3_-fomit-frame-pointer2019082020190816
1936323 0 015781 396 736refgcc_-funroll-loops_-m32_-march=nocona_-O3_-fomit-frame-pointer2019082020190816
1940107 0 011364 392 736refgcc_-m32_-march=nocona_-O2_-fomit-frame-pointer2019082020190816
1941108 0 011328 392 736refgcc_-m32_-march=pentium3_-O_-fomit-frame-pointer2019082020190816
1952323 0 015096 392 736refgcc_-funroll-loops_-m32_-march=i386_-O_-fomit-frame-pointer2019082020190816
1952374 0 016052 392 736refgcc_-funroll-loops_-m32_-march=i486_-O3_-fomit-frame-pointer2019082020190816
1952323 0 015781 396 736refgcc_-funroll-loops_-m32_-march=prescott_-O3_-fomit-frame-pointer2019082020190816
1952111 0 011681 396 736refgcc_-m32_-march=corei7_-O2_-fomit-frame-pointer2019082020190816
1960374 0 015493 396 736refgcc_-funroll-loops_-m32_-march=pentium-mmx_-O2_-fomit-frame-pointer2019082020190816
1964326 0 017204 392 736refgcc_-funroll-loops_-m32_-march=pentium-m_-O3_-fomit-frame-pointer2019082020190816
1968108 0 011336 392 736refgcc_-m32_-march=k8_-O_-fomit-frame-pointer2019082020190816
196885 0 010392 384 736refgcc_-m32_-march=native_-mtune=native_-Os_-fomit-frame-pointer2019082020190816
1968109 0 014480 392 736refgcc_-m32_-march=pentiumpro_-O3_-fomit-frame-pointer2019082020190816
1971112 0 014609 396 736refgcc_-m32_-march=pentium-mmx_-O3_-fomit-frame-pointer2019082020190816
1976326 0 014836 392 736refgcc_-funroll-loops_-m32_-march=i386_-O2_-fomit-frame-pointer2019082020190816
197685 0 010312 384 736refgcc_-funroll-loops_-m32_-march=pentium3_-Os_-fomit-frame-pointer2019082020190816
1984325 0 015628 392 736refgcc_-funroll-loops_-m32_-march=nocona_-O_-fomit-frame-pointer2019082020190816
199585 0 010392 384 736refgcc_-m32_-march=athlon_-Os_-fomit-frame-pointer2019082020190816
200185 0 010424 384 736refgcc_-m32_-march=pentium4_-Os_-fomit-frame-pointer2019082020190816
2004109 0 014480 392 736refgcc_-m32_-march=pentium2_-O3_-fomit-frame-pointer2019082020190816
2008111 0 011681 396 736refgcc_-m32_-march=core2_-msse4_-O2_-fomit-frame-pointer2019082020190816
2008107 0 011364 392 736refgcc_-m32_-march=prescott_-O2_-fomit-frame-pointer2019082020190816
2020109 0 011620 392 736refgcc_-m32_-march=pentium3_-O2_-fomit-frame-pointer2019082020190816
202485 0 010376 384 736refgcc_-funroll-loops_-m32_-march=athlon_-Os_-fomit-frame-pointer2019082020190816
2028373 0 015400 392 736refgcc_-funroll-loops_-m32_-march=i486_-O_-fomit-frame-pointer2019082020190816
2028110 0 011305 396 736refgcc_-m32_-O_-fomit-frame-pointer2019082020190816
2031110 0 011345 396 736refgcc_-m32_-march=core2_-O_-fomit-frame-pointer2019082020190816
203285 0 010376 384 736refgcc_-funroll-loops_-m32_-march=i486_-Os_-fomit-frame-pointer2019082020190816
203485 0 010376 384 736refgcc_-funroll-loops_-m32_-Os_-fomit-frame-pointer2019082020190816
2040326 0 016028 392 736refgcc_-funroll-loops_-m32_-march=pentium-m_-O2_-fomit-frame-pointer2019082020190816
205285 0 010312 384 736refgcc_-funroll-loops_-m32_-march=pentium2_-Os_-fomit-frame-pointer2019082020190816
2052111 0 011857 396 736refgcc_-m32_-march=k6-2_-O2_-fomit-frame-pointer2019082020190816
2058111 0 014850 400 736refgcc_-m32_-march=k6-3_-O3_-fomit-frame-pointer2019082020190816
2060111 0 011681 396 736refgcc_-m32_-march=core2_-msse4.1_-O2_-fomit-frame-pointer2019082020190816
2080109 0 011517 396 736refgcc_-m32_-march=athlon_-O2_-fomit-frame-pointer2019082020190816
2088111 0 011665 396 736refgcc_-m32_-march=corei7-avx_-O2_-fomit-frame-pointer2019082020190816
2088109 0 014757 396 736refgcc_-m32_-march=k8_-O3_-fomit-frame-pointer2019082020190816
2092100 0 010496 384 736refgcc_-m32_-march=k6_-Os_-fomit-frame-pointer2019082020190816
2096374 0 015493 396 736refgcc_-funroll-loops_-m32_-march=pentium_-O2_-fomit-frame-pointer2019082020190816
210085 0 010376 384 736refgcc_-m32_-march=pentium-m_-Os_-fomit-frame-pointer2019082020190816
2104373 0 015325 396 736refgcc_-funroll-loops_-m32_-march=pentium-mmx_-O_-fomit-frame-pointer2019082020190816
2104112 0 014244 392 736refgcc_-m32_-march=i486_-O3_-fomit-frame-pointer2019082020190816
2112108 0 011368 392 736refgcc_-m32_-march=pentium-m_-O_-fomit-frame-pointer2019082020190816
211285 0 010328 384 736refgcc_-m32_-march=pentium3_-Os_-fomit-frame-pointer2019082020190816
211685 0 010408 384 736refgcc_-funroll-loops_-m32_-march=nocona_-Os_-fomit-frame-pointer2019082020190816
2116111 0 014562 400 736refgcc_-m32_-march=core-avx-i_-O3_-fomit-frame-pointer2019082020190816
212485 0 010392 384 736refgcc_-m32_-march=corei7-avx_-Os_-fomit-frame-pointer2019082020190816
2124109 0 011437 396 736refgcc_-m32_-march=k6-2_-O_-fomit-frame-pointer2019082020190816
2124111 0 011857 396 736refgcc_-m32_-march=k6-3_-O2_-fomit-frame-pointer2019082020190816
2124110 0 011420 392 736refgcc_-m32_-march=prescott_-O_-fomit-frame-pointer2019082020190816
2128373 0 015325 396 736refgcc_-funroll-loops_-m32_-march=pentium_-O_-fomit-frame-pointer2019082020190816
213285 0 010408 384 736refgcc_-funroll-loops_-m32_-march=barcelona_-Os_-fomit-frame-pointer2019082020190816
2136111 0 011305 396 736refgcc_-m32_-march=pentium_-O_-fomit-frame-pointer2019082020190816
214085 0 010424 384 736refgcc_-m32_-march=k8_-Os_-fomit-frame-pointer2019082020190816
2151100 0 010480 384 736refgcc_-funroll-loops_-m32_-march=k6-2_-Os_-fomit-frame-pointer2019082020190816
2152109 0 014688 392 736refgcc_-m32_-march=pentium3_-O3_-fomit-frame-pointer2019082020190816
2168110 0 011345 396 736refgcc_-m32_-march=core2_-msse4_-O_-fomit-frame-pointer2019082020190816
2168110 0 011420 392 736refgcc_-m32_-march=nocona_-O_-fomit-frame-pointer2019082020190816
2169109 0 011437 396 736refgcc_-m32_-march=k6_-O_-fomit-frame-pointer2019082020190816
2172110 0 011345 396 736refgcc_-m32_-march=native_-mtune=native_-O_-fomit-frame-pointer2019082020190816
2172109 0 011976 392 736refgcc_-m32_-march=pentium-m_-O2_-fomit-frame-pointer2019082020190816
2176100 0 010496 384 736refgcc_-m32_-march=k6-3_-Os_-fomit-frame-pointer2019082020190816
2184100 0 010480 384 736refgcc_-funroll-loops_-m32_-march=k6_-Os_-fomit-frame-pointer2019082020190816
2188110 0 011345 396 736refgcc_-m32_-march=core-avx-i_-O_-fomit-frame-pointer2019082020190816
2192112 0 011621 396 736refgcc_-m32_-march=pentium-mmx_-O2_-fomit-frame-pointer2019082020190816
219685 0 010408 384 736refgcc_-funroll-loops_-m32_-march=k8_-Os_-fomit-frame-pointer2019082020190816
220485 0 010312 384 736refgcc_-funroll-loops_-m32_-march=pentiumpro_-Os_-fomit-frame-pointer2019082020190816
221185 0 010392 384 736refgcc_-m32_-march=pentium_-Os_-fomit-frame-pointer2019082020190816
224485 0 010424 384 736refgcc_-m32_-march=prescott_-Os_-fomit-frame-pointer2019082020190816
2256111 0 014142 400 736refgcc_-m32_-O3_-fomit-frame-pointer2019082020190816
2256108 0 011221 396 736refgcc_-m32_-march=athlon_-O_-fomit-frame-pointer2019082020190816
227285 0 010360 384 736refgcc_-funroll-loops_-m32_-march=pentium-m_-Os_-fomit-frame-pointer2019082020190816
2272374 0 016485 396 736refgcc_-funroll-loops_-m32_-march=pentium_-O3_-fomit-frame-pointer2019082020190816
227285 0 010392 384 736refgcc_-m32_-march=i486_-Os_-fomit-frame-pointer2019082020190816
2272100 0 010496 384 736refgcc_-m32_-march=k6-2_-Os_-fomit-frame-pointer2019082020190816
2272110 0 011436 392 736refgcc_-m32_-march=pentium4_-O_-fomit-frame-pointer2019082020190816
2280109 0 011688 392 736refgcc_-m32_-march=k8_-O2_-fomit-frame-pointer2019082020190816
2288109 0 011620 392 736refgcc_-m32_-march=pentium2_-O2_-fomit-frame-pointer2019082020190816
228985 0 010328 384 736refgcc_-m32_-march=pentiumpro_-Os_-fomit-frame-pointer2019082020190816
230485 0 010360 384 736refgcc_-funroll-loops_-m32_-march=pentium-mmx_-Os_-fomit-frame-pointer2019082020190816
2328109 0 014868 392 736refgcc_-m32_-march=pentium-m_-O3_-fomit-frame-pointer2019082020190816
2332111 0 014242 400 736refgcc_-m32_-march=core2_-msse4.1_-O3_-fomit-frame-pointer2019082020190816
2332111 0 014294 400 736refgcc_-m32_-march=corei7_-O3_-fomit-frame-pointer2019082020190816
233685 0 010424 384 736refgcc_-m32_-march=nocona_-Os_-fomit-frame-pointer2019082020190816
234485 0 010392 384 736refgcc_-m32_-Os_-fomit-frame-pointer2019082020190816
2348250 0 012292 392 736refgcc_-m32_-march=barcelona_-O2_-fomit-frame-pointer2019082020190816
236885 0 010408 384 736refgcc_-m32_-march=corei7_-Os_-fomit-frame-pointer2019082020190816
238085 0 010392 384 736refgcc_-m32_-march=core-avx-i_-Os_-fomit-frame-pointer2019082020190816
2396111 0 014562 400 736refgcc_-m32_-march=corei7-avx_-O3_-fomit-frame-pointer2019082020190816
2404170 0 010424 384 736refgcc_-m32_-march=barcelona_-Os_-fomit-frame-pointer2019082020190816
2412112 0 011776 392 736refgcc_-m32_-march=i486_-O2_-fomit-frame-pointer2019082020190816
2416111 0 011305 396 736refgcc_-m32_-march=pentium-mmx_-O_-fomit-frame-pointer2019082020190816
242485 0 010392 384 736refgcc_-m32_-march=pentium-mmx_-Os_-fomit-frame-pointer2019082020190816
245285 0 010408 384 736refgcc_-funroll-loops_-m32_-march=pentium4_-Os_-fomit-frame-pointer2019082020190816
248085 0 010424 384 736refgcc_-m32_-march=core2_-Os_-fomit-frame-pointer2019082020190816
250085 0 010408 384 736refgcc_-m32_-march=core2_-msse4.1_-Os_-fomit-frame-pointer2019082020190816
2516112 0 011621 396 736refgcc_-m32_-march=pentium_-O2_-fomit-frame-pointer2019082020190816
2538111 0 011380 392 736refgcc_-m32_-march=i486_-O_-fomit-frame-pointer2019082020190816
2816100 0 010480 384 736refgcc_-funroll-loops_-m32_-march=k6-3_-Os_-fomit-frame-pointer2019082020190816

Test failure

Implementation: avx
Security model: unknown
Compiler: gcc -m32 -march=core-avx2 -O2 -fomit-frame-pointer
error 111

Number of similar (compiler,implementation) pairs: 6, namely:
CompilerImplementations
gcc -m32 -march=core-avx2 -O2 -fomit-frame-pointer avx
gcc -m32 -march=core-avx2 -O -fomit-frame-pointer avx
gcc -m32 -march=core-avx2 -Os -fomit-frame-pointer avx
gcc -m32 -march=core-avx2 -O2 -fomit-frame-pointer ref
gcc -m32 -march=core-avx2 -O -fomit-frame-pointer ref
gcc -m32 -march=core-avx2 -Os -fomit-frame-pointer ref

Compiler output

Implementation: avx
Security model: unknown
Compiler: gcc -funroll-loops -m32 -O2 -fomit-frame-pointer
decode.c: decode.c: In function 'crypto_decode_256x2_avx':
decode.c: decode.c:16:13: warning: AVX vector return without AVX enabled changes the ABI [-Wpsabi]
decode.c: __m256i x = _mm256_set1_epi32(*(int32_t *) s);
decode.c: ^
decode.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/immintrin.h:41:0,
decode.c: from decode.c:1:
decode.c: /usr/lib/gcc/x86_64-linux-gnu/7/include/avxintrin.h:925:1: error: inlining failed in call to always_inline '_mm256_storeu_si256': target specific option mismatch
decode.c: _mm256_storeu_si256 (__m256i_u *__P, __m256i __A)
decode.c: ^~~~~~~~~~~~~~~~~~~
decode.c: decode.c:23:5: note: called from here
decode.c: _mm256_storeu_si256(r,x);
decode.c: ^~~~~~~~~~~~~~~~~~~~~~~~
decode.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/immintrin.h:41:0,
decode.c: from decode.c:1:
decode.c: /usr/lib/gcc/x86_64-linux-gnu/7/include/avxintrin.h:1341:1: error: inlining failed in call to always_inline '_mm256_set1_epi64x': target specific option mismatch
decode.c: _mm256_set1_epi64x (long long __A)
decode.c: ^~~~~~~~~~~~~~~~~~
decode.c: decode.c:7:15: note: called from here
decode.c: #define MASK2 _mm256_set1_epi64x(0x0101010101010101)
decode.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
decode.c: decode.c:22:10: note: in expansion of macro 'MASK2'
decode.c: x &= MASK2;
decode.c: ^~~~~
decode.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/immintrin.h:43:0,
decode.c: from decode.c:1:
decode.c: ...

Number of similar (compiler,implementation) pairs: 156, namely:
CompilerImplementations
gcc -funroll-loops -m32 -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=athlon -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=athlon -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=athlon -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=athlon -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=barcelona -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=barcelona -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=barcelona -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=barcelona -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=i386 -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=i386 -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=i386 -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=i386 -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=i486 -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=i486 -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=i486 -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=i486 -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k6-2 -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k6-2 -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k6-2 -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k6-2 -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k6-3 -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k6-3 -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k6-3 -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k6-3 -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k6 -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k6 -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k6 -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k6 -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k8 -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k8 -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k8 -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=k8 -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=nocona -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=nocona -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=nocona -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=nocona -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium-m -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium-m -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium-m -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium-m -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium-mmx -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium-mmx -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium-mmx -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium-mmx -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium2 -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium2 -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium2 -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium2 -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium3 -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium3 -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium3 -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium3 -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium4 -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium4 -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium4 -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium4 -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentium -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentiumpro -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentiumpro -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentiumpro -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=pentiumpro -Os -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=prescott -O2 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=prescott -O3 -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=prescott -O -fomit-frame-pointer avx
gcc -funroll-loops -m32 -march=prescott -Os -fomit-frame-pointer avx
gcc -m32 -O2 -fomit-frame-pointer avx
gcc -m32 -O3 -fomit-frame-pointer avx
gcc -m32 -O -fomit-frame-pointer avx
gcc -m32 -Os -fomit-frame-pointer avx
gcc -m32 -march=athlon -O2 -fomit-frame-pointer avx
gcc -m32 -march=athlon -O3 -fomit-frame-pointer avx
gcc -m32 -march=athlon -O -fomit-frame-pointer avx
gcc -m32 -march=athlon -Os -fomit-frame-pointer avx
gcc -m32 -march=core2 -O2 -fomit-frame-pointer avx
gcc -m32 -march=core2 -O3 -fomit-frame-pointer avx
gcc -m32 -march=core2 -O -fomit-frame-pointer avx
gcc -m32 -march=core2 -Os -fomit-frame-pointer avx
gcc -m32 -march=core2 -msse4.1 -O2 -fomit-frame-pointer avx
gcc -m32 -march=core2 -msse4.1 -O3 -fomit-frame-pointer avx
gcc -m32 -march=core2 -msse4.1 -O -fomit-frame-pointer avx
gcc -m32 -march=core2 -msse4.1 -Os -fomit-frame-pointer avx
gcc -m32 -march=core2 -msse4 -O2 -fomit-frame-pointer avx
gcc -m32 -march=core2 -msse4 -O3 -fomit-frame-pointer avx
gcc -m32 -march=core2 -msse4 -O -fomit-frame-pointer avx
gcc -m32 -march=core2 -msse4 -Os -fomit-frame-pointer avx
gcc -m32 -march=corei7 -O2 -fomit-frame-pointer avx
gcc -m32 -march=corei7 -O3 -fomit-frame-pointer avx
gcc -m32 -march=corei7 -O -fomit-frame-pointer avx
gcc -m32 -march=corei7 -Os -fomit-frame-pointer avx
gcc -m32 -march=i386 -O2 -fomit-frame-pointer avx
gcc -m32 -march=i386 -O3 -fomit-frame-pointer avx
gcc -m32 -march=i386 -O -fomit-frame-pointer avx
gcc -m32 -march=i386 -Os -fomit-frame-pointer avx
gcc -m32 -march=i486 -O2 -fomit-frame-pointer avx
gcc -m32 -march=i486 -O3 -fomit-frame-pointer avx
gcc -m32 -march=i486 -O -fomit-frame-pointer avx
gcc -m32 -march=i486 -Os -fomit-frame-pointer avx
gcc -m32 -march=k6-2 -O2 -fomit-frame-pointer avx
gcc -m32 -march=k6-2 -O3 -fomit-frame-pointer avx
gcc -m32 -march=k6-2 -O -fomit-frame-pointer avx
gcc -m32 -march=k6-2 -Os -fomit-frame-pointer avx
gcc -m32 -march=k6-3 -O2 -fomit-frame-pointer avx
gcc -m32 -march=k6-3 -O3 -fomit-frame-pointer avx
gcc -m32 -march=k6-3 -O -fomit-frame-pointer avx
gcc -m32 -march=k6-3 -Os -fomit-frame-pointer avx
gcc -m32 -march=k6 -O2 -fomit-frame-pointer avx
gcc -m32 -march=k6 -O3 -fomit-frame-pointer avx
gcc -m32 -march=k6 -O -fomit-frame-pointer avx
gcc -m32 -march=k6 -Os -fomit-frame-pointer avx
gcc -m32 -march=k8 -O2 -fomit-frame-pointer avx
gcc -m32 -march=k8 -O3 -fomit-frame-pointer avx
gcc -m32 -march=k8 -O -fomit-frame-pointer avx
gcc -m32 -march=k8 -Os -fomit-frame-pointer avx
gcc -m32 -march=nocona -O2 -fomit-frame-pointer avx
gcc -m32 -march=nocona -O3 -fomit-frame-pointer avx
gcc -m32 -march=nocona -O -fomit-frame-pointer avx
gcc -m32 -march=nocona -Os -fomit-frame-pointer avx
gcc -m32 -march=pentium-m -O2 -fomit-frame-pointer avx
gcc -m32 -march=pentium-m -O3 -fomit-frame-pointer avx
gcc -m32 -march=pentium-m -O -fomit-frame-pointer avx
gcc -m32 -march=pentium-m -Os -fomit-frame-pointer avx
gcc -m32 -march=pentium-mmx -O2 -fomit-frame-pointer avx
gcc -m32 -march=pentium-mmx -O3 -fomit-frame-pointer avx
gcc -m32 -march=pentium-mmx -O -fomit-frame-pointer avx
gcc -m32 -march=pentium-mmx -Os -fomit-frame-pointer avx
gcc -m32 -march=pentium2 -O2 -fomit-frame-pointer avx
gcc -m32 -march=pentium2 -O3 -fomit-frame-pointer avx
gcc -m32 -march=pentium2 -O -fomit-frame-pointer avx
gcc -m32 -march=pentium2 -Os -fomit-frame-pointer avx
gcc -m32 -march=pentium3 -O2 -fomit-frame-pointer avx
gcc -m32 -march=pentium3 -O3 -fomit-frame-pointer avx
gcc -m32 -march=pentium3 -O -fomit-frame-pointer avx
gcc -m32 -march=pentium3 -Os -fomit-frame-pointer avx
gcc -m32 -march=pentium4 -O2 -fomit-frame-pointer avx
gcc -m32 -march=pentium4 -O3 -fomit-frame-pointer avx
gcc -m32 -march=pentium4 -O -fomit-frame-pointer avx
gcc -m32 -march=pentium4 -Os -fomit-frame-pointer avx
gcc -m32 -march=pentium -O2 -fomit-frame-pointer avx
gcc -m32 -march=pentium -O3 -fomit-frame-pointer avx
gcc -m32 -march=pentium -O -fomit-frame-pointer avx
gcc -m32 -march=pentium -Os -fomit-frame-pointer avx
gcc -m32 -march=pentiumpro -O2 -fomit-frame-pointer avx
gcc -m32 -march=pentiumpro -O3 -fomit-frame-pointer avx
gcc -m32 -march=pentiumpro -O -fomit-frame-pointer avx
gcc -m32 -march=pentiumpro -Os -fomit-frame-pointer avx
gcc -m32 -march=prescott -O2 -fomit-frame-pointer avx
gcc -m32 -march=prescott -O3 -fomit-frame-pointer avx
gcc -m32 -march=prescott -O -fomit-frame-pointer avx
gcc -m32 -march=prescott -Os -fomit-frame-pointer avx

Compiler output

Implementation: avx
Security model: unknown
Compiler: gcc -m32 -march=barcelona -O2 -fomit-frame-pointer
decode.c: decode.c: In function 'crypto_decode_256x2_avx':
decode.c: decode.c:16:13: warning: AVX vector return without AVX enabled changes the ABI [-Wpsabi]
decode.c: __m256i x = _mm256_set1_epi32(*(int32_t *) s);
decode.c: ^
decode.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/immintrin.h:41:0,
decode.c: from decode.c:1:
decode.c: /usr/lib/gcc/x86_64-linux-gnu/7/include/avxintrin.h:925:1: error: inlining failed in call to always_inline '_mm256_storeu_si256': target specific option mismatch
decode.c: _mm256_storeu_si256 (__m256i_u *__P, __m256i __A)
decode.c: ^~~~~~~~~~~~~~~~~~~
decode.c: decode.c:23:5: note: called from here
decode.c: _mm256_storeu_si256(r,x);
decode.c: ^~~~~~~~~~~~~~~~~~~~~~~~
decode.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/immintrin.h:41:0,
decode.c: from decode.c:1:
decode.c: /usr/lib/gcc/x86_64-linux-gnu/7/include/avxintrin.h:1341:1: error: inlining failed in call to always_inline '_mm256_set1_epi64x': target specific option mismatch
decode.c: _mm256_set1_epi64x (long long __A)
decode.c: ^~~~~~~~~~~~~~~~~~
decode.c: decode.c:7:15: note: called from here
decode.c: #define MASK2 _mm256_set1_epi64x(0x0101010101010101)
decode.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
decode.c: decode.c:22:10: note: in expansion of macro 'MASK2'
decode.c: x &= MASK2;
decode.c: ^~~~~
decode.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/immintrin.h:43:0,
decode.c: from decode.c:1:
decode.c: ...
decode.c: decode.c: In function 'crypto_decode_256x2_avx':
decode.c: decode.c:16:13: warning: AVX vector return without AVX enabled changes the ABI [-Wpsabi]
decode.c: __m256i x = _mm256_set1_epi32(*(int32_t *) s);
decode.c: ^
decode.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/immintrin.h:41:0,
decode.c: from decode.c:1:
decode.c: /usr/lib/gcc/x86_64-linux-gnu/7/include/avxintrin.h:925:1: error: inlining failed in call to always_inline '_mm256_storeu_si256': target specific option mismatch
decode.c: _mm256_storeu_si256 (__m256i_u *__P, __m256i __A)
decode.c: ^~~~~~~~~~~~~~~~~~~
decode.c: decode.c:23:5: note: called from here
decode.c: _mm256_storeu_si256(r,x);
decode.c: ^~~~~~~~~~~~~~~~~~~~~~~~
decode.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/immintrin.h:41:0,
decode.c: from decode.c:1:
decode.c: /usr/lib/gcc/x86_64-linux-gnu/7/include/avxintrin.h:1341:1: error: inlining failed in call to always_inline '_mm256_set1_epi64x': target specific option mismatch
decode.c: _mm256_set1_epi64x (long long __A)
decode.c: ^~~~~~~~~~~~~~~~~~
decode.c: decode.c:7:15: note: called from here
decode.c: #define MASK2 _mm256_set1_epi64x(0x0101010101010101)
decode.c: ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
decode.c: decode.c:22:10: note: in expansion of macro 'MASK2'
decode.c: x &= MASK2;
decode.c: ^~~~~
decode.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/immintrin.h:43:0,
decode.c: from decode.c:1:
decode.c: ...

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

Compiler output

Implementation: avx
Security model: unknown
Compiler: gcc -m32 -march=core-avx-i -O2 -fomit-frame-pointer
decode.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/immintrin.h:43:0,
decode.c: from decode.c:1:
decode.c: decode.c: In function 'crypto_decode_256x2_avx':
decode.c: /usr/lib/gcc/x86_64-linux-gnu/7/include/avx2intrin.h:231:1: error: inlining failed in call to always_inline '_mm256_cmpeq_epi8': target specific option mismatch
decode.c: _mm256_cmpeq_epi8 (__m256i __A, __m256i __B)
decode.c: ^~~~~~~~~~~~~~~~~
decode.c: decode.c:21:7: note: called from here
decode.c: x = _mm256_cmpeq_epi8(x,_mm256_setzero_si256());
decode.c: ~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
decode.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/immintrin.h:43:0,
decode.c: from decode.c:1:
decode.c: /usr/lib/gcc/x86_64-linux-gnu/7/include/avx2intrin.h:186:1: error: inlining failed in call to always_inline '_mm256_andnot_si256': target specific option mismatch
decode.c: _mm256_andnot_si256 (__m256i __A, __m256i __B)
decode.c: ^~~~~~~~~~~~~~~~~~~
decode.c: decode.c:20:7: note: called from here
decode.c: x = _mm256_andnot_si256(x,MASK);
decode.c: ~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
decode.c: In file included from /usr/lib/gcc/x86_64-linux-gnu/7/include/immintrin.h:43:0,
decode.c: from decode.c:1:
decode.c: /usr/lib/gcc/x86_64-linux-gnu/7/include/avx2intrin.h:588:1: error: inlining failed in call to always_inline '_mm256_shuffle_epi8': target specific option mismatch
decode.c: _mm256_shuffle_epi8 (__m256i __X, __m256i __Y)
decode.c: ^~~~~~~~~~~~~~~~~~~
decode.c: decode.c:18:7: note: called from here
decode.c: x = _mm256_shuffle_epi8(x,COPY);
decode.c: ~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
decode.c: ...

Number of similar (compiler,implementation) pairs: 12, namely:
CompilerImplementations
gcc -m32 -march=core-avx-i -O2 -fomit-frame-pointer avx
gcc -m32 -march=core-avx-i -O3 -fomit-frame-pointer avx
gcc -m32 -march=core-avx-i -O -fomit-frame-pointer avx
gcc -m32 -march=core-avx-i -Os -fomit-frame-pointer avx
gcc -m32 -march=corei7-avx -O2 -fomit-frame-pointer avx
gcc -m32 -march=corei7-avx -O3 -fomit-frame-pointer avx
gcc -m32 -march=corei7-avx -O -fomit-frame-pointer avx
gcc -m32 -march=corei7-avx -Os -fomit-frame-pointer avx
gcc -m32 -march=native -mtune=native -O2 -fomit-frame-pointer avx
gcc -m32 -march=native -mtune=native -O3 -fomit-frame-pointer avx
gcc -m32 -march=native -mtune=native -O -fomit-frame-pointer avx
gcc -m32 -march=native -mtune=native -Os -fomit-frame-pointer avx