mirror of
https://github.com/qemu/qemu.git
synced 2024-11-26 12:23:36 +08:00
target-ppc: Altivec 2.07: Add/Subtract Unsigned Doubleword Modulo
This patch adds two Altivec unsigned doublword modulo instructions that are introduced in Power ISA Version V2.07: - vaddudm : Vector Add Unsigned Doubleword Modulo - vsubudm : Vector Subtrace Unsigned Doubleword Modulo Signed-off-by: Tom Musta <tommusta@gmail.com> Signed-off-by: Alexander Graf <agraf@suse.de>
This commit is contained in:
parent
111c5f54a1
commit
56eabc7508
@ -109,9 +109,11 @@ DEF_HELPER_FLAGS_1(ftsqrt, TCG_CALL_NO_RWG_SE, i32, i64)
|
||||
DEF_HELPER_3(vaddubm, void, avr, avr, avr)
|
||||
DEF_HELPER_3(vadduhm, void, avr, avr, avr)
|
||||
DEF_HELPER_3(vadduwm, void, avr, avr, avr)
|
||||
DEF_HELPER_3(vaddudm, void, avr, avr, avr)
|
||||
DEF_HELPER_3(vsububm, void, avr, avr, avr)
|
||||
DEF_HELPER_3(vsubuhm, void, avr, avr, avr)
|
||||
DEF_HELPER_3(vsubuwm, void, avr, avr, avr)
|
||||
DEF_HELPER_3(vsubudm, void, avr, avr, avr)
|
||||
DEF_HELPER_3(vavgub, void, avr, avr, avr)
|
||||
DEF_HELPER_3(vavguh, void, avr, avr, avr)
|
||||
DEF_HELPER_3(vavguw, void, avr, avr, avr)
|
||||
|
@ -504,6 +504,7 @@ void helper_vaddcuw(ppc_avr_t *r, ppc_avr_t *a, ppc_avr_t *b)
|
||||
VARITH(ubm, u8)
|
||||
VARITH(uhm, u16)
|
||||
VARITH(uwm, u32)
|
||||
VARITH(udm, u64)
|
||||
#undef VARITH_DO
|
||||
#undef VARITH
|
||||
|
||||
|
@ -6932,9 +6932,11 @@ static void glue(gen_, name0##_##name1)(DisasContext *ctx) \
|
||||
GEN_VXFORM(vaddubm, 0, 0);
|
||||
GEN_VXFORM(vadduhm, 0, 1);
|
||||
GEN_VXFORM(vadduwm, 0, 2);
|
||||
GEN_VXFORM(vaddudm, 0, 3);
|
||||
GEN_VXFORM(vsububm, 0, 16);
|
||||
GEN_VXFORM(vsubuhm, 0, 17);
|
||||
GEN_VXFORM(vsubuwm, 0, 18);
|
||||
GEN_VXFORM(vsubudm, 0, 19);
|
||||
GEN_VXFORM(vmaxub, 1, 0);
|
||||
GEN_VXFORM(vmaxuh, 1, 1);
|
||||
GEN_VXFORM(vmaxuw, 1, 2);
|
||||
@ -10338,9 +10340,11 @@ GEN_HANDLER_E(name0##_##name1, 0x4, opc2, (opc3 | 0x10), 0x00000000, tp0, tp1),
|
||||
GEN_VXFORM(vaddubm, 0, 0),
|
||||
GEN_VXFORM(vadduhm, 0, 1),
|
||||
GEN_VXFORM(vadduwm, 0, 2),
|
||||
GEN_VXFORM_207(vaddudm, 0, 3),
|
||||
GEN_VXFORM(vsububm, 0, 16),
|
||||
GEN_VXFORM(vsubuhm, 0, 17),
|
||||
GEN_VXFORM(vsubuwm, 0, 18),
|
||||
GEN_VXFORM_207(vsubudm, 0, 19),
|
||||
GEN_VXFORM(vmaxub, 1, 0),
|
||||
GEN_VXFORM(vmaxuh, 1, 1),
|
||||
GEN_VXFORM(vmaxuw, 1, 2),
|
||||
|
Loading…
Reference in New Issue
Block a user