mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 08:13:54 -06:00
target/riscv: vector bitwise logical instructions
Signed-off-by: LIU Zhiwei <zhiwei_liu@c-sky.com> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Message-Id: <20200701152549.1218-14-zhiwei_liu@c-sky.com> Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
This commit is contained in:
parent
3a6f8f68ad
commit
d3842924cf
4 changed files with 96 additions and 0 deletions
|
@ -1265,3 +1265,54 @@ GEN_VEXT_VMADC_VXM(vmsbc_vxm_b, uint8_t, H1, DO_MSBC)
|
|||
GEN_VEXT_VMADC_VXM(vmsbc_vxm_h, uint16_t, H2, DO_MSBC)
|
||||
GEN_VEXT_VMADC_VXM(vmsbc_vxm_w, uint32_t, H4, DO_MSBC)
|
||||
GEN_VEXT_VMADC_VXM(vmsbc_vxm_d, uint64_t, H8, DO_MSBC)
|
||||
|
||||
/* Vector Bitwise Logical Instructions */
|
||||
RVVCALL(OPIVV2, vand_vv_b, OP_SSS_B, H1, H1, H1, DO_AND)
|
||||
RVVCALL(OPIVV2, vand_vv_h, OP_SSS_H, H2, H2, H2, DO_AND)
|
||||
RVVCALL(OPIVV2, vand_vv_w, OP_SSS_W, H4, H4, H4, DO_AND)
|
||||
RVVCALL(OPIVV2, vand_vv_d, OP_SSS_D, H8, H8, H8, DO_AND)
|
||||
RVVCALL(OPIVV2, vor_vv_b, OP_SSS_B, H1, H1, H1, DO_OR)
|
||||
RVVCALL(OPIVV2, vor_vv_h, OP_SSS_H, H2, H2, H2, DO_OR)
|
||||
RVVCALL(OPIVV2, vor_vv_w, OP_SSS_W, H4, H4, H4, DO_OR)
|
||||
RVVCALL(OPIVV2, vor_vv_d, OP_SSS_D, H8, H8, H8, DO_OR)
|
||||
RVVCALL(OPIVV2, vxor_vv_b, OP_SSS_B, H1, H1, H1, DO_XOR)
|
||||
RVVCALL(OPIVV2, vxor_vv_h, OP_SSS_H, H2, H2, H2, DO_XOR)
|
||||
RVVCALL(OPIVV2, vxor_vv_w, OP_SSS_W, H4, H4, H4, DO_XOR)
|
||||
RVVCALL(OPIVV2, vxor_vv_d, OP_SSS_D, H8, H8, H8, DO_XOR)
|
||||
GEN_VEXT_VV(vand_vv_b, 1, 1, clearb)
|
||||
GEN_VEXT_VV(vand_vv_h, 2, 2, clearh)
|
||||
GEN_VEXT_VV(vand_vv_w, 4, 4, clearl)
|
||||
GEN_VEXT_VV(vand_vv_d, 8, 8, clearq)
|
||||
GEN_VEXT_VV(vor_vv_b, 1, 1, clearb)
|
||||
GEN_VEXT_VV(vor_vv_h, 2, 2, clearh)
|
||||
GEN_VEXT_VV(vor_vv_w, 4, 4, clearl)
|
||||
GEN_VEXT_VV(vor_vv_d, 8, 8, clearq)
|
||||
GEN_VEXT_VV(vxor_vv_b, 1, 1, clearb)
|
||||
GEN_VEXT_VV(vxor_vv_h, 2, 2, clearh)
|
||||
GEN_VEXT_VV(vxor_vv_w, 4, 4, clearl)
|
||||
GEN_VEXT_VV(vxor_vv_d, 8, 8, clearq)
|
||||
|
||||
RVVCALL(OPIVX2, vand_vx_b, OP_SSS_B, H1, H1, DO_AND)
|
||||
RVVCALL(OPIVX2, vand_vx_h, OP_SSS_H, H2, H2, DO_AND)
|
||||
RVVCALL(OPIVX2, vand_vx_w, OP_SSS_W, H4, H4, DO_AND)
|
||||
RVVCALL(OPIVX2, vand_vx_d, OP_SSS_D, H8, H8, DO_AND)
|
||||
RVVCALL(OPIVX2, vor_vx_b, OP_SSS_B, H1, H1, DO_OR)
|
||||
RVVCALL(OPIVX2, vor_vx_h, OP_SSS_H, H2, H2, DO_OR)
|
||||
RVVCALL(OPIVX2, vor_vx_w, OP_SSS_W, H4, H4, DO_OR)
|
||||
RVVCALL(OPIVX2, vor_vx_d, OP_SSS_D, H8, H8, DO_OR)
|
||||
RVVCALL(OPIVX2, vxor_vx_b, OP_SSS_B, H1, H1, DO_XOR)
|
||||
RVVCALL(OPIVX2, vxor_vx_h, OP_SSS_H, H2, H2, DO_XOR)
|
||||
RVVCALL(OPIVX2, vxor_vx_w, OP_SSS_W, H4, H4, DO_XOR)
|
||||
RVVCALL(OPIVX2, vxor_vx_d, OP_SSS_D, H8, H8, DO_XOR)
|
||||
GEN_VEXT_VX(vand_vx_b, 1, 1, clearb)
|
||||
GEN_VEXT_VX(vand_vx_h, 2, 2, clearh)
|
||||
GEN_VEXT_VX(vand_vx_w, 4, 4, clearl)
|
||||
GEN_VEXT_VX(vand_vx_d, 8, 8, clearq)
|
||||
GEN_VEXT_VX(vor_vx_b, 1, 1, clearb)
|
||||
GEN_VEXT_VX(vor_vx_h, 2, 2, clearh)
|
||||
GEN_VEXT_VX(vor_vx_w, 4, 4, clearl)
|
||||
GEN_VEXT_VX(vor_vx_d, 8, 8, clearq)
|
||||
GEN_VEXT_VX(vxor_vx_b, 1, 1, clearb)
|
||||
GEN_VEXT_VX(vxor_vx_h, 2, 2, clearh)
|
||||
GEN_VEXT_VX(vxor_vx_w, 4, 4, clearl)
|
||||
GEN_VEXT_VX(vxor_vx_d, 8, 8, clearq)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue