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の同じビットを使用
キャリーレス乗算は一部の暗号アルゴリズムで使われる特殊な演算です。