SVE Instruction List by Dougall Johnson
TBL: Programmable table lookup in one or two vector table (zeroing)
TBL Zd.D, { Zn1.D, Zn2.D }, Zm.D (SVE2 (SME
svfloat64_t svtbl2[_f64](svfloat64x2_t data, svuint64_t indices)
svint64_t svtbl2[_s64](svint64x2_t data, svuint64_t indices)
svuint64_t svtbl2[_u64](svuint64x2_t data, svuint64_t indices)
128-bit SVE
data:image/s3,"s3://crabby-images/39bcc/39bcc8b346fc7ad1fa370168b01f4372d9f1eb30" alt=""
For each 64-bit index from (2), if 0 ≤ index < 4, set (3) to the 64-bit element at that index in the two-register table (1), otherwise set (3) to zero.
256-bit SVE
data:image/s3,"s3://crabby-images/693be/693be034c83b1d2cc65fe4a2100f98c6a48536b7" alt=""
For each 64-bit index from (2), if 0 ≤ index < 8, set (3) to the 64-bit element at that index in the two-register table (1), otherwise set (3) to zero.
512-bit SVE
data:image/s3,"s3://crabby-images/22648/22648420c2db9011f82c4168a8d5be8ecbd8bfc3" alt=""
For each 64-bit index from (2), if 0 ≤ index < 16, set (3) to the 64-bit element at that index in the two-register table (1), otherwise set (3) to zero.
Larger sizes
1024-bit SVE
data:image/s3,"s3://crabby-images/f8c54/f8c546e6f16f0a793f8051e7271874e5854d5700" alt=""
For each 64-bit index from (2), if 0 ≤ index < 32, set (3) to the 64-bit element at that index in the two-register table (1), otherwise set (3) to zero.
2048-bit SVE
data:image/s3,"s3://crabby-images/64897/648974264f08ce53bcb8a7258e653c40d72a9e27" alt=""
For each 64-bit index from (2), if 0 ≤ index < 64, set (3) to the 64-bit element at that index in the two-register table (1), otherwise set (3) to zero.
Report mistakes or give feedback
Inspired by and based on the x86/x64 SIMD Instruction List by Daytime.