SVE Instruction List by Dougall Johnson
TBL: Programmable table lookup in one or two vector table (zeroing)
TBL Zd.H, { Zn1.H, Zn2.H }, Zm.H (SVE2 (SME
svbfloat16_t svtbl2[_bf16](svbfloat16x2_t data, svuint16_t indices)
svfloat16_t svtbl2[_f16](svfloat16x2_t data, svuint16_t indices)
svint16_t svtbl2[_s16](svint16x2_t data, svuint16_t indices)
svuint16_t svtbl2[_u16](svuint16x2_t data, svuint16_t indices)
128-bit SVE
data:image/s3,"s3://crabby-images/d743d/d743dd564b71461a6168b764f19f95d85364cdba" alt=""
For each 16-bit index from (2), if 0 ≤ index < 16, set (3) to the 16-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/07c69/07c697c119618d44c3b46c69b23eb1a92240adcd" alt=""
For each 16-bit index from (2), if 0 ≤ index < 32, set (3) to the 16-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/0c0a7/0c0a70d54cd90b17009b0a9d78558915a5f84e89" alt=""
For each 16-bit index from (2), if 0 ≤ index < 64, set (3) to the 16-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/4d07d/4d07d53ec6b7b9f178a3e34cbdc6239b30dd57ad" alt=""
For each 16-bit index from (2), if 0 ≤ index < 128, set (3) to the 16-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/a6dfd/a6dfd5847d1dc617323fa468635c249f42f2c60b" alt=""
For each 16-bit index from (2), set (3) to the 16-bit element at that index in the two-register table (1). Optional zeroing is not possible on 2048-bit SVE.
Report mistakes or give feedback
Inspired by and based on the x86/x64 SIMD Instruction List by Daytime.