Konstantinos Margaritis
0d1d76140a
provide an {l,r}shift128_var() to fix immediate value build failure in loadu_maskz
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
f680a79f1e
fix arm loadu_maskz()
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
b0fbb39cf0
add arm rshift128/rshift128
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
93abed4d87
add {l,r}shift128()+tests, rename printv_u64() to print64()
2021-07-26 00:10:54 +03:00
George Wort
e325ce9452
Use SVE2 Bitperm's bdep instruction in bitutils and state_compress
...
Specifically for pdep64, expand32, and expand64 in bitutils,
as well as all of the loadcompressed functions used in
state_compress.
Change-Id: I92851bd12481dbee6a7e344df0890c4901b56d01
2021-07-26 00:10:54 +03:00
George Wort
7d7d31ec0d
Add SVE2 support for vermicelli
...
Change-Id: Ia025de53521fbaefe5fb1e4425aaf75c7d80a14e
2021-07-26 00:10:54 +03:00
apostolos
4326aecfda
Supervector test fixes
2021-07-26 00:10:54 +03:00
apostolos
a98a114568
SuperVector AVX512 implementations
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
56b124b9a1
really fix lshift for avx2
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
46c37ece4b
add AVX2 specializations
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
65d911c976
lots of fixes to AVX2 implementation
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
517d2aa633
convert print helper functions to class methods
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
3021db0a17
fix arm SuperVector implementation
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
d1097e713d
fix x86 debug alignr
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
848a583599
move firstMatch, lastMatch to own header in util
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
69378e7eee
compilation fixes for debug mode
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
a5cce2670e
fix arm implementation of alignr()
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
736da56850
harmonise syntax of x86 SuperVector impl.cpp like arm, fix alignr, define printv_* functions when on debug mode only
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
f6edd100c4
style fixes
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
a6bbe55574
removed obsolete file
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
6348a2f222
rename supervector class header, use dup_*() functions names instead of set1_*(), minor fixes
2021-07-26 00:10:54 +03:00
apostolos
885a4da0c8
Truffle simd vectorized
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
1c0d9f399f
nits
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
0fbd90c511
fix typo
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
f7ae729930
fix unit tests, and resp. ARM SuperVector methods based on those unit tests, add print functions for SuperVector
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
655c2eb87f
add missing ARM SuperVector methods, some tests still fail, WIP
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
38600b717e
rename arm impl.hpp to impl.cpp, add operator|() to SuperVector class
2021-07-26 00:10:54 +03:00
George Wort
27b1bea462
Add SVE, SVE2, and SVE2_BITPERM as targets
...
Change-Id: I5231e2eb0a31708a16c853dc83ea48db32e0b0a5
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
cc26212560
add more functions, move defines here, enable inlining of template specializations only when running optimized code
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
74e460d89b
fix compilation on C++
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
492874db43
simplify function
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
d232a50d72
add arm support for the new SuperVector class
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
73199585dd
add C++ template SIMD library (WIP)
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
8d9dd3c286
add global definitions for CHUNKSIZE/VECTORSIZE, define HAVE_AVX512* only when BUILD_AVX512 is also enabled
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
c15018286a
fix typo
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
7c6e47c95b
replace push_back by emplace_back where possible
2021-07-26 00:10:54 +03:00
Konstantinos Margaritis
27bd09454f
use correct function names for AVX512, fix build failure
2021-02-15 13:54:19 +02:00
Konstantinos Margaritis
741d8246c5
fix some AVX512 function names, to fix AVX512 build failure, also rename the expand* functions to broadcast*() ones for consistency
2021-02-15 13:54:19 +02:00
Konstantinos Margaritis
c3c68b1c3f
fix x86 implementations for compress128/expand128
2021-02-15 13:54:19 +02:00
Konstantinos Margaritis
814045201f
add BUILD_AVX2 definition, enable non-AVX2 building selectively
2021-02-15 13:54:19 +02:00
Konstantinos Margaritis
be66cdb51d
fixes in shifting primitives
2021-02-08 19:38:20 +02:00
Konstantinos Margaritis
f541f75400
bugfix compress128/expand128, add unit tests
2021-02-08 19:20:37 +02:00
Konstantinos Margaritis
d9874898c7
make const
2021-02-08 19:19:52 +02:00
Wang Xiang W
5f930b267c
Limex: exception handling with AVX512
2021-01-25 14:13:13 +02:00
Chang, Harry
b19a41528a
Add cpu feature / target info "AVX512VBMI".
2021-01-25 14:13:13 +02:00
Zhu,Wenjun
d96f1ab505
MCSHENG64: extend to 64-state based on mcsheng
2021-01-25 14:13:13 +02:00
Hong, Yang A
dea7c4dc2e
lookaround:
...
add 64x8 and 64x16 shufti models
add mask64 model
expand entry quantity
2021-01-25 14:13:13 +02:00
Chang, Harry
f5657ef7b7
Fix find_vertices_in_cycles(): don't check self-loop in SCC.
2021-01-25 14:13:13 +02:00
Konstantinos Margaritis
e2f253d8ab
remove loads from movemask128, variable_byte_shift, add palignr_imm(), minor fixes
2021-01-25 12:13:35 +02:00
Konstantinos Margaritis
a039089888
fix non-const char * write-strings compile error
2021-01-25 12:13:35 +02:00