PCLMULQDQ - Packed CarryLess MULtiplication Qword DoubleQword

PCLMULQDQ xmm1, xmm2/m128, imm8   (PCLMULQDQ
__m128i  _mm_clmulepi64_si128(__m128i a, __m128i b, const int imm8);

①と②からひとつずつQWORDを選択し、選択されたQWORDをキャリーレス乗算した結果を③にセットする。

VPCLMULQDQ xmm1, xmm2, xmm3/m128, imm8   (PCLMULQDQ + (V1

①と②からひとつずつQWORDを選択し、選択されたQWORDをキャリーレス乗算した結果を③にセットする。

VPCLMULQDQ ymm1, ymm2, ymm3/m256, imm8   (VPCLMULQDQ
__m256i  _mm256_clmulepi64_epi128(__m256i a, __m256i b, const int imm8);

各レーンについて①と②からひとつずつQWORDを選択し、選択されたQWORDをキャリーレス乗算した結果を③にセットする。両レーンでimm8の同じビットを使用

VPCLMULQDQ zmm1, zmm2, zmm3/m512, imm8   (VPCLMULQDQ + (V5
__m512i  _mm512_clmulepi64_epi128(__m512i a, __m512i b, const int imm8);

各レーンについて①と②からひとつずつQWORDを選択し、選択されたQWORDをキャリーレス乗算した結果を③にセットする。全レーンでimm8の同じビットを使用

キャリーレス乗算は一部の暗号アルゴリズムで使われる特殊な演算です。


x86/x64 SIMD命令一覧表 フィードバック

ホームページ http://www.officedaytime.com/