SVE Instruction List by Dougall Johnson
TBL: Programmable table lookup in one or two vector table (zeroing)
TBL Zd.D, { Zn.D }, Zm.D (SVE (SME
svfloat64_t svtbl[_f64](svfloat64_t data, svuint64_t indices)
svint64_t svtbl[_s64](svint64_t data, svuint64_t indices)
svuint64_t svtbl[_u64](svuint64_t data, svuint64_t indices)
128-bit SVE
data:image/s3,"s3://crabby-images/6bf1b/6bf1bbbff75fe01fa91f21409d608cbba63004ae" alt=""
For each 64-bit index from (2), if 0 ≤ (2) < 2, set (3) to the 64-bit element at that index in (1), otherwise set (3) to zero.
256-bit SVE
data:image/s3,"s3://crabby-images/4808a/4808a8d8b2d5be1ed5baddba7acf303e92be53c3" alt=""
For each 64-bit index from (2), if 0 ≤ (2) < 4, set (3) to the 64-bit element at that index in (1), otherwise set (3) to zero.
512-bit SVE
data:image/s3,"s3://crabby-images/dd051/dd0513e5aad3ebdf459efcde87343878bd1ebb57" alt=""
For each 64-bit index from (2), if 0 ≤ (2) < 8, set (3) to the 64-bit element at that index in (1), otherwise set (3) to zero.
Larger sizes
1024-bit SVE
data:image/s3,"s3://crabby-images/5311a/5311a1b9ab0130ee87c0690a7083e68567d654c6" alt=""
For each 64-bit index from (2), if 0 ≤ (2) < 16, set (3) to the 64-bit element at that index in (1), otherwise set (3) to zero.
2048-bit SVE
data:image/s3,"s3://crabby-images/9a38d/9a38d99914b6d5578601a488a6bee0260c5974b1" alt=""
For each 64-bit index from (2), if 0 ≤ (2) < 32, set (3) to the 64-bit element at that index in (1), otherwise set (3) to zero.
Report mistakes or give feedback
Inspired by and based on the x86/x64 SIMD Instruction List by Daytime.