SVE Instruction List by Dougall Johnson
PMULLB: Polynomial multiply long (bottom)
PMULLB Zd.H, Zn.B, Zm.B (SVE2 (SME
svuint16_t svpmullb[_u16](svuint8_t op1, svuint8_t op2)
svuint8_t svpmullb_pair[_u8](svuint8_t op1, svuint8_t op2)
128-bit SVE
data:image/s3,"s3://crabby-images/c31c7/c31c702c3ce26884fc4975a2c224f9cdcbcc2eee" alt=""
Interpreting each even 8-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/9fb88/9fb88d63d53541b84a5ab97ef1e99011e5a3044c" alt=""
Interpreting each even 8-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/fcf7a/fcf7a0a9e755cf6a5f86549cc1ae802e9678912e" alt=""
Interpreting each even 8-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/884f0/884f01a14919fad138ebf9fb7ba85f3a94fc6315" alt=""
Interpreting each even 8-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/1d7d9/1d7d9a6b3ddd4cd13233aaaaea00107362c9d914" alt=""
Interpreting each even 8-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.