共用方式為


_mm_cmov_si128

更新:2011 年 3 月

必須有 Visual Studio 2010 SP1。

Microsoft 專有的

產生 XOP 指令 vpcmov,以根據其第三個來源值執行前兩個來源的位元條件式移動。

__m128i _mm_cmov_si128 (
   __m128i src1,
   __m128i src2,
   __m128i selector
);

參數

  • [in] src1
    128 位元參數。

  • [in] src2
    128 位元參數。

  • [in] selector
    128 位元參數,這個參數會選取 src1和 src2 中的位元。

傳回值

128 位元結果 r,這個結果包含 src1 和 src2 中的位元。 選取的位元取決於 selector。

需求

內建

架構

_mm_cmov_si128

XOP

標頭檔 <intrin.h>

備註

結果中的每個位元都是根據 selector 中對應位元位置的值,從 src1或 src2 的該位元位置所選取 (複製)。 如果 selector 中的位元是 1,則會從 src1 選取位元,否則從 src2 選取位元。

vpcmov 指令屬於 XOP 指令家族的一部分。 在使用這個內建之前,您必須先確定處理器支援這個指令。 若要判斷這個指令的硬體支援,請指定 InfoType = 0x80000001 以呼叫 __cpuid 內建,並檢查 CPUInfo[2] (ECX) 的位元 11。 當支援指令時,這個位元為 1,否則為 0。

範例

#include <stdio.h>
#include <intrin.h>
int main()
{
    __m128i a, b, selector, d;
    int i;
    a.m128i_u64[1] = 0xccccccccccccccccll;
    a.m128i_u64[0] = 0x8888888888888888ll;
    b.m128i_u64[1] = 0x3333333333333333ll;
    b.m128i_u64[0] = 0x7777777777777777ll;
    selector.m128i_u64[1] = 0xfedcba9876543210ll;
    selector.m128i_u64[0] = 0x0123456789abcdefll;
    d = _mm_cmov_si128(a, b, selector);
    printf_s("a:        %016I64x %016I64x\n",
              a.m128i_u64[1], a.m128i_u64[0]);
    printf_s("b:        %016I64x %016I64x\n",
              b.m128i_u64[1], b.m128i_u64[0]);
    printf_s("selector  %016I64x %016I64x\n",
              selector.m128i_u64[1], selector.m128i_u64[0]);
    printf_s("result:   %016I64x %016I64x\n",
              d.m128i_u64[1], d.m128i_u64[0]);
}
  

請參閱

參考

__cpuid, __cpuidex

其他資源

_mm256_cmov_si256

_mm_perm_epi8

針對 Visual Studio 2010 SP1 加入的 XOP 內建

變更記錄

日期

記錄

原因

2011 年 3 月

新增此內容。

SP1 功能變更。