summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPetri Hintukainen <phintuka@users.sourceforge.net>2012-03-29 12:43:55 +0300
committerPetri Hintukainen <phintuka@users.sourceforge.net>2012-03-29 12:43:55 +0300
commitf16beec935a55a18bd09f84e5fff7fcbe0943f1d (patch)
treef1e935e127b7e4380420d7952700ce2fee3487e5 /src
parent0bd49a14320a205abd7300abbd6003b4cf7276d8 (diff)
downloadxine-lib-f16beec935a55a18bd09f84e5fff7fcbe0943f1d.tar.gz
xine-lib-f16beec935a55a18bd09f84e5fff7fcbe0943f1d.tar.bz2
Added macros for loading 32-bit value to mmx/sse register from memory or GP register (mmx_a2r)
Diffstat (limited to 'src')
-rw-r--r--src/xine-utils/xine_mmx.h13
1 files changed, 13 insertions, 0 deletions
diff --git a/src/xine-utils/xine_mmx.h b/src/xine-utils/xine_mmx.h
index 26e712409..dab061688 100644
--- a/src/xine-utils/xine_mmx.h
+++ b/src/xine-utils/xine_mmx.h
@@ -46,11 +46,22 @@ typedef union {
: /* nothing */ \
: "m" (mem))
+/* load dword from memory or gp register */
+#define mmx_a2r(op,any,reg) \
+ __asm__ __volatile__ (#op " %0, %%" #reg \
+ : /* nothing */ \
+ : "g" (any))
+
#define mmx_r2m(op,reg,mem) \
__asm__ __volatile__ (#op " %%" #reg ", %0" \
: "=m" (mem) \
: /* nothing */ )
+#define mmx_r2a(op,reg,any) \
+ __asm__ __volatile__ (#op " %%" #reg ", %0" \
+ : "=g" (any) \
+ : /* nothing */ )
+
#define mmx_r2r(op,regs,regd) \
__asm__ __volatile__ (#op " %" #regs ", %" #regd)
@@ -60,6 +71,8 @@ typedef union {
#define movd_m2r(var,reg) mmx_m2r (movd, var, reg)
#define movd_r2m(reg,var) mmx_r2m (movd, reg, var)
#define movd_r2r(regs,regd) mmx_r2r (movd, regs, regd)
+#define movd_a2r(any,reg) mmx_a2r (movd, any, reg)
+#define movd_r2a(reg,any) mmx_r2a (movd, reg, any)
#define movq_m2r(var,reg) mmx_m2r (movq, var, reg)
#define movq_r2m(reg,var) mmx_r2m (movq, reg, var)