mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-01 23:03:54 -06:00
target/loongarch: Implement vadda
This patch includes: - VADDA.{B/H/W/D}. Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Song Gao <gaosong@loongson.cn> Message-Id: <20230504122810.4094787-13-gaosong@loongson.cn>
This commit is contained in:
parent
4972565967
commit
af448cb31a
5 changed files with 87 additions and 0 deletions
|
@ -318,3 +318,22 @@ DO_3OP(vabsd_bu, 8, UB, DO_VABSD)
|
|||
DO_3OP(vabsd_hu, 16, UH, DO_VABSD)
|
||||
DO_3OP(vabsd_wu, 32, UW, DO_VABSD)
|
||||
DO_3OP(vabsd_du, 64, UD, DO_VABSD)
|
||||
|
||||
#define DO_VABS(a) ((a < 0) ? (-a) : (a))
|
||||
|
||||
#define DO_VADDA(NAME, BIT, E, DO_OP) \
|
||||
void HELPER(NAME)(void *vd, void *vj, void *vk, uint32_t v) \
|
||||
{ \
|
||||
int i; \
|
||||
VReg *Vd = (VReg *)vd; \
|
||||
VReg *Vj = (VReg *)vj; \
|
||||
VReg *Vk = (VReg *)vk; \
|
||||
for (i = 0; i < LSX_LEN/BIT; i++) { \
|
||||
Vd->E(i) = DO_OP(Vj->E(i)) + DO_OP(Vk->E(i)); \
|
||||
} \
|
||||
}
|
||||
|
||||
DO_VADDA(vadda_b, 8, B, DO_VABS)
|
||||
DO_VADDA(vadda_h, 16, H, DO_VABS)
|
||||
DO_VADDA(vadda_w, 32, W, DO_VABS)
|
||||
DO_VADDA(vadda_d, 64, D, DO_VABS)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue