mirror of
https://github.com/qemu/qemu.git
synced 2025-08-09 19:15:32 +00:00
target-ppc: Altivec 2.07: vmuluw Instruction
This patch adds the Vector Multiply Unsigned Word Modulo (vmuluwm) instruction. The existing VARITH_DO macro is re-used to (trivially) instantiate the helper code. Since bits 21-31 of any vmuluwm instruction is 137, the instruction is coded as a dual to vmulouw (bits 21-31 = 136). Signed-off-by: Tom Musta <tommusta@gmail.com> Signed-off-by: Alexander Graf <agraf@suse.de>
This commit is contained in:
parent
63be09365a
commit
953f0f5842
@ -176,6 +176,7 @@ DEF_HELPER_3(vmulosw, void, avr, avr, avr)
|
|||||||
DEF_HELPER_3(vmuloub, void, avr, avr, avr)
|
DEF_HELPER_3(vmuloub, void, avr, avr, avr)
|
||||||
DEF_HELPER_3(vmulouh, void, avr, avr, avr)
|
DEF_HELPER_3(vmulouh, void, avr, avr, avr)
|
||||||
DEF_HELPER_3(vmulouw, void, avr, avr, avr)
|
DEF_HELPER_3(vmulouw, void, avr, avr, avr)
|
||||||
|
DEF_HELPER_3(vmuluwm, void, avr, avr, avr)
|
||||||
DEF_HELPER_3(vsrab, void, avr, avr, avr)
|
DEF_HELPER_3(vsrab, void, avr, avr, avr)
|
||||||
DEF_HELPER_3(vsrah, void, avr, avr, avr)
|
DEF_HELPER_3(vsrah, void, avr, avr, avr)
|
||||||
DEF_HELPER_3(vsraw, void, avr, avr, avr)
|
DEF_HELPER_3(vsraw, void, avr, avr, avr)
|
||||||
|
@ -505,6 +505,7 @@ VARITH(ubm, u8)
|
|||||||
VARITH(uhm, u16)
|
VARITH(uhm, u16)
|
||||||
VARITH(uwm, u32)
|
VARITH(uwm, u32)
|
||||||
VARITH(udm, u64)
|
VARITH(udm, u64)
|
||||||
|
VARITH_DO(muluwm, *, u32)
|
||||||
#undef VARITH_DO
|
#undef VARITH_DO
|
||||||
#undef VARITH
|
#undef VARITH
|
||||||
|
|
||||||
|
@ -6964,6 +6964,9 @@ GEN_VXFORM(vmrglw, 6, 6);
|
|||||||
GEN_VXFORM(vmuloub, 4, 0);
|
GEN_VXFORM(vmuloub, 4, 0);
|
||||||
GEN_VXFORM(vmulouh, 4, 1);
|
GEN_VXFORM(vmulouh, 4, 1);
|
||||||
GEN_VXFORM(vmulouw, 4, 2);
|
GEN_VXFORM(vmulouw, 4, 2);
|
||||||
|
GEN_VXFORM(vmuluwm, 4, 2);
|
||||||
|
GEN_VXFORM_DUAL(vmulouw, PPC_ALTIVEC, PPC_NONE,
|
||||||
|
vmuluwm, PPC_NONE, PPC2_ALTIVEC_207)
|
||||||
GEN_VXFORM(vmulosb, 4, 4);
|
GEN_VXFORM(vmulosb, 4, 4);
|
||||||
GEN_VXFORM(vmulosh, 4, 5);
|
GEN_VXFORM(vmulosh, 4, 5);
|
||||||
GEN_VXFORM(vmulosw, 4, 6);
|
GEN_VXFORM(vmulosw, 4, 6);
|
||||||
@ -10375,7 +10378,7 @@ GEN_VXFORM(vmrglh, 6, 5),
|
|||||||
GEN_VXFORM(vmrglw, 6, 6),
|
GEN_VXFORM(vmrglw, 6, 6),
|
||||||
GEN_VXFORM(vmuloub, 4, 0),
|
GEN_VXFORM(vmuloub, 4, 0),
|
||||||
GEN_VXFORM(vmulouh, 4, 1),
|
GEN_VXFORM(vmulouh, 4, 1),
|
||||||
GEN_VXFORM_207(vmulouw, 4, 2),
|
GEN_VXFORM_DUAL(vmulouw, vmuluwm, 4, 2, PPC_ALTIVEC, PPC_NONE),
|
||||||
GEN_VXFORM(vmulosb, 4, 4),
|
GEN_VXFORM(vmulosb, 4, 4),
|
||||||
GEN_VXFORM(vmulosh, 4, 5),
|
GEN_VXFORM(vmulosh, 4, 5),
|
||||||
GEN_VXFORM_207(vmulosw, 4, 6),
|
GEN_VXFORM_207(vmulosw, 4, 6),
|
||||||
|
Loading…
Reference in New Issue
Block a user