SVE Instruction List by Dougall Johnson
TBL: Programmable table lookup in one or two vector table (zeroing)
TBL Zd.B, { Zn1.B, Zn2.B }, Zm.B (SVE2 (SME
svint8_t svtbl2[_s8](svint8x2_t data, svuint8_t indices)
svuint8_t svtbl2[_u8](svuint8x2_t data, svuint8_t indices)
128-bit SVE
data:image/s3,"s3://crabby-images/4eefc/4eefcb230a91b7c6033b5499e503911ffb0bf9e0" alt=""
For each 8-bit index from (2), if 0 ≤ index < 32, set (3) to the 8-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/f69db/f69db6cead32c9f8990c360b0f512fcf2e48ed1e" alt=""
For each 8-bit index from (2), if 0 ≤ index < 64, set (3) to the 8-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/9ff0b/9ff0b5af433c6e4441646d9570abec00f072e2df" alt=""
For each 8-bit index from (2), if 0 ≤ index < 128, set (3) to the 8-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/da9e8/da9e8e8d19247a04fc0c9c309a05c1719aad9779" alt=""
For each 8-bit index from (2), set (3) to the 8-bit element at that index in the two-register table (1). Optional zeroing is not possible on 1024-bit SVE.
2048-bit SVE
data:image/s3,"s3://crabby-images/a6fb8/a6fb85eb6bb5afa18d2419311b88e599a64ed77d" alt=""
For each 8-bit index from (2), set (3) to the 8-bit element at that index in the two-register table (1). Optional zeroing is not possible, and only the first register of the two-register table will be used on 2048-bit SVE.
Report mistakes or give feedback
Inspired by and based on the x86/x64 SIMD Instruction List by Daytime.