From ecd6df1c72aca4fd3d2494eb5b4dd47dc62a07d2 Mon Sep 17 00:00:00 2001 From: henry Date: Mon, 11 Dec 2006 08:35:49 +0000 Subject: (hopefully) the rest of PPC modifications git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@21587 b3059339-0415-0410-9bf9-f77b7e298cf2 --- libmpeg2/cpu_state.c | 16 +++++++------- libmpeg2/idct_altivec.c | 8 +++---- libmpeg2/libmpeg-0.4.1.diff | 52 +++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 64 insertions(+), 12 deletions(-) (limited to 'libmpeg2') diff --git a/libmpeg2/cpu_state.c b/libmpeg2/cpu_state.c index 07b9ebf354..819f693e32 100644 --- a/libmpeg2/cpu_state.c +++ b/libmpeg2/cpu_state.c @@ -47,19 +47,19 @@ static void state_restore_mmx (cpu_state_t * state) } #endif -#ifdef ARCH_PPC -#ifdef HAVE_ALTIVEC_H /* gnu */ -#define LI(a,b) "li " #a "," #b "\n\t" -#define STVX0(a,b,c) "stvx " #a ",0," #c "\n\t" -#define STVX(a,b,c) "stvx " #a "," #b "," #c "\n\t" -#define LVX0(a,b,c) "lvx " #a ",0," #c "\n\t" -#define LVX(a,b,c) "lvx " #a "," #b "," #c "\n\t" -#else /* apple */ +#if defined(ARCH_PPC) && defined(HAVE_ALTIVEC) +#if defined( __APPLE_CC__ ) && defined( __APPLE_ALTIVEC__ ) /* apple */ #define LI(a,b) "li r" #a "," #b "\n\t" #define STVX0(a,b,c) "stvx v" #a ",0,r" #c "\n\t" #define STVX(a,b,c) "stvx v" #a ",r" #b ",r" #c "\n\t" #define LVX0(a,b,c) "lvx v" #a ",0,r" #c "\n\t" #define LVX(a,b,c) "lvx v" #a ",r" #b ",r" #c "\n\t" +#else /* gnu */ +#define LI(a,b) "li " #a "," #b "\n\t" +#define STVX0(a,b,c) "stvx " #a ",0," #c "\n\t" +#define STVX(a,b,c) "stvx " #a "," #b "," #c "\n\t" +#define LVX0(a,b,c) "lvx " #a ",0," #c "\n\t" +#define LVX(a,b,c) "lvx " #a "," #b "," #c "\n\t" #endif static void state_save_altivec (cpu_state_t * state) diff --git a/libmpeg2/idct_altivec.c b/libmpeg2/idct_altivec.c index 6b1b8586c0..3eec6b49d0 100644 --- a/libmpeg2/idct_altivec.c +++ b/libmpeg2/idct_altivec.c @@ -41,7 +41,7 @@ typedef vector unsigned short vector_u16_t; typedef vector signed int vector_s32_t; typedef vector unsigned int vector_u32_t; -#if defined(HAVE_ALTIVEC_H) && (__GNUC__ * 100 + __GNUC_MINOR__ < 303) +#if defined( HAVE_ALTIVEC_H ) && !defined( __APPLE_ALTIVEC__ ) && (__GNUC__ * 100 + __GNUC_MINOR__ < 303) /* work around gcc <3.3 vec_mergel bug */ static inline vector_s16_t my_vec_mergel (vector_s16_t const A, vector_s16_t const B) @@ -56,10 +56,10 @@ static inline vector_s16_t my_vec_mergel (vector_s16_t const A, #define vec_mergel my_vec_mergel #endif -#ifdef HAVE_ALTIVEC_H /* gnu */ -#define VEC_S16(a,b,c,d,e,f,g,h) {a, b, c, d, e, f, g, h} -#else /* apple */ +#if defined( __APPLE_CC__ ) && defined( __APPLE_ALTIVEC__ ) /* apple */ #define VEC_S16(a,b,c,d,e,f,g,h) (vector_s16_t) (a, b, c, d, e, f, g, h) +#else /* gnu */ +#define VEC_S16(a,b,c,d,e,f,g,h) {a, b, c, d, e, f, g, h} #endif static const vector_s16_t constants ATTR_ALIGN(16) = diff --git a/libmpeg2/libmpeg-0.4.1.diff b/libmpeg2/libmpeg-0.4.1.diff index be7bd1b51a..4576c49aad 100644 --- a/libmpeg2/libmpeg-0.4.1.diff +++ b/libmpeg2/libmpeg-0.4.1.diff @@ -125,6 +125,33 @@ static void state_restore_mmx (cpu_state_t * state) { emms (); +@@ -48,18 +48,18 @@ + #endif + +-#ifdef ARCH_PPC ++#if defined(ARCH_PPC) && defined(HAVE_ALTIVEC) +-#ifdef HAVE_ALTIVEC_H /* gnu */ +-#define LI(a,b) "li " #a "," #b "\n\t" +-#define STVX0(a,b,c) "stvx " #a ",0," #c "\n\t" +-#define STVX(a,b,c) "stvx " #a "," #b "," #c "\n\t" +-#define LVX0(a,b,c) "lvx " #a ",0," #c "\n\t" +-#define LVX(a,b,c) "lvx " #a "," #b "," #c "\n\t" +-#else /* apple */ ++#if defined( __APPLE_CC__ ) && defined( __APPLE_ALTIVEC__ ) /* apple */ + #define LI(a,b) "li r" #a "," #b "\n\t" + #define STVX0(a,b,c) "stvx v" #a ",0,r" #c "\n\t" + #define STVX(a,b,c) "stvx v" #a ",r" #b ",r" #c "\n\t" + #define LVX0(a,b,c) "lvx v" #a ",0,r" #c "\n\t" + #define LVX(a,b,c) "lvx v" #a ",r" #b ",r" #c "\n\t" ++#else /* gnu */ ++#define LI(a,b) "li " #a "," #b "\n\t" ++#define STVX0(a,b,c) "stvx " #a ",0," #c "\n\t" ++#define STVX(a,b,c) "stvx " #a "," #b "," #c "\n\t" ++#define LVX0(a,b,c) "lvx " #a ",0," #c "\n\t" ++#define LVX(a,b,c) "lvx " #a "," #b "," #c "\n\t" + #endif + + static void state_save_altivec (cpu_state_t * state) @@ -115,12 +119,12 @@ void mpeg2_cpu_state_init (uint32_t accel) @@ -384,3 +411,28 @@ if (accel & MPEG2_ACCEL_PPC_ALTIVEC) { mpeg2_idct_copy = mpeg2_idct_copy_altivec; mpeg2_idct_add = mpeg2_idct_add_altivec; +--- libmpeg2/idct_altivec.c 2004/08/02 11:26:43 12933 ++++ libmpeg2/idct_altivec.c 2005/05/15 20:11:34 15484 +@@ -41,7 +41,7 @@ + typedef vector signed int vector_s32_t; + typedef vector unsigned int vector_u32_t; + +-#if defined(HAVE_ALTIVEC_H) && (__GNUC__ * 100 + __GNUC_MINOR__ < 303) ++#if defined( HAVE_ALTIVEC_H ) && !defined( __APPLE_ALTIVEC__ ) && (__GNUC__ * 100 + __GNUC_MINOR__ < 303) + /* work around gcc <3.3 vec_mergel bug */ + static inline vector_s16_t my_vec_mergel (vector_s16_t const A, + vector_s16_t const B) +@@ -56,10 +56,10 @@ + #define vec_mergel my_vec_mergel + #endif + +-#ifdef HAVE_ALTIVEC_H /* gnu */ +-#define VEC_S16(a,b,c,d,e,f,g,h) {a, b, c, d, e, f, g, h} +-#else /* apple */ ++#if defined( __APPLE_CC__ ) && defined( __APPLE_ALTIVEC__ ) /* apple */ + #define VEC_S16(a,b,c,d,e,f,g,h) (vector_s16_t) (a, b, c, d, e, f, g, h) ++#else /* gnu */ ++#define VEC_S16(a,b,c,d,e,f,g,h) {a, b, c, d, e, f, g, h} + #endif + + static const vector_s16_t constants ATTR_ALIGN(16) = -- cgit v1.2.3