SVE Instruction List by Dougall Johnson
RSUBHNT: Rounding subtract narrow high part (top)
RSUBHNT Zd.H, Zn.S, Zm.S (SVE2 (SME
svint16_t svrsubhnt[_s32](svint16_t even, svint32_t op1, svint32_t op2)
svuint16_t svrsubhnt[_u32](svuint16_t even, svuint32_t op1, svuint32_t op2)
128-bit SVE
data:image/s3,"s3://crabby-images/08067/08067cca25549629fc1cf1bf9191463d28758334" alt=""
For each 32-bit integer set the odd 16-bit elements of (3) to ( (1) − (2) + 0x8000 ) >> 16, preserving even elements.
256-bit SVE
data:image/s3,"s3://crabby-images/ea54d/ea54d51ba496661d31cfb7f6ff728abe21a40ae3" alt=""
For each 32-bit integer set the odd 16-bit elements of (3) to ( (1) − (2) + 0x8000 ) >> 16, preserving even elements.
512-bit SVE
data:image/s3,"s3://crabby-images/22fec/22fec33622569a8ead4f2d6a5e2d6ea3d6cba451" alt=""
For each 32-bit integer set the odd 16-bit elements of (3) to ( (1) − (2) + 0x8000 ) >> 16, preserving even elements.
Larger sizes
1024-bit SVE
data:image/s3,"s3://crabby-images/3cd83/3cd83458dd8042ccb726be0cfc98985f9e8ac03d" alt=""
For each 32-bit integer set the odd 16-bit elements of (3) to ( (1) − (2) + 0x8000 ) >> 16, preserving even elements.
2048-bit SVE
data:image/s3,"s3://crabby-images/a92df/a92dff18f0431378aee1c4a8cdfd95d731c3a540" alt=""
For each 32-bit integer set the odd 16-bit elements of (3) to ( (1) − (2) + 0x8000 ) >> 16, preserving even elements.
Report mistakes or give feedback
Inspired by and based on the x86/x64 SIMD Instruction List by Daytime.