[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 10/42] target-ppc: add vcmpequ{b, h, w} and vcmpgt{s
From: |
Nathan Froyd |
Subject: |
[Qemu-devel] [PATCH 10/42] target-ppc: add vcmpequ{b, h, w} and vcmpgt{s, u}{b, h, w} instructions. |
Date: |
Sun, 14 Dec 2008 18:14:43 -0800 |
Signed-off-by: Nathan Froyd <address@hidden>
---
target-ppc/helper.h | 9 +++++++++
target-ppc/op_helper.c | 33 +++++++++++++++++++++++++++++++++
target-ppc/translate.c | 10 ++++++++++
3 files changed, 52 insertions(+), 0 deletions(-)
diff --git a/target-ppc/helper.h b/target-ppc/helper.h
index 196106e..efe7a1a 100644
--- a/target-ppc/helper.h
+++ b/target-ppc/helper.h
@@ -123,6 +123,15 @@ DEF_HELPER_3(vminuw, void, avr, avr, avr)
DEF_HELPER_3(vmaxub, void, avr, avr, avr)
DEF_HELPER_3(vmaxuh, void, avr, avr, avr)
DEF_HELPER_3(vmaxuw, void, avr, avr, avr)
+DEF_HELPER_3(vcmpequb, i32, avr, avr, avr)
+DEF_HELPER_3(vcmpequh, i32, avr, avr, avr)
+DEF_HELPER_3(vcmpequw, i32, avr, avr, avr)
+DEF_HELPER_3(vcmpgtub, i32, avr, avr, avr)
+DEF_HELPER_3(vcmpgtuh, i32, avr, avr, avr)
+DEF_HELPER_3(vcmpgtuw, i32, avr, avr, avr)
+DEF_HELPER_3(vcmpgtsb, i32, avr, avr, avr)
+DEF_HELPER_3(vcmpgtsh, i32, avr, avr, avr)
+DEF_HELPER_3(vcmpgtsw, i32, avr, avr, avr)
DEF_HELPER_1(efscfsi, i32, i32)
DEF_HELPER_1(efscfui, i32, i32)
diff --git a/target-ppc/op_helper.c b/target-ppc/op_helper.c
index 8f74286..d36a046 100644
--- a/target-ppc/op_helper.c
+++ b/target-ppc/op_helper.c
@@ -2066,6 +2066,39 @@ VAVG(w, s32, int64_t, u32, uint64_t)
#undef VAVG_DO
#undef VAVG
+#define VCMP(suffix, compare, element) \
+ uint32_t helper_vcmp##suffix (ppc_avr_t *r, ppc_avr_t *a, ppc_avr_t *b) \
+ { \
+ uint32_t ones = (sizeof (a->element[0]) == 4 \
+ ? 0xffffffff \
+ : (sizeof (a->element[0]) == 2 \
+ ? 0xffff \
+ : 0xff)); \
+ uint32_t all = ones; \
+ uint32_t none = 0; \
+ VECTOR_FOR (element) { \
+ uint32_t result = (a->element[i] compare b->element[i] ? ones :
0x0); \
+ switch (sizeof (a->element[0])) { \
+ case 4: r->u32[i] = result; break; \
+ case 2: r->u16[i] = result; break; \
+ case 1: r->u8[i] = result; break; \
+ } \
+ all &= result; \
+ none |= result; \
+ } \
+ return ((all != 0) << 3) | ((none == 0) << 1); \
+ }
+VCMP(equb, ==, u8)
+VCMP(equh, ==, u16)
+VCMP(equw, ==, u32)
+VCMP(gtub, >, u8)
+VCMP(gtuh, >, u16)
+VCMP(gtuw, >, u32)
+VCMP(gtsb, >, s8)
+VCMP(gtsh, >, s16)
+VCMP(gtsw, >, s32)
+#undef VCMP
+
#define VMINMAX_DO(name, compare, element) \
void helper_v##name (ppc_avr_t *r, ppc_avr_t *a, ppc_avr_t *b) \
{ \
diff --git a/target-ppc/translate.c b/target-ppc/translate.c
index 53cff59..8b90971 100644
--- a/target-ppc/translate.c
+++ b/target-ppc/translate.c
@@ -6203,6 +6203,16 @@ GEN_VXFORM(vavgsw, 1410);
GEN_VXRFORM1(name, name, #name, xo, 0) \
GEN_VXRFORM1(name, name##_, #name ".", xo, 1)
+GEN_VXRFORM(vcmpequb, 6)
+GEN_VXRFORM(vcmpequh, 70)
+GEN_VXRFORM(vcmpequw, 134)
+GEN_VXRFORM(vcmpgtsb, 774)
+GEN_VXRFORM(vcmpgtsh, 838)
+GEN_VXRFORM(vcmpgtsw, 902)
+GEN_VXRFORM(vcmpgtub, 518)
+GEN_VXRFORM(vcmpgtuh, 582)
+GEN_VXRFORM(vcmpgtuw, 646)
+
/*** SPE extension ***/
/* Register moves */
--
1.6.0.5
- [Qemu-devel] [PATCH] target-ppc: add Altivec instructions, patch-bomb version, Nathan Froyd, 2008/12/14
- [Qemu-devel] [PATCH 06/42] target-ppc: add signed fields to ppc_avr_t., Nathan Froyd, 2008/12/14
- [Qemu-devel] [PATCH 07/42] target-ppc: add vavg{s, u}{b, h, w} instructions., Nathan Froyd, 2008/12/14
- [Qemu-devel] [PATCH 10/42] target-ppc: add vcmpequ{b, h, w} and vcmpgt{s, u}{b, h, w} instructions.,
Nathan Froyd <=
- [Qemu-devel] [PATCH 12/42] target-ppc: add vmrg{l, h}{b, h, w} instructions., Nathan Froyd, 2008/12/14
- [Qemu-devel] [PATCH 14/42] target-ppc: add vsr{, a}{b, h, w} instructions., Nathan Froyd, 2008/12/14
- [Qemu-devel] [PATCH 17/42] target-ppc: add v{add, sub}cuw instructions., Nathan Froyd, 2008/12/14
- [Qemu-devel] [PATCH 18/42] target-ppc: add lvs{l,r} instructions., Nathan Froyd, 2008/12/14
- [Qemu-devel] [PATCH 19/42] target-ppc: add m{f, t}vscr instructions., Nathan Froyd, 2008/12/14
- [Qemu-devel] [PATCH 23/42] target-ppc: add vsldoi instruction., Nathan Froyd, 2008/12/14
- [Qemu-devel] [PATCH 28/42] target-ppc: add GEN_VXFORM_NOA macro for subsequent instructions., Nathan Froyd, 2008/12/14
- [Qemu-devel] [PATCH 31/42] target-ppc: add GEN_VAFORM_PAIRED macro for subsequent instructions., Nathan Froyd, 2008/12/14
- [Qemu-devel] [PATCH 35/42] target-ppc: add vpks{h, w}{s, u}s, vpku{h, w}us, and vpku{h, w}um instructions., Nathan Froyd, 2008/12/14
- [Qemu-devel] [PATCH 39/42] target-ppc: add vmsumsh{m, s} instructions., Nathan Froyd, 2008/12/14
- Prev by Date:
[Qemu-devel] [PATCH 07/42] target-ppc: add vavg{s, u}{b, h, w} instructions.
- Next by Date:
[Qemu-devel] [PATCH 12/42] target-ppc: add vmrg{l, h}{b, h, w} instructions.
- Previous by thread:
[Qemu-devel] [PATCH 07/42] target-ppc: add vavg{s, u}{b, h, w} instructions.
- Next by thread:
[Qemu-devel] [PATCH 12/42] target-ppc: add vmrg{l, h}{b, h, w} instructions.
- Index(es):