SVE Instruction List by Dougall Johnson
TBL: Programmable table lookup in one or two vector table (zeroing)
TBL Zd.S, { Zn.S }, Zm.S (SVE (SME
svfloat32_t svtbl[_f32](svfloat32_t data, svuint32_t indices)
svint32_t svtbl[_s32](svint32_t data, svuint32_t indices)
svuint32_t svtbl[_u32](svuint32_t data, svuint32_t indices)
128-bit SVE
data:image/s3,"s3://crabby-images/3ff64/3ff64775b9c6ab6d5c7ca77f76cc719c22710c3b" alt=""
For each 32-bit index from (2), if 0 ≤ (2) < 4, set (3) to the 32-bit element at that index in (1), otherwise set (3) to zero.
256-bit SVE
data:image/s3,"s3://crabby-images/acd0a/acd0a827db3b3e19594ac7c47d86b104fe3e1e73" alt=""
For each 32-bit index from (2), if 0 ≤ (2) < 8, set (3) to the 32-bit element at that index in (1), otherwise set (3) to zero.
512-bit SVE
data:image/s3,"s3://crabby-images/e8140/e81405a1ab266a5c87f46010948d1645e00d12b6" alt=""
For each 32-bit index from (2), if 0 ≤ (2) < 16, set (3) to the 32-bit element at that index in (1), otherwise set (3) to zero.
Larger sizes
1024-bit SVE
data:image/s3,"s3://crabby-images/ef1fd/ef1fd9b2ba7cb5e11b72295b9b8c833a221e0f40" alt=""
For each 32-bit index from (2), if 0 ≤ (2) < 32, set (3) to the 32-bit element at that index in (1), otherwise set (3) to zero.
2048-bit SVE
data:image/s3,"s3://crabby-images/35da6/35da68cc4e22bac138e2a9e44b776ae5587dbcad" alt=""
For each 32-bit index from (2), if 0 ≤ (2) < 64, set (3) to the 32-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.