|
#define | VECT_XOR_ARR_2_MASK(dst, src, src_end, mask) |
|
#define | VECT_ANDNOT_ARR_2_MASK(dst, src, src_end, mask) |
|
#define | VECT_BITCOUNT(first, last) |
|
#define | VECT_BITCOUNT_AND(first, last, mask) |
|
#define | VECT_BITCOUNT_OR(first, last, mask) |
|
#define | VECT_BITCOUNT_XOR(first, last, mask) |
|
#define | VECT_BITCOUNT_SUB(first, last, mask) |
|
#define | VECT_INVERT_BLOCK(first) |
|
#define | VECT_AND_BLOCK(dst, src) |
|
#define | VECT_OR_BLOCK(dst, src) |
|
#define | VECT_OR_BLOCK_2WAY(dst, src1, src2) |
|
#define | VECT_OR_BLOCK_3WAY(dst, src1, src2) |
|
#define | VECT_OR_BLOCK_5WAY(dst, src1, src2, src3, src4) |
|
#define | VECT_SUB_BLOCK(dst, src) |
|
#define | VECT_XOR_BLOCK(dst, src) |
|
#define | VECT_XOR_BLOCK_2WAY(dst, src1, src2) |
|
#define | VECT_COPY_BLOCK(dst, src) |
|
#define | VECT_STREAM_BLOCK(dst, src) |
|
#define | VECT_SET_BLOCK(dst, value) |
|
#define | VECT_GAP_BFIND(buf, pos, is_set) |
|
|
bm::id_t | bm::sse2_bit_count (const __m128i *block, const __m128i *block_end) |
|
template<class Func > |
bm::id_t | bm::sse2_bit_count_op (const __m128i *BMRESTRICT block, const __m128i *BMRESTRICT block_end, const __m128i *BMRESTRICT mask_block, Func sse2_func) |
|
bm::id_t | bm::sse2_bit_block_calc_count_change (const __m128i *BMRESTRICT block, const __m128i *BMRESTRICT block_end, unsigned *BMRESTRICT bit_count) |
|
unsigned | bm::sse2_gap_find (const bm::gap_word_t *BMRESTRICT pbuf, const bm::gap_word_t pos, const unsigned size) |
|
unsigned | bm::sse2_gap_bfind (const unsigned short *BMRESTRICT buf, unsigned pos, unsigned *BMRESTRICT is_set) |
| Hybrid binary search, starts as binary, then switches to linear scan.
|
|
unsigned | bm::sse2_gap_test (const unsigned short *BMRESTRICT buf, unsigned pos) |
| Hybrid binary search, starts as binary, then switches to scan.
|
|
Compute functions for SSE2 SIMD instruction set (internal)
Definition in file bmsse2.h.