SVE Instruction List by Dougall Johnson
PMULLB: Polynomial multiply long (bottom)
PMULLB Zd.D, Zn.S, Zm.S (SVE2 (SME
svuint64_t svpmullb[_u64](svuint32_t op1, svuint32_t op2)
svuint32_t svpmullb_pair[_u32](svuint32_t op1, svuint32_t op2)
128-bit SVE
data:image/s3,"s3://crabby-images/07a27/07a27f102811e9b7cb5d066e690d8c627b99263a" alt=""
Interpreting each even 32-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/2f722/2f722736348945f405b885029a2ea2b3a70fde2c" alt=""
Interpreting each even 32-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/924ee/924eec09c713db4067d749066ad3d416651590cb" alt=""
Interpreting each even 32-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/506e5/506e569b582945a32049a580d5ad47f6e2c4d8c3" alt=""
Interpreting each even 32-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/1d4c5/1d4c5949429490f328f6ce481925aa0070993677" alt=""
Interpreting each even 32-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.