SVE Instruction List by Dougall Johnson
See "SLI" in the exploration tools

SLI: Shift left and insert (immediate)

SLI Zd.D, Zn.D, #const (SVE2 (SME
svint64_t svsli[_n_s64](svint64_t op1, svint64_t op2, uint64_t imm3)
svuint64_t svsli[_n_u64](svuint64_t op1, svuint64_t op2, uint64_t imm3)

128-bit SVE

For each 64-bit integer set (3) to ( (2) << const ) | ( (1) & ~( 0xFFFFFFFFFFFFFFFF << const ) ). This preserves the const least-significant bits from (1), while inserting the ( 64 − const ) least-significant bits from (2) into the most-significant bits of (3). The shift amount is limited to 0 ≤ const ≤ 63.

256-bit SVE

For each 64-bit integer set (3) to ( (2) << const ) | ( (1) & ~( 0xFFFFFFFFFFFFFFFF << const ) ). This preserves the const least-significant bits from (1), while inserting the ( 64 − const ) least-significant bits from (2) into the most-significant bits of (3). The shift amount is limited to 0 ≤ const ≤ 63.

512-bit SVE

For each 64-bit integer set (3) to ( (2) << const ) | ( (1) & ~( 0xFFFFFFFFFFFFFFFF << const ) ). This preserves the const least-significant bits from (1), while inserting the ( 64 − const ) least-significant bits from (2) into the most-significant bits of (3). The shift amount is limited to 0 ≤ const ≤ 63.

Larger sizes

1024-bit SVE

For each 64-bit integer set (3) to ( (2) << const ) | ( (1) & ~( 0xFFFFFFFFFFFFFFFF << const ) ). This preserves the const least-significant bits from (1), while inserting the ( 64 − const ) least-significant bits from (2) into the most-significant bits of (3). The shift amount is limited to 0 ≤ const ≤ 63.

2048-bit SVE

For each 64-bit integer set (3) to ( (2) << const ) | ( (1) & ~( 0xFFFFFFFFFFFFFFFF << const ) ). This preserves the const least-significant bits from (1), while inserting the ( 64 − const ) least-significant bits from (2) into the most-significant bits of (3). The shift amount is limited to 0 ≤ const ≤ 63.

Report mistakes or give feedback
Inspired by and based on the x86/x64 SIMD Instruction List by Daytime.