1515 Commits

Author SHA1 Message Date
Konstantinos Margaritis
dfba9227e9 fix non-const char * write-strings compile error 2021-01-22 10:11:20 +02:00
Konstantinos Margaritis
9bf5cac782 replace andn() by explicit bitops and group loads/stores, gives ~1% gain 2021-01-18 13:15:15 +02:00
Konstantinos Margaritis
94739756b4 borrow cache prefetching tricks from the Marvell port, seem to improve performance by 5-28% 2021-01-15 17:42:11 +02:00
Konstantinos Margaritis
fc4338eca0 fix compilation on non-x86 2021-01-15 17:35:21 +02:00
Konstantinos Margaritis
ef9bf02d00 add some useful intrinsics 2021-01-15 17:35:01 +02:00
Konstantinos Margaritis
6a11c83630 add expand128() implementation for NEON 2021-01-15 17:33:41 +02:00
Konstantinos Margaritis
644aac5e1b
Merge pull request #5 from VectorCamp/bugfix/fix-ia32-build
fix IA32 build, as we need minimum SSSE3 support for compilation to s…
v5.3.2
2020-12-31 09:50:35 +02:00
Konstantinos Margaritis
752a42419b fix IA32 build, as we need minimum SSSE3 support for compilation to succeed 2020-12-30 19:57:44 +02:00
Konstantinos Margaritis
124455a4a8
Merge pull request #2 from VectorCamp/develop
Develop
v5.3.1
2020-12-21 20:50:27 +02:00
Konstantinos Margaritis
0372a8120a
Merge pull request #1 from VectorCamp/feature/add-arm-support
Feature/add arm support
2020-12-16 19:01:32 +02:00
Konstantinos Margaritis
61b963a717 fix x86 compilation 2020-12-08 11:42:30 +02:00
Konstantinos Margaritis
e088c6ae2b remove forgotten printf 2020-12-07 23:12:41 +02:00
Konstantinos Margaritis
773dc6fa69 optimize *shiftbyte_m128() functions to use palign instead of variable_byte_shift_m128() 2020-12-07 23:12:26 +02:00
Konstantinos Margaritis
39945b7775 clear zones array 2020-12-03 19:30:50 +02:00
Konstantinos Margaritis
c38722a68b add ARM platform 2020-12-03 19:27:58 +02:00
Konstantinos Margaritis
38477b08bc fix movq and load_m128_from_u64a and resp. test for NEON 2020-12-03 19:27:38 +02:00
Konstantinos Margaritis
259c2572c1 define debug vector print functions to NULL in non-debug mode 2020-12-03 19:27:05 +02:00
Konstantinos Margaritis
17ab42d891 small optimization that was for some reason failing in ARM, should be faster anyway 2020-11-24 17:59:42 +02:00
Konstantinos Margaritis
d76365240b helper functions to print a m128 vector in debug mode 2020-11-24 17:57:16 +02:00
Konstantinos Margaritis
1c26f044a7 when building in debug mode, vgetq_lane_*() and vextq_*() need immediate operands, and we have to use switch()'ed versions 2020-11-24 17:56:40 +02:00
Konstantinos Margaritis
606c53a05f fix compiler flag testcase 2020-11-24 17:55:03 +02:00
Konstantinos Margaritis
c4f1372814 remove debug from functions 2020-11-05 20:33:17 +02:00
Konstantinos Margaritis
62fed20ad0 add some debug and minor optimizations in unit test 2020-11-05 19:21:16 +02:00
Konstantinos Margaritis
501f60e930 add some debug info 2020-11-05 19:20:37 +02:00
Konstantinos Margaritis
33904180d8 add compress128 function and implementation 2020-11-05 19:20:06 +02:00
Konstantinos Margaritis
7b8cf97546 add extra instructions (currently arm-only), fix order of elements in set4x32/set2x64 2020-11-05 19:18:53 +02:00
Konstantinos Margaritis
18296eee47 fix 32-bit/64-bit detection 2020-11-05 17:31:20 +02:00
Konstantinos Margaritis
592b1905af needed for ARM vector type conversions 2020-10-30 10:50:24 +02:00
Konstantinos Margaritis
547f79b920 small optimization in storecompress*() 2020-10-30 10:49:50 +02:00
Konstantinos Margaritis
548242981d fix ARM implementations 2020-10-30 10:38:41 +02:00
Konstantinos Margaritis
0bef151437 don't use SSE directly in the tests 2020-10-30 10:38:05 +02:00
Konstantinos Margaritis
149ea938c4 don't redefine function on x86 2020-10-16 13:09:08 +03:00
Konstantinos Margaritis
c4db63665a scalar implementations of diffrich256 and diffrich384 2020-10-16 13:02:40 +03:00
Konstantinos Margaritis
4bce012570 Revert "move x86 popcount.h implementations to util/arch/x86/popcount.h"
This reverts commit 6581aae90e55520353c03edb716de80ecc03521a.
2020-10-16 12:32:44 +03:00
Konstantinos Margaritis
83977db7ab split arch-agnostic simd_utils.h functions into the common file 2020-10-16 12:30:34 +03:00
Konstantinos Margaritis
e7e1308d7f fix compilation paths for cpuid_flags for x86 2020-10-16 12:29:45 +03:00
Konstantinos Margaritis
45bfed9b9d add scalar versions of the vectorized functions for architectures that don't support 256-bit/512-bit SIMD vectors such as ARM 2020-10-15 16:30:18 +03:00
Konstantinos Margaritis
c5a7f4b846 add ARM simd_utils vectorized functions for 128-bit vectors 2020-10-15 16:26:49 +03:00
Konstantinos Margaritis
5b425bd5a6 add arm simple cpuid_flags 2020-10-15 16:26:04 +03:00
Konstantinos Margaritis
31ac6718dd add ARM version of simd_utils.h 2020-10-13 09:19:56 +03:00
Konstantinos Margaritis
a9212174ee add arm bitutils.h header 2020-10-08 20:50:55 +03:00
Konstantinos Margaritis
1c2c73becf add C implementation of pdep64() 2020-10-08 20:50:18 +03:00
Konstantinos Margaritis
d2cf1a7882 move cpuid_flags.h header to common 2020-10-08 20:49:33 +03:00
Konstantinos Margaritis
5d773dd9db use C implementation of popcount for arm 2020-10-07 14:28:45 +03:00
Konstantinos Margaritis
4c924cc920 add arm architecture basic defines 2020-10-07 14:28:12 +03:00
Konstantinos Margaritis
9a0494259e minor fix 2020-10-07 14:26:41 +03:00
Konstantinos Margaritis
e91082d477 use right intrinsic 2020-10-06 13:45:52 +03:00
Konstantinos Margaritis
5952c64066 add necessary modifications to CMake system to enable building on ARM, add arm_neon.h intrinsic header to intrinsics.h 2020-10-06 12:44:23 +03:00
Konstantinos Margaritis
b1170bcc2e add arm checks in platform.cmake 2020-10-06 08:09:18 +03:00
Konstantinos Margaritis
f0e70bc0ad Revert "Revert "move x86 popcount.h implementations to util/arch/x86/popcount.h""
This reverts commit 04fbf2468140cc4d7ccabc62a2bdc4503a3d31c5.
2020-09-24 11:52:59 +03:00