Disable AltiVec IDCT for lowres decoding in lavc patch by (Sigbjørn Skjæret: cisc...
authorSigbjørn Skjæret <cisc@broadpark.no>
Fri, 1 Jul 2005 09:37:35 +0000 (09:37 +0000)
committerMichael Niedermayer <michaelni@gmx.at>
Fri, 1 Jul 2005 09:37:35 +0000 (09:37 +0000)
Originally committed as revision 4413 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavcodec/ppc/dsputil_ppc.c
libavcodec/ppc/mpegvideo_ppc.c

index 80dea03..776f423 100644 (file)
@@ -305,6 +305,8 @@ void dsputil_init_ppc(DSPContext* c, AVCodecContext *avctx)
        }
 #endif //CONFIG_ENCODERS
 
+      if (avctx->lowres==0)
+      {
         if ((avctx->idct_algo == FF_IDCT_AUTO) ||
                 (avctx->idct_algo == FF_IDCT_ALTIVEC))
         {
@@ -316,6 +318,7 @@ void dsputil_init_ppc(DSPContext* c, AVCodecContext *avctx)
             c->idct_permutation_type = FF_NO_IDCT_PERM;
 #endif /* ALTIVEC_USE_REFERENCE_C_CODE */
         }
+      }
         
 #ifdef POWERPC_PERFORMANCE_REPORT
         {
index c8269eb..832bace 100644 (file)
@@ -39,6 +39,8 @@ void MPV_common_init_ppc(MpegEncContext *s)
 #ifdef HAVE_ALTIVEC
     if (has_altivec())
     {
+      if (s->avctx->lowres==0)
+      {
         if ((s->avctx->idct_algo == FF_IDCT_AUTO) ||
                 (s->avctx->idct_algo == FF_IDCT_ALTIVEC))
         {
@@ -50,6 +52,7 @@ void MPV_common_init_ppc(MpegEncContext *s)
             s->dsp.idct_permutation_type = FF_NO_IDCT_PERM;
 #endif /* ALTIVEC_USE_REFERENCE_C_CODE */
         }
+      }
 
         // Test to make sure that the dct required alignments are met.
         if ((((long)(s->q_intra_matrix) & 0x0f) != 0) ||