SVE Instruction List by Dougall Johnson
TBL: Programmable table lookup in one or two vector table (zeroing)
TBL Zd.H, { Zn.H }, Zm.H (SVE (SME
svbfloat16_t svtbl[_bf16](svbfloat16_t data, svuint16_t indices)
svfloat16_t svtbl[_f16](svfloat16_t data, svuint16_t indices)
svint16_t svtbl[_s16](svint16_t data, svuint16_t indices)
svuint16_t svtbl[_u16](svuint16_t data, svuint16_t indices)
128-bit SVE
data:image/s3,"s3://crabby-images/226d5/226d5fc55cebeda52e37bd6e79c2ceb4760d2200" alt=""
For each 16-bit index from (2), if 0 ≤ (2) < 8, set (3) to the 16-bit element at that index in (1), otherwise set (3) to zero.
256-bit SVE
data:image/s3,"s3://crabby-images/e1319/e13192a593c5935154389444d2ba081cd63c52e2" alt=""
For each 16-bit index from (2), if 0 ≤ (2) < 16, set (3) to the 16-bit element at that index in (1), otherwise set (3) to zero.
512-bit SVE
data:image/s3,"s3://crabby-images/6b967/6b967640836e81495cde766140130d296293470c" alt=""
For each 16-bit index from (2), if 0 ≤ (2) < 32, set (3) to the 16-bit element at that index in (1), otherwise set (3) to zero.
Larger sizes
1024-bit SVE
data:image/s3,"s3://crabby-images/0f312/0f312210e46647408891ba026707acd674ad5623" alt=""
For each 16-bit index from (2), if 0 ≤ (2) < 64, set (3) to the 16-bit element at that index in (1), otherwise set (3) to zero.
2048-bit SVE
data:image/s3,"s3://crabby-images/b1999/b199907b478dc3a3974f733a2f7ac86671607905" alt=""
For each 16-bit index from (2), if 0 ≤ (2) < 128, set (3) to the 16-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.