SVE Instruction List by Dougall Johnson
PMULLB: Polynomial multiply long (bottom)
PMULLB Zd.Q, Zn.D, Zm.D (SVE2+PMULL128+NS
svuint64_t svpmullb_pair[_u64](svuint64_t op1, svuint64_t op2)
128-bit SVE
data:image/s3,"s3://crabby-images/3bc93/3bc93ad55c3423fcb7947ca81a8481d1ba247520" alt=""
Interpreting each even 64-bit integer from (1) and (2) as a ℤ2 polynomial, set the double-width (3) to (1) * (2). This can also be described as a carryless multiplication, or a multiplication using exclusive-or instead of addition.
256-bit SVE
data:image/s3,"s3://crabby-images/2e989/2e989fec2eba7901d3a61ad10244293eb6ebeefd" alt=""
Interpreting each even 64-bit integer from (1) and (2) as a ℤ2 polynomial, set the double-width (3) to (1) * (2). This can also be described as a carryless multiplication, or a multiplication using exclusive-or instead of addition.
512-bit SVE
data:image/s3,"s3://crabby-images/9cfc5/9cfc599bf75612e15bbcf6c28f126e2ff6b92a9f" alt=""
Interpreting each even 64-bit integer from (1) and (2) as a ℤ2 polynomial, set the double-width (3) to (1) * (2). This can also be described as a carryless multiplication, or a multiplication using exclusive-or instead of addition.
Larger sizes
1024-bit SVE
data:image/s3,"s3://crabby-images/b7b03/b7b03d59c4c49940ec4ef4d44f6938c5062b2b50" alt=""
Interpreting each even 64-bit integer from (1) and (2) as a ℤ2 polynomial, set the double-width (3) to (1) * (2). This can also be described as a carryless multiplication, or a multiplication using exclusive-or instead of addition.
2048-bit SVE
data:image/s3,"s3://crabby-images/37c99/37c99d875c6602b965de0457255e12a7573c2cf0" alt=""
Interpreting each even 64-bit integer from (1) and (2) as a ℤ2 polynomial, set the double-width (3) to (1) * (2). This can also be described as a carryless multiplication, or a multiplication using exclusive-or instead of addition.
Report mistakes or give feedback
Inspired by and based on the x86/x64 SIMD Instruction List by Daytime.