SVE Instruction List by Dougall Johnson
SLI: Shift left and insert (immediate)
SLI Zd.S, Zn.S, #const (SVE2 (SME
svint32_t svsli[_n_s32](svint32_t op1, svint32_t op2, uint64_t imm3)
svuint32_t svsli[_n_u32](svuint32_t op1, svuint32_t op2, uint64_t imm3)
128-bit SVE
data:image/s3,"s3://crabby-images/98893/988932a6fd8f24c19e37ebeb85f6f79641b70db7" alt=""
For each 32-bit integer set (3) to ( (2) << const ) | ( (1) & ~( 0xFFFFFFFF << const ) ). This preserves the const least-significant bits from (1), while inserting the ( 32 − const ) least-significant bits from (2) into the most-significant bits of (3). The shift amount is limited to 0 ≤ const ≤ 31.
256-bit SVE
data:image/s3,"s3://crabby-images/358e5/358e580332485488960e211b8452bce11256bec6" alt=""
For each 32-bit integer set (3) to ( (2) << const ) | ( (1) & ~( 0xFFFFFFFF << const ) ). This preserves the const least-significant bits from (1), while inserting the ( 32 − const ) least-significant bits from (2) into the most-significant bits of (3). The shift amount is limited to 0 ≤ const ≤ 31.
512-bit SVE
data:image/s3,"s3://crabby-images/e68c7/e68c773f908701ca02e50f60c583fda9979aab35" alt=""
For each 32-bit integer set (3) to ( (2) << const ) | ( (1) & ~( 0xFFFFFFFF << const ) ). This preserves the const least-significant bits from (1), while inserting the ( 32 − const ) least-significant bits from (2) into the most-significant bits of (3). The shift amount is limited to 0 ≤ const ≤ 31.
Larger sizes
1024-bit SVE
data:image/s3,"s3://crabby-images/017e3/017e351c4657fc9f800a5a4d4334af6527c5f062" alt=""
For each 32-bit integer set (3) to ( (2) << const ) | ( (1) & ~( 0xFFFFFFFF << const ) ). This preserves the const least-significant bits from (1), while inserting the ( 32 − const ) least-significant bits from (2) into the most-significant bits of (3). The shift amount is limited to 0 ≤ const ≤ 31.
2048-bit SVE
data:image/s3,"s3://crabby-images/2216e/2216e8f2cd85c2a205481ad77f56da0860164bf5" alt=""
For each 32-bit integer set (3) to ( (2) << const ) | ( (1) & ~( 0xFFFFFFFF << const ) ). This preserves the const least-significant bits from (1), while inserting the ( 32 − const ) least-significant bits from (2) into the most-significant bits of (3). The shift amount is limited to 0 ≤ const ≤ 31.
Report mistakes or give feedback
Inspired by and based on the x86/x64 SIMD Instruction List by Daytime.