8

我正在使用 SSE2 内在函数来优化我的应用程序的瓶颈,并且有以下问题:

ddata = _mm_xor_si128(_mm_xor_si128(
    _mm_sll_epi32(xdata, 0x7u), _mm_srl_epi32(tdata, 0x19u)), xdata);

在 Microsoft C++ 编译器上,这不会编译,因为类型__m128iunsigned int(传递给_mm_sll_epi32指令)不可互换。

为什么会这样,我应该如何将任意unsigned int值传递给_mm_sll_epi32


_m128i是:

typedef union __declspec(intrin_type) _CRT_ALIGN(16) __m128i {
    __int8              m128i_i8[16];
    __int16             m128i_i16[8];
    __int32             m128i_i32[4];    
    __int64             m128i_i64[2];
    unsigned __int8     m128i_u8[16];
    unsigned __int16    m128i_u16[8];
    unsigned __int32    m128i_u32[4];
    unsigned __int64    m128i_u64[2];
} __m128i;
4

2 回答 2

11

它应该是:

ddata = _mm_xor_si128(_mm_xor_si128(
    _mm_slli_epi32(xdata, 0x7), _mm_srli_epi32(tdata, 0x19)), xdata);

注意i“立即”。没有这个,移位内在函数需要一个向量作为第二个参数。

于 2011-11-03T13:35:50.033 回答
6

您可以使用_mm_slli_epi32(注意i)和同样的_mm_srli_epi32。它需要一个整数参数而不是一个__m128i.

于 2011-11-03T13:36:34.623 回答