Merge commit 'd396987c303bdc4eea7d1a1ff6776475d9bbd9ea' into release/2.2
authorMichael Niedermayer <michaelni@gmx.at>
Wed, 30 Jul 2014 18:35:23 +0000 (20:35 +0200)
committerMichael Niedermayer <michaelni@gmx.at>
Wed, 30 Jul 2014 18:35:23 +0000 (20:35 +0200)
* commit 'd396987c303bdc4eea7d1a1ff6776475d9bbd9ea':
  fate: Add dependencies for dct/fft/mdct/rdft tests

Conflicts:
libavcodec/fft-test.c
tests/fate/fft.mak

Merged-by: Michael Niedermayer <michaelni@gmx.at>
1  2 
libavcodec/fft-test.c
tests/fate/fft.mak

diff --combined libavcodec/fft-test.c
@@@ -1,20 -1,20 +1,20 @@@
  /*
   * (c) 2002 Fabrice Bellard
   *
 - * This file is part of Libav.
 + * This file is part of FFmpeg.
   *
 - * Libav is free software; you can redistribute it and/or
 + * FFmpeg is free software; you can redistribute it and/or
   * modify it under the terms of the GNU Lesser General Public
   * License as published by the Free Software Foundation; either
   * version 2.1 of the License, or (at your option) any later version.
   *
 - * Libav is distributed in the hope that it will be useful,
 + * FFmpeg is distributed in the hope that it will be useful,
   * but WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   * Lesser General Public License for more details.
   *
   * You should have received a copy of the GNU Lesser General Public
 - * License along with Libav; if not, write to the Free Software
 + * License along with FFmpeg; if not, write to the Free Software
   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
   */
  
  #   define RANGE 1.0
  #   define REF_SCALE(x, bits)  (x)
  #   define FMT "%10.6f"
 +#elif FFT_FIXED_32
 +#   define RANGE 8388608
 +#   define REF_SCALE(x, bits) (x)
 +#   define FMT "%6d"
  #else
  #   define RANGE 16384
  #   define REF_SCALE(x, bits) ((x) / (1<<(bits)))
@@@ -117,6 -113,7 +117,7 @@@ static void fft_ref(FFTComplex *tabr, F
      }
  }
  
+ #if CONFIG_MDCT
  static void imdct_ref(FFTSample *out, FFTSample *in, int nbits)
  {
      int n = 1<<nbits;
@@@ -151,9 -148,11 +152,11 @@@ static void mdct_ref(FFTSample *output
          output[k] = REF_SCALE(s, nbits - 1);
      }
  }
+ #endif /* CONFIG_MDCT */
  
  #if FFT_FLOAT
 -static void idct_ref(float *output, float *input, int nbits)
+ #if CONFIG_DCT
 +static void idct_ref(FFTSample *output, FFTSample *input, int nbits)
  {
      int n = 1<<nbits;
      int k, i;
          output[i] = 2 * s / n;
      }
  }
 -static void dct_ref(float *output, float *input, int nbits)
 +static void dct_ref(FFTSample *output, FFTSample *input, int nbits)
  {
      int n = 1<<nbits;
      int k, i;
          output[k] = s;
      }
  }
+ #endif /* CONFIG_DCT */
  #endif
  
  
@@@ -210,7 -210,7 +214,7 @@@ static int check_diff(FFTSample *tab1, 
          error+= e*e;
          if(e>max) max= e;
      }
 -    av_log(NULL, AV_LOG_INFO, "max:%f e:%g\n", max, sqrt(error)/n);
 +    av_log(NULL, AV_LOG_INFO, "max:%f e:%g\n", max, sqrt(error/n));
      return err;
  }
  
@@@ -293,12 -293,10 +297,12 @@@ int main(int argc, char **argv
              scale = atof(optarg);
              break;
          case 'c':
 -            cpuflags = av_parse_cpu_flags(optarg);
 -            if (cpuflags < 0)
 +            cpuflags = av_get_cpu_flags();
 +
 +            if (av_parse_cpu_caps(&cpuflags, optarg) < 0)
                  return 1;
 -            av_set_cpu_flags_mask(cpuflags);
 +
 +            av_force_cpu_flags(cpuflags);
              break;
          }
      }
      tab2 = av_malloc(fft_size * sizeof(FFTSample));
  
      switch (transform) {
+ #if CONFIG_MDCT
      case TRANSFORM_MDCT:
          av_log(NULL, AV_LOG_INFO,"Scale factor is set to %f\n", scale);
          if (do_inverse)
              av_log(NULL, AV_LOG_INFO,"MDCT");
          ff_mdct_init(m, fft_nbits, do_inverse, scale);
          break;
+ #endif /* CONFIG_MDCT */
      case TRANSFORM_FFT:
          if (do_inverse)
              av_log(NULL, AV_LOG_INFO,"IFFT");
          fft_ref_init(fft_nbits, do_inverse);
          break;
  #if FFT_FLOAT
 -#if CONFIG_RDFT
++#    if CONFIG_RDFT
      case TRANSFORM_RDFT:
          if (do_inverse)
              av_log(NULL, AV_LOG_INFO,"IDFT_C2R");
          ff_rdft_init(r, fft_nbits, do_inverse ? IDFT_C2R : DFT_R2C);
          fft_ref_init(fft_nbits, do_inverse);
          break;
 -#endif /* CONFIG_RDFT */
 -#if CONFIG_DCT
++#    endif /* CONFIG_RDFT */
 +#    if CONFIG_DCT
      case TRANSFORM_DCT:
          if (do_inverse)
              av_log(NULL, AV_LOG_INFO,"DCT_III");
              av_log(NULL, AV_LOG_INFO,"DCT_II");
          ff_dct_init(d, fft_nbits, do_inverse ? DCT_III : DCT_II);
          break;
- #    endif
 -#endif /* CONFIG_DCT */
++#    endif /* CONFIG_DCT */
  #endif
      default:
          av_log(NULL, AV_LOG_ERROR, "Requested transform not supported\n");
      av_log(NULL, AV_LOG_INFO,"Checking...\n");
  
      switch (transform) {
+ #if CONFIG_MDCT
      case TRANSFORM_MDCT:
          if (do_inverse) {
              imdct_ref((FFTSample *)tab_ref, (FFTSample *)tab1, fft_nbits);
              err = check_diff((FFTSample *)tab_ref, tab2, fft_size / 2, scale);
          }
          break;
+ #endif /* CONFIG_MDCT */
      case TRANSFORM_FFT:
          memcpy(tab, tab1, fft_size * sizeof(FFTComplex));
          s->fft_permute(s, tab);
          err = check_diff((FFTSample *)tab_ref, (FFTSample *)tab, fft_size * 2, 1.0);
          break;
  #if FFT_FLOAT
+ #if CONFIG_RDFT
      case TRANSFORM_RDFT:
          fft_size_2 = fft_size >> 1;
          if (do_inverse) {
              err = check_diff((float *)tab_ref, (float *)tab2, fft_size, 1.0);
          }
          break;
+ #endif /* CONFIG_RDFT */
+ #if CONFIG_DCT
      case TRANSFORM_DCT:
          memcpy(tab, tab1, fft_size * sizeof(FFTComplex));
 -        d->dct_calc(d, tab);
 +        d->dct_calc(d, (FFTSample *)tab);
          if (do_inverse) {
 -            idct_ref(tab_ref, tab1, fft_nbits);
 +            idct_ref((FFTSample*)tab_ref, (FFTSample *)tab1, fft_nbits);
          } else {
 -            dct_ref(tab_ref, tab1, fft_nbits);
 +            dct_ref((FFTSample*)tab_ref, (FFTSample *)tab1, fft_nbits);
          }
          err = check_diff((float *)tab_ref, (float *)tab, fft_size, 1.0);
          break;
+ #endif /* CONFIG_DCT */
  #endif
      }
  
      }
  
      switch (transform) {
+ #if CONFIG_MDCT
      case TRANSFORM_MDCT:
          ff_mdct_end(m);
          break;
+ #endif /* CONFIG_MDCT */
      case TRANSFORM_FFT:
          ff_fft_end(s);
          break;
  #if FFT_FLOAT
 -#if CONFIG_RDFT
++#    if CONFIG_RDFT
      case TRANSFORM_RDFT:
          ff_rdft_end(r);
          break;
 -#endif /* CONFIG_RDFT */
 -#if CONFIG_DCT
++#    endif /* CONFIG_RDFT */
 +#    if CONFIG_DCT
      case TRANSFORM_DCT:
          ff_dct_end(d);
          break;
- #    endif
 -#endif /* CONFIG_DCT */
++#    endif /* CONFIG_DCT */
  #endif
      }
  
diff --combined tests/fate/fft.mak
@@@ -1,8 -1,8 +1,8 @@@
  define DEF_FFT
- FATE_FFT += fate-fft-$(1)   fate-ifft-$(1)   \
-             fate-mdct-$(1)  fate-imdct-$(1)  \
-             fate-rdft-$(1)  fate-irdft-$(1)  \
            fate-dct1d-$(1) fate-idct1d-$(1)
+ FATE_FFT-$(CONFIG_DCT)  += fate-dct1d-$(1) fate-idct1d-$(1)
+ FATE_FFT-$(CONFIG_FFT)  += fate-fft-$(1)   fate-ifft-$(1)
+ FATE_FFT-$(CONFIG_MDCT) += fate-mdct-$(1)  fate-imdct-$(1)
FATE_FFT-$(CONFIG_RDFT) += fate-rdft-$(1)  fate-irdft-$(1)
  
  fate-fft-$(N):    ARGS = -n$(1)
  fate-ifft-$(N):   ARGS = -n$(1) -i
@@@ -16,14 -16,14 +16,14 @@@ ende
  
  $(foreach N, 4 5 6 7 8 9 10 11 12, $(eval $(call DEF_FFT,$(N))))
  
- fate-fft-test: $(FATE_FFT)
- $(FATE_FFT): libavcodec/fft-test$(EXESUF)
- $(FATE_FFT): CMD = run libavcodec/fft-test $(CPUFLAGS:%=-c%) $(ARGS)
- $(FATE_FFT): REF = /dev/null
+ fate-fft-float: $(FATE_FFT-yes)
+ $(FATE_FFT-yes): libavcodec/fft-test$(EXESUF)
+ $(FATE_FFT-yes): CMD = run libavcodec/fft-test $(CPUFLAGS:%=-c%) $(ARGS)
+ $(FATE_FFT-yes): REF = /dev/null
  
  define DEF_FFT_FIXED
- FATE_FFT_FIXED += fate-fft-fixed-$(1)   fate-ifft-fixed-$(1)  \
                  fate-mdct-fixed-$(1) fate-imdct-fixed-$(1)
+ FATE_FFT_FIXED-$(CONFIG_FFT)  += fate-fft-fixed-$(1)  fate-ifft-fixed-$(1)
FATE_FFT_FIXED-$(CONFIG_MDCT) += fate-mdct-fixed-$(1) fate-imdct-fixed-$(1)
  
  fate-fft-fixed-$(1):   ARGS = -n$(1)
  fate-ifft-fixed-$(1):  ARGS = -n$(1) -i
@@@ -33,27 -33,10 +33,27 @@@ ende
  
  $(foreach N, 4 5 6 7 8 9 10 11 12, $(eval $(call DEF_FFT_FIXED,$(N))))
  
- fate-fft-fixed-test: $(FATE_FFT_FIXED)
- $(FATE_FFT_FIXED): libavcodec/fft-fixed-test$(EXESUF)
- $(FATE_FFT_FIXED): CMD = run libavcodec/fft-fixed-test $(CPUFLAGS:%=-c%) $(ARGS)
- $(FATE_FFT_FIXED): REF = /dev/null
+ fate-fft-fixed: $(FATE_FFT_FIXED-yes)
+ $(FATE_FFT_FIXED-yes): libavcodec/fft-fixed-test$(EXESUF)
+ $(FATE_FFT_FIXED-yes): CMD = run libavcodec/fft-fixed-test $(CPUFLAGS:%=-c%) $(ARGS)
+ $(FATE_FFT_FIXED-yes): REF = /dev/null
  
 -FATE-$(CONFIG_AVCODEC) += $(FATE_FFT-yes) $(FATE_FFT_FIXED-yes)
 -fate-fft: $(FATE_FFT-yes) $(FATE_FFT_FIXED-yes)
 +define DEF_FFT_FIXED32
 +FATE_FFT_FIXED32 += fate-fft-fixed32-$(1)   fate-ifft-fixed32-$(1)  \
 +                  fate-mdct-fixed32-$(1) fate-imdct-fixed32-$(1)
 +
 +fate-fft-fixed32-$(1):   ARGS = -n$(1)
 +fate-ifft-fixed32-$(1):  ARGS = -n$(1) -i
 +#fate-mdct-fixed32-$(1):  ARGS = -n$(1) -m
 +fate-imdct-fixed32-$(1): ARGS = -n$(1) -m -i
 +endef
 +
 +$(foreach N, 4 5 6 7 8 9 10 11 12, $(eval $(call DEF_FFT_FIXED32,$(N))))
 +
 +fate-fft-fixed32-test: $(FATE_FFT_FIXED32)
 +$(FATE_FFT_FIXED32): libavcodec/fft-fixed32-test$(EXESUF)
 +$(FATE_FFT_FIXED32): CMD = run libavcodec/fft-fixed32-test $(CPUFLAGS:%=-c%) $(ARGS)
 +$(FATE_FFT_FIXED32): REF = /dev/null
 +
- FATE-$(call ALLYES, AVCODEC FFT MDCT) += $(FATE_FFT) $(FATE_FFT_FIXED) $(FATE_FFT_FIXED32)
- fate-fft: $(FATE_FFT) $(FATE_FFT_FIXED) $(FATE_FFT_FIXED32)
++FATE-$(call ALLYES, AVCODEC FFT MDCT) += $(FATE_FFT-yes) $(FATE_FFT_FIXED-yes) $(FATE_FFT_FIXED32)
++fate-fft: $(FATE_FFT-yes) $(FATE_FFT_FIXED-yes) $(FATE_FFT_FIXED32)