Merge remote-tracking branch 'qatar/master'
authorMichael Niedermayer <michaelni@gmx.at>
Wed, 28 Mar 2012 02:12:24 +0000 (04:12 +0200)
committerMichael Niedermayer <michaelni@gmx.at>
Wed, 28 Mar 2012 02:12:24 +0000 (04:12 +0200)
* qatar/master:
  westwood_vqa: fix SND0 chunk handling
  westwood_vqa: set video stream duration
  raw: forward avpicture_fill() error code in raw_decode().
  build: Do not explicitly add the doc directory to the OBJDIRS list.
  dv: Split off DV video decoder into its own file.
  build: fix RALF decoder standalone compilation, which depends on Golomb code
  configure: Drop stray duplicate entry for --disable-fft from help output.

Conflicts:
libavcodec/dv.c
libavcodec/rawdec.c
libavformat/westwood_vqa.c

Merged-by: Michael Niedermayer <michaelni@gmx.at>
1  2 
configure
doc/Makefile
libavcodec/Makefile
libavcodec/dv.c
libavcodec/dv_tablegen.h
libavcodec/dvdata.h
libavcodec/dvdec.c
libavcodec/rawdec.c

diff --combined configure
+++ b/configure
@@@ -1,6 -1,6 +1,6 @@@
  #!/bin/sh
  #
 -# Libav configure script
 +# FFmpeg configure script
  #
  # Copyright (c) 2000-2002 Fabrice Bellard
  # Copyright (c) 2005-2008 Diego Biurrun
@@@ -44,9 -44,9 +44,9 @@@ if test "$E1" != 0 || test "$E2" = 0; t
      echo "No compatible shell script interpreter found."
      echo "This configure script requires a POSIX-compatible shell"
      echo "such as bash or ksh."
 -    echo "THIS IS NOT A BUG IN LIBAV, DO NOT REPORT IT AS SUCH."
 +    echo "THIS IS NOT A BUG IN FFMPEG, DO NOT REPORT IT AS SUCH."
      echo "Instead, install a working POSIX-compatible shell."
 -    echo "Disabling this configure test will create a broken Libav."
 +    echo "Disabling this configure test will create a broken FFmpeg."
      if test "$BASH_VERSION" = '2.04.0(1)-release'; then
          echo "This bash version ($BASH_VERSION) is broken on your platform."
          echo "Upgrade to a later version if available."
@@@ -78,7 -78,7 +78,7 @@@ Standard options
    --disable-logging        do not log configure debug information
    --prefix=PREFIX          install in PREFIX [$prefix]
    --bindir=DIR             install binaries in DIR [PREFIX/bin]
 -  --datadir=DIR            install data files in DIR [PREFIX/share/avconv]
 +  --datadir=DIR            install data files in DIR [PREFIX/share/ffmpeg]
    --libdir=DIR             install libs in DIR [PREFIX/lib]
    --shlibdir=DIR           install shared libs in DIR [PREFIX/lib]
    --incdir=DIR             install includes in DIR [PREFIX/include]
@@@ -101,31 -101,27 +101,30 @@@ Configuration options
  
  Component options:
    --disable-doc            do not build documentation
 -  --disable-avconv         disable avconv build
 -  --disable-avplay         disable avplay build
 -  --disable-avprobe        disable avprobe build
 -  --disable-avserver       disable avserver build
 +  --disable-ffmpeg         disable ffmpeg build
 +  --disable-ffplay         disable ffplay build
 +  --disable-ffprobe        disable ffprobe build
 +  --disable-ffserver       disable ffserver build
    --disable-avdevice       disable libavdevice build
    --disable-avcodec        disable libavcodec build
    --disable-avformat       disable libavformat build
 +  --disable-swresample     disable libswresample build
    --disable-swscale        disable libswscale build
 +  --disable-postproc       disable libpostproc build
    --disable-avfilter       disable video filter support [no]
    --disable-pthreads       disable pthreads [auto]
    --disable-w32threads     disable Win32 threads [auto]
 +  --disable-os2threads     disable OS/2 threads [auto]
    --enable-x11grab         enable X11 grabbing [no]
    --disable-network        disable network support [no]
    --disable-dct            disable DCT code
-   --disable-fft            disable FFT code
    --disable-mdct           disable MDCT code
    --disable-rdft           disable RDFT code
    --disable-fft            disable FFT code
    --enable-dxva2           enable DXVA2 code
 -  --enable-vaapi           enable VAAPI code
 -  --enable-vda             enable VDA code
 -  --enable-vdpau           enable VDPAU code
 +  --enable-vaapi           enable VAAPI code [autodetect]
 +  --enable-vda             enable VDA code   [autodetect]
 +  --enable-vdpau           enable VDPAU code [autodetect]
  
  Individual component options:
    --disable-everything     disable all components listed below
@@@ -169,10 -165,6 +168,10 @@@ External library support
    --enable-bzlib           enable bzlib [autodetect]
    --enable-frei0r          enable frei0r video filtering
    --enable-gnutls          enable gnutls [no]
 +  --enable-libaacplus      enable AAC+ encoding via libaacplus [no]
 +  --enable-libass          enable libass subtitles rendering [no]
 +  --enable-libbluray       enable BluRay reading using libbluray [no]
 +  --enable-libcelt         enable CELT decoding via libcelt [no]
    --enable-libopencore-amrnb enable AMR-NB de/encoding via libopencore-amrnb [no]
    --enable-libopencore-amrwb enable AMR-WB decoding via libopencore-amrwb [no]
    --enable-libopencv       enable video filtering via libopencv [no]
    --enable-libfaac         enable FAAC support via libfaac [no]
    --enable-libfreetype     enable libfreetype [no]
    --enable-libgsm          enable GSM support via libgsm [no]
 +  --enable-libmodplug      enable ModPlug via libmodplug [no]
    --enable-libmp3lame      enable MP3 encoding via libmp3lame [no]
    --enable-libnut          enable NUT (de)muxing via libnut,
                             native (de)muxer exists [no]
 -  --enable-libopenjpeg     enable JPEG 2000 decoding via OpenJPEG [no]
 +  --enable-libopenjpeg     enable JPEG 2000 encoding/decoding via OpenJPEG [no]
    --enable-libpulse        enable Pulseaudio input via libpulse [no]
    --enable-librtmp         enable RTMP[E] support via librtmp [no]
    --enable-libschroedinger enable Dirac support via libschroedinger [no]
    --enable-libspeex        enable Speex support via libspeex [no]
 +  --enable-libstagefright-h264  enable H.264 decoding via libstagefright [no]
    --enable-libtheora       enable Theora encoding via libtheora [no]
 +  --enable-libutvideo      enable Ut Video encoding and decoding via libutvideo [no]
 +  --enable-libv4l2         enable libv4l2/v4l-utils [no]
    --enable-libvo-aacenc    enable AAC encoding via libvo-aacenc [no]
    --enable-libvo-amrwbenc  enable AMR-WB encoding via libvo-amrwbenc [no]
    --enable-libvorbis       enable Vorbis encoding via libvorbis,
    --enable-libxavs         enable AVS encoding via xavs [no]
    --enable-libxvid         enable Xvid encoding via xvidcore,
                             native MPEG-4/Xvid encoder exists [no]
 +  --enable-openal          enable OpenAL 1.1 capture support [no]
    --enable-openssl         enable openssl [no]
    --enable-zlib            enable zlib [autodetect]
  
@@@ -217,26 -204,22 +216,26 @@@ Advanced options (experts only)
    --target-os=OS           compiler targets OS [$target_os]
    --target-exec=CMD        command to run executables on target
    --target-path=DIR        path to view of build directory on target
 -  --nm=NM                  use nm tool
 +  --nm=NM                  use nm tool NM [$nm_default]
    --ar=AR                  use archive tool AR [$ar_default]
    --as=AS                  use assembler AS [$as_default]
 +  --yasmexe=EXE            use yasm-compatible assembler EXE [$yasmexe_default]
    --cc=CC                  use C compiler CC [$cc_default]
 -  --ld=LD                  use linker LD
 +  --cxx=CXX                use C compiler CXX [$cxx_default]
 +  --ld=LD                  use linker LD [$ld_default]
    --host-cc=HOSTCC         use host C compiler HOSTCC
    --host-cflags=HCFLAGS    use HCFLAGS when compiling for host
    --host-ldflags=HLDFLAGS  use HLDFLAGS when linking for host
    --host-libs=HLIBS        use libs HLIBS when linking for host
    --extra-cflags=ECFLAGS   add ECFLAGS to CFLAGS [$CFLAGS]
 +  --extra-cxxflags=ECFLAGS add ECFLAGS to CXXFLAGS [$CXXFLAGS]
    --extra-ldflags=ELDFLAGS add ELDFLAGS to LDFLAGS [$LDFLAGS]
    --extra-libs=ELIBS       add ELIBS [$ELIBS]
    --extra-version=STRING   version string suffix []
    --optflags               override optimization-related compiler flags
    --build-suffix=SUFFIX    library name suffix []
    --malloc-prefix=PREFIX   prefix malloc and related names with PREFIX
 +  --progs-suffix=SUFFIX    program name suffix []
    --arch=ARCH              select architecture [$arch]
    --cpu=CPU                select the minimum required CPU (affects
                             instruction selection, may crash on older CPUs)
@@@ -268,19 -251,12 +267,19 @@@ Optimization options (experts only)
    --disable-neon           disable NEON optimizations
    --disable-vis            disable VIS optimizations
    --disable-yasm           disable use of yasm assembler
 +  --postproc-version=V     build libpostproc version V.
 +                           Where V can be '$ALT_PP_VER_MAJOR.$ALT_PP_VER_MINOR.$ALT_PP_VER_MICRO' or 'current'. [$postproc_version_default]
  
 -Developer options (useful when working on Libav itself):
 +Developer options (useful when working on FFmpeg itself):
 +  --enable-coverage        build with test coverage instrumentation
    --disable-debug          disable debugging symbols
    --enable-debug=LEVEL     set the debug level [$debuglevel]
    --disable-optimizations  disable compiler optimizations
    --enable-extra-warnings  enable more compiler warnings
 +  --disable-stripping      disable stripping of executables and shared libraries
 +  --valgrind=VALGRIND      run "make fate" tests through valgrind to detect memory
 +                           leaks and errors, using the specified valgrind binary.
 +                           Cannot be combined with --target-exec
    --samples=PATH           location of test samples for FATE, if not set use
                             \$FATE_SAMPLES at make invocation time.
    --enable-xmm-clobber-test check XMM registers for clobbering (Win64-only;
@@@ -319,7 -295,7 +318,7 @@@ die()
  
  If you think configure made a mistake, make sure you are using the latest
  version from Git.  If the latest version fails, report the problem to the
 -libav-user@libav.org mailing list or IRC #libav on irc.freenode.net.
 +ffmpeg-user@ffmpeg.org mailing list or IRC #ffmpeg on irc.freenode.net.
  EOF
      if disabled logging; then
          cat <<EOF
@@@ -617,10 -593,6 +616,10 @@@ add_cflags()
      append CFLAGS $($filter_cflags "$@")
  }
  
 +add_cxxflags(){
 +    append CXXFLAGS $($filter_cflags "$@")
 +}
 +
  add_asflags(){
      append ASFLAGS $($filter_asflags "$@")
  }
@@@ -645,13 -617,6 +644,13 @@@ check_cc()
      check_cmd $cc $CPPFLAGS $CFLAGS "$@" -c -o $TMPO $TMPC
  }
  
 +check_cxx(){
 +    log check_cxx "$@"
 +    cat > $TMPCPP
 +    log_file $TMPCPP
 +    check_cmd $cxx $CPPFLAGS $CFLAGS $CXXFLAGS "$@" -c -o $TMPO $TMPCPP
 +}
 +
  check_cpp(){
      log check_cpp "$@"
      cat > $TMPC
@@@ -687,14 -652,12 +686,14 @@@ check_yasm()
  
  check_ld(){
      log check_ld "$@"
 +    type=$1
 +    shift 1
      flags=''
      libs=''
      for f; do
          test "${f}" = "${f#-l}" && flags="$flags $f" || libs="$libs $f"
      done
 -    check_cc $($filter_cflags $flags) || return
 +    check_$type $($filter_cflags $flags) || return
      check_cmd $ld $LDFLAGS $flags -o $TMPE $TMPO $libs $extralibs
  }
  
@@@ -714,17 -677,9 +713,17 @@@ int x
  EOF
  }
  
 +check_cxxflags(){
 +    log check_cxxflags "$@"
 +    set -- $($filter_cflags "$@")
 +    check_cxx "$@" <<EOF && append CXXFLAGS "$@"
 +int x;
 +EOF
 +}
 +
  test_ldflags(){
      log test_ldflags "$@"
 -    check_ld "$@" <<EOF
 +    check_ld "cc" "$@" <<EOF
  int main(void){ return 0; }
  EOF
  }
@@@ -750,7 -705,7 +749,7 @@@ check_func()
      func=$1
      shift
      disable $func
 -    check_ld "$@" <<EOF && enable $func
 +    check_ld "cc" "$@" <<EOF && enable $func
  extern int $func();
  int main(void){ $func(); }
  EOF
@@@ -761,10 -716,10 +760,10 @@@ check_mathfunc()
      func=$1
      shift
      disable $func
 -    check_ld "$@" <<EOF && enable $func
 +    check_ld "cc" "$@" <<EOF && enable $func
  #include <math.h>
  float foo(float f) { return $func(f); }
 -int main(void){ return 0; }
 +int main(void){ return (int) foo; }
  EOF
  }
  
@@@ -781,26 -736,7 +780,26 @@@ check_func_headers()
              echo "long check_$func(void) { return (long) $func; }"
          done
          echo "int main(void) { return 0; }"
 -    } | check_ld "$@" && enable $funcs && enable_safe $headers
 +    } | check_ld "cc" "$@" && enable $funcs && enable_safe $headers
 +}
 +
 +check_class_headers_cpp(){
 +    log check_class_headers_cpp "$@"
 +    headers=$1
 +    classes=$2
 +    shift 2
 +    {
 +        for hdr in $headers; do
 +            echo "#include <$hdr>"
 +        done
 +        echo "int main(void) { "
 +        i=1
 +        for class in $classes; do
 +            echo "$class obj$i;"
 +            i=$(expr $i + 1)
 +        done
 +        echo "return 0; }"
 +    } | check_ld "cxx" "$@" && enable $funcs && enable_safe $headers
  }
  
  check_cpp_condition(){
@@@ -832,21 -768,13 +831,21 @@@ check_lib2()
      check_func_headers "$headers" "$funcs" "$@" && add_extralibs "$@"
  }
  
 +check_lib_cpp(){
 +    log check_lib_cpp "$@"
 +    headers="$1"
 +    classes="$2"
 +    shift 2
 +    check_class_headers_cpp "$headers" "$classes" "$@" && add_extralibs "$@"
 +}
 +
  check_pkg_config(){
      log check_pkg_config "$@"
      pkg="$1"
      headers="$2"
      funcs="$3"
      shift 3
 -    $pkg_config --exists $pkg || return
 +    $pkg_config --exists $pkg 2>/dev/null || return
      pkg_cflags=$($pkg_config --cflags $pkg)
      pkg_libs=$($pkg_config --libs $pkg)
      check_func_headers "$headers" "$funcs" $pkg_cflags $pkg_libs "$@" &&
  }
  
  check_exec(){
 -    check_ld "$@" && { enabled cross_compile || $TMPE >> $logfile 2>&1; }
 +    check_ld "cc" "$@" && { enabled cross_compile || $TMPE >> $logfile 2>&1; }
  }
  
  check_exec_crash(){
  static void sighandler(int sig){
      raise(SIGTERM);
  }
 +int func(void){
 +    $code
 +}
 +int (*func_ptr)(void) = func;
  int main(void){
      signal(SIGILL, sighandler);
      signal(SIGFPE, sighandler);
  #ifdef SIGBUS
      signal(SIGBUS, sighandler);
  #endif
 -    { $code }
 +    return func_ptr();
  }
  EOF
  }
@@@ -939,14 -863,6 +938,14 @@@ require2()
      check_lib2 "$headers" $func "$@" || die "ERROR: $name not found"
  }
  
 +require_cpp(){
 +    name="$1"
 +    headers="$2"
 +    classes="$3"
 +    shift 3
 +    check_lib_cpp "$headers" "$classes" "$@" || die "ERROR: $name not found"
 +}
 +
  require_pkg_config(){
      pkg="$1"
      check_pkg_config "$@" || die "ERROR: $pkg not found"
@@@ -998,10 -914,10 +997,10 @@@ COMPONENT_LIST=
  "
  
  PROGRAM_LIST="
 -    avconv
 -    avplay
 -    avprobe
 -    avserver
 +    ffplay
 +    ffprobe
 +    ffserver
 +    ffmpeg
  "
  
  CONFIG_LIST="
      avformat
      avisynth
      bzlib
 +    crystalhd
      dct
      doc
      dwt
      gpl
      gray
      hardcoded_tables
 +    libaacplus
 +    libass
 +    libbluray
      libcdio
 +    libcelt
      libdc1394
      libdirac
      libfaac
      libfreetype
      libgsm
 +    libmodplug
      libmp3lame
      libnut
      libopencore_amrnb
      librtmp
      libschroedinger
      libspeex
 +    libstagefright_h264
      libtheora
 +    libutvideo
 +    libv4l2
      libvo_aacenc
      libvo_amrwbenc
      libvorbis
      mpegaudiodsp
      network
      nonfree
 +    openal
      openssl
      pic
 +    postproc
      rdft
      rtpdec
      runtime_cpudetect
      small
      sram
      static
 +    swresample
      swscale
      swscale_alpha
      thumb
  THREADS_LIST='
      pthreads
      w32threads
 +    os2threads
  '
  
  ARCH_LIST='
@@@ -1154,10 -1057,8 +1153,10 @@@ HAVE_LIST=
      altivec_h
      arpa_inet_h
      asm_mod_y
 +    asm_types_h
      attribute_may_alias
      attribute_packed
 +    cbrtf
      closesocket
      cmov
      dcbzl
      inet_aton
      inline_asm
      isatty
 +    kbhit
      ldbrx
      libdc1394_1
      libdc1394_2
      loongson
      lrint
      lrintf
 +    lzo1x_999_compress
      machine_ioctl_bt848_h
      machine_ioctl_meteor_h
 +    makeinfo
      malloc_h
      MapViewOfFile
      memalign
      mkstemp
      mmap
 +    PeekNamedPipe
      poll_h
      posix_memalign
      round
      soundcard_h
      strerror_r
      strptime
 -    strtok_r
      struct_addrinfo
      struct_ipv6_mreq
      struct_rusage_ru_maxrss
      sys_select_h
      sys_soundcard_h
      sys_videoio_h
 +    termios_h
      threads
      trunc
      truncf
@@@ -1277,13 -1174,11 +1276,13 @@@ CMDLINE_SELECT=
      $CONFIG_LIST
      $THREADS_LIST
      asm
 +    coverage
      cross_compile
      debug
      extra_warnings
      logging
      optimizations
 +    stripping
      symver
      yasm
  "
@@@ -1307,7 -1202,6 +1306,7 @@@ CMDLINE_SET=
      cc
      cpu
      cross_prefix
 +    cxx
      dep_cc
      extra_version
      host_cc
      host_ldflags
      host_libs
      host_os
 +    install
      ld
      logfile
      malloc_prefix
      nm
      optflags
      pkg_config
 +    postproc_version
 +    progs_suffix
      samples
 +    strip
      sysinclude
      sysroot
      target_exec
      target_os
      target_path
 +    valgrind
 +    yasmexe
  "
  
  CMDLINE_APPEND="
      extra_cflags
 +    extra_cxxflags
  "
  
  # code dependency declarations
@@@ -1413,7 -1300,6 +1412,7 @@@ flac_decoder_select="golomb
  flac_encoder_select="golomb lpc"
  flashsv_decoder_select="zlib"
  flashsv_encoder_select="zlib"
 +flashsv2_encoder_select="zlib"
  flashsv2_decoder_select="zlib"
  flv_decoder_select="h263_decoder"
  flv_encoder_select="h263_encoder"
@@@ -1424,12 -1310,10 +1423,12 @@@ h263_encoder_select="aandct
  h263_vaapi_hwaccel_select="vaapi h263_decoder"
  h263i_decoder_select="h263_decoder"
  h263p_encoder_select="h263_encoder"
 +h264_crystalhd_decoder_select="crystalhd h264_mp4toannexb_bsf h264_parser"
  h264_decoder_select="golomb h264chroma h264dsp h264pred h264qpel"
  h264_dxva2_hwaccel_deps="dxva2api_h"
  h264_dxva2_hwaccel_select="dxva2 h264_decoder"
  h264_vaapi_hwaccel_select="vaapi h264_decoder"
 +h264_vda_hwaccel_deps="VideoDecodeAcceleration_VDADecoder_h pthreads"
  h264_vda_hwaccel_select="vda h264_decoder"
  h264_vdpau_decoder_select="vdpau h264_decoder"
  imc_decoder_select="fft mdct sinewin"
@@@ -1455,20 -1339,15 +1454,20 @@@ mpeg_vdpau_decoder_select="vdpau mpegvi
  mpeg_xvmc_decoder_deps="X11_extensions_XvMClib_h"
  mpeg_xvmc_decoder_select="mpegvideo_decoder"
  mpeg1_vdpau_decoder_select="vdpau mpeg1video_decoder"
 +mpeg1_vdpau_hwaccel_select="vdpau mpeg1video_decoder"
  mpeg1video_encoder_select="aandct"
 +mpeg2_crystalhd_decoder_select="crystalhd"
  mpeg2_dxva2_hwaccel_deps="dxva2api_h"
  mpeg2_dxva2_hwaccel_select="dxva2 mpeg2video_decoder"
 +mpeg2_vdpau_hwaccel_select="vdpau mpeg2video_decoder"
  mpeg2_vaapi_hwaccel_select="vaapi mpeg2video_decoder"
  mpeg2video_encoder_select="aandct"
 +mpeg4_crystalhd_decoder_select="crystalhd"
  mpeg4_decoder_select="h263_decoder mpeg4video_parser"
  mpeg4_encoder_select="h263_encoder"
  mpeg4_vaapi_hwaccel_select="vaapi mpeg4_decoder"
  mpeg4_vdpau_decoder_select="vdpau mpeg4_decoder"
 +msmpeg4_crystalhd_decoder_select="crystalhd"
  msmpeg4v1_decoder_select="h263_decoder"
  msmpeg4v1_encoder_select="h263_encoder"
  msmpeg4v2_decoder_select="h263_decoder"
@@@ -1482,6 -1361,7 +1481,7 @@@ png_encoder_select="zlib
  qcelp_decoder_select="lsp"
  qdm2_decoder_select="mdct rdft mpegaudiodsp"
  ra_144_encoder_select="lpc"
+ ralf_decoder_select="golomb"
  rv10_decoder_select="h263_decoder"
  rv10_encoder_select="h263_encoder"
  rv20_decoder_select="h263_decoder"
@@@ -1492,9 -1372,6 +1492,9 @@@ shorten_decoder_select="golomb
  sipr_decoder_select="lsp"
  snow_decoder_select="dwt"
  snow_encoder_select="aandct dwt"
 +sonic_decoder_select="golomb"
 +sonic_encoder_select="golomb"
 +sonic_ls_encoder_select="golomb"
  svq1_encoder_select="aandct"
  svq3_decoder_select="golomb h264chroma h264dsp h264pred h264qpel"
  svq3_decoder_suggest="zlib"
@@@ -1504,7 -1381,6 +1504,7 @@@ tiff_encoder_suggest="zlib
  truehd_decoder_select="mlp_decoder"
  tscc_decoder_select="zlib"
  twinvq_decoder_select="mdct lsp sinewin"
 +vc1_crystalhd_decoder_select="crystalhd"
  vc1_decoder_select="h263_decoder h264chroma h264qpel"
  vc1_dxva2_hwaccel_deps="dxva2api_h"
  vc1_dxva2_hwaccel_select="dxva2 vc1_decoder"
@@@ -1528,7 -1404,6 +1528,7 @@@ wmv1_encoder_select="h263_encoder
  wmv2_decoder_select="h263_decoder"
  wmv2_encoder_select="h263_encoder"
  wmv3_decoder_select="vc1_decoder"
 +wmv3_crystalhd_decoder_select="crystalhd"
  wmv3_dxva2_hwaccel_select="vc1_dxva2_hwaccel"
  wmv3_vaapi_hwaccel_select="vc1_vaapi_hwaccel"
  wmv3_vdpau_decoder_select="vc1_vdpau_decoder"
@@@ -1539,7 -1414,6 +1539,7 @@@ zlib_encoder_select="zlib
  zmbv_decoder_select="zlib"
  zmbv_encoder_select="zlib"
  
 +crystalhd_deps="libcrystalhd_libcrystalhd_if_h"
  vaapi_deps="va_va_h"
  vda_deps="VideoDecodeAcceleration_VDADecoder_h pthreads"
  vdpau_deps="vdpau_vdpau_h vdpau_vdpau_x11_h"
  h264_parser_select="golomb h264dsp h264pred"
  
  # external libraries
 +libaacplus_encoder_deps="libaacplus"
 +libcelt_decoder_deps="libcelt"
  libdirac_decoder_deps="libdirac !libschroedinger"
  libfaac_encoder_deps="libfaac"
  libgsm_decoder_deps="libgsm"
  libgsm_encoder_deps="libgsm"
  libgsm_ms_decoder_deps="libgsm"
  libgsm_ms_encoder_deps="libgsm"
 +libmodplug_demuxer_deps="libmodplug"
  libmp3lame_encoder_deps="libmp3lame"
  libopencore_amrnb_decoder_deps="libopencore_amrnb"
  libopencore_amrnb_encoder_deps="libopencore_amrnb"
  libopencore_amrwb_decoder_deps="libopencore_amrwb"
  libopenjpeg_decoder_deps="libopenjpeg"
 +libopenjpeg_encoder_deps="libopenjpeg"
  libschroedinger_decoder_deps="libschroedinger"
  libschroedinger_encoder_deps="libschroedinger"
  libspeex_decoder_deps="libspeex"
  libspeex_encoder_deps="libspeex"
 +libstagefright_h264_decoder_deps="libstagefright_h264"
  libtheora_encoder_deps="libtheora"
  libvo_aacenc_encoder_deps="libvo_aacenc"
  libvo_amrwbenc_encoder_deps="libvo_amrwbenc"
@@@ -1575,11 -1444,8 +1575,11 @@@ libvorbis_encoder_deps="libvorbis
  libvpx_decoder_deps="libvpx"
  libvpx_encoder_deps="libvpx"
  libx264_encoder_deps="libx264"
 +libx264rgb_encoder_deps="libx264"
  libxavs_encoder_deps="libxavs"
  libxvid_encoder_deps="libxvid"
 +libutvideo_decoder_deps="libutvideo"
 +libutvideo_encoder_deps="libutvideo"
  
  # demuxers / muxers
  ac3_demuxer_select="ac3_parser"
@@@ -1616,30 -1482,22 +1616,30 @@@ w64_demuxer_deps="wav_demuxer
  alsa_indev_deps="alsa_asoundlib_h snd_pcm_htimestamp"
  alsa_outdev_deps="alsa_asoundlib_h"
  bktr_indev_deps_any="dev_bktr_ioctl_bt848_h machine_ioctl_bt848_h dev_video_bktr_ioctl_bt848_h dev_ic_bt8xx_h"
 +dshow_indev_deps="IBaseFilter"
 +dshow_indev_extralibs="-lpsapi -lole32 -lstrmiids -luuid"
  dv1394_indev_deps="dv1394 dv_demuxer"
  fbdev_indev_deps="linux_fb_h"
 -jack_indev_deps="jack_jack_h"
 +jack_indev_deps="jack_jack_h sem_timedwait"
 +lavfi_indev_deps="avfilter"
  libcdio_indev_deps="libcdio"
  libdc1394_indev_deps="libdc1394"
 +libv4l2_indev_deps="libv4l2"
 +openal_indev_deps="openal"
  oss_indev_deps_any="soundcard_h sys_soundcard_h"
  oss_outdev_deps_any="soundcard_h sys_soundcard_h"
  pulse_indev_deps="libpulse"
 +sdl_outdev_deps="sdl"
  sndio_indev_deps="sndio_h"
  sndio_outdev_deps="sndio_h"
 +v4l_indev_deps="linux_videodev_h"
  v4l2_indev_deps_any="linux_videodev2_h sys_videoio_h"
  vfwcap_indev_deps="capCreateCaptureWindow vfwcap_defines"
  vfwcap_indev_extralibs="-lavicap32"
  x11_grab_device_indev_deps="x11grab XShmCreateImage"
  
  # protocols
 +bluray_protocol_deps="libbluray"
  gopher_protocol_deps="network"
  httpproxy_protocol_deps="network"
  httpproxy_protocol_select="tcp_protocol"
@@@ -1662,41 -1520,29 +1662,41 @@@ tls_protocol_select="tcp_protocol
  udp_protocol_deps="network"
  
  # filters
 +aconvert_filter_deps="swresample"
 +amovie_filter_deps="avcodec avformat"
 +aresample_filter_deps="swresample"
 +ass_filter_deps="libass"
  blackframe_filter_deps="gpl"
  boxblur_filter_deps="gpl"
  cropdetect_filter_deps="gpl"
  delogo_filter_deps="gpl"
  drawtext_filter_deps="libfreetype"
 -frei0r_filter_deps="frei0r dlopen strtok_r"
 -frei0r_src_filter_deps="frei0r dlopen strtok_r"
 +frei0r_filter_deps="frei0r dlopen"
 +frei0r_src_filter_deps="frei0r dlopen"
  hqdn3d_filter_deps="gpl"
 +movie_filter_deps="avcodec avformat"
 +mp_filter_deps="gpl avcodec swscale postproc"
 +mptestsrc_filter_deps="gpl"
 +negate_filter_deps="lut_filter"
  ocv_filter_deps="libopencv"
 +pan_filter_deps="swresample"
  scale_filter_deps="swscale"
 +tinterlace_filter_deps="gpl"
  yadif_filter_deps="gpl"
  
  # libraries
  avdevice_deps="avcodec avformat"
  avformat_deps="avcodec"
 +postproc_deps="gpl"
  
  # programs
 -avconv_deps="avcodec avformat swscale"
 -avplay_deps="avcodec avformat swscale sdl"
 -avplay_select="rdft"
 -avprobe_deps="avcodec avformat"
 -avserver_deps="avformat ffm_muxer fork rtp_protocol rtsp_demuxer !shared"
 -avserver_extralibs='$ldl'
 +ffplay_deps="avcodec avformat swscale swresample sdl"
 +ffplay_select="buffersink_filter rdft"
 +ffprobe_deps="avcodec avformat"
 +ffserver_deps="avformat ffm_muxer fork rtp_protocol rtsp_demuxer"
 +ffserver_extralibs='$ldl'
 +ffmpeg_deps="avcodec avformat swscale swresample"
 +ffmpeg_select="buffersink_filter"
  
  doc_deps="texi2html"
  
@@@ -1780,11 -1626,11 +1780,11 @@@ test_deps _muxer _demuxe
      gxf                                                                 \
      matroska=mkv                                                        \
      mmf                                                                 \
 -    mov                                                                 \
 +    mov="mov ismv"                                                      \
      pcm_mulaw=mulaw                                                     \
      mxf="mxf mxf_d10"                                                   \
      nut                                                                 \
 -    ogg                                                                 \
 +    ogg="ogg ogg_vp3"                                                   \
      rawvideo=pixfmt                                                     \
      rm                                                                  \
      swf                                                                 \
      yuv4mpegpipe=yuv4mpeg                                               \
  
  ac3_fixed_test_deps="ac3_fixed_encoder ac3_decoder"
 +flashsv2_test_deps="zlib"
  mpg_test_deps="mpeg1system_muxer mpegps_demuxer"
 +mpng_test_deps="zlib"
 +pp_test_deps="mp_filter"
 +pp2_test_deps="mp_filter"
 +pp3_test_deps="mp_filter"
 +pp4_test_deps="mp_filter"
 +pp5_test_deps="mp_filter"
 +pp6_test_deps="mp_filter"
 +zlib_test_deps="zlib"
 +zmbv_test_deps="zlib"
  
  # default parameters
  
@@@ -1813,27 -1649,23 +1813,27 @@@ logfile="config.log
  # installation paths
  prefix_default="/usr/local"
  bindir_default='${prefix}/bin'
 -datadir_default='${prefix}/share/avconv'
 +datadir_default='${prefix}/share/ffmpeg'
  incdir_default='${prefix}/include'
  libdir_default='${prefix}/lib'
  mandir_default='${prefix}/share/man'
  shlibdir_default="$libdir_default"
 +postproc_version_default="current"
  
  # toolchain
  ar_default="ar"
  cc_default="gcc"
 +cxx_default="g++"
  cc_version=\"unknown\"
  host_cc_default="gcc"
 +install="install"
  ln_s="ln -sf"
  nm_default="nm"
  objformat="elf"
  pkg_config_default=pkg-config
  ranlib="ranlib"
 -yasmexe="yasm"
 +strip_default="strip"
 +yasmexe_default="yasm"
  
  nm_opts='-g'
  nogas=":"
@@@ -1846,12 -1678,6 +1846,12 @@@ cpu="generic
  target_os_default=$(tolower $(uname -s))
  host_os=$target_os_default
  
 +# alternative libpostproc version
 +ALT_PP_VER_MAJOR=51
 +ALT_PP_VER_MINOR=2
 +ALT_PP_VER_MICRO=101
 +ALT_PP_VER=$ALT_PP_VER_MAJOR.$ALT_PP_VER_MINOR.$ALT_PP_VER_MICRO
 +
  # configurable options
  enable $PROGRAM_LIST
  
@@@ -1860,9 -1686,6 +1860,9 @@@ enable avdevic
  enable avfilter
  enable avformat
  enable avutil
 +enable postproc
 +enable stripping
 +enable swresample
  enable swscale
  
  enable asm
@@@ -1877,7 -1700,7 +1877,7 @@@ enable swscale_alph
  
  # build settings
  SHFLAGS='-shared -Wl,-soname,$$(@F)'
 -AVSERVERLDFLAGS=-Wl,-E
 +FFSERVERLDFLAGS=-Wl,-E
  LIBPREF="lib"
  LIBSUF=".a"
  FULLNAME='$(NAME)$(BUILDSUF)'
@@@ -1893,7 -1716,6 +1893,7 @@@ SLIB_INSTALL_LINKS='$(SLIBNAME_WITH_MAJ
  
  AS_O='-o $@'
  CC_O='-o $@'
 +CXX_O='-o $@'
  
  host_cflags='-D_ISOC99_SOURCE -O3 -g'
  host_libs='-lm'
@@@ -1920,7 -1742,7 +1920,7 @@@ for v in "$@"; d
      r=${v#*=}
      l=${v%"$r"}
      r=$(sh_quote "$r")
 -    LIBAV_CONFIGURATION="${LIBAV_CONFIGURATION# } ${l}${r}"
 +    FFMPEG_CONFIGURATION="${FFMPEG_CONFIGURATION# } ${l}${r}"
  done
  
  find_things(){
@@@ -1962,12 -1784,11 +1962,12 @@@ find_tests()
  
  ACODEC_TESTS=$(find_tests acodec)
  VCODEC_TESTS=$(find_tests vsynth1)
 +LAVF_FATE_TESTS=$(find_tests lavf-fate)
  LAVF_TESTS=$(find_tests lavf)
  LAVFI_TESTS=$(find_tests lavfi)
  SEEK_TESTS=$(find_tests seek seek_)
  
 -ALL_TESTS="$ACODEC_TESTS $VCODEC_TESTS $LAVF_TESTS $LAVFI_TESTS $SEEK_TESTS"
 +ALL_TESTS="$ACODEC_TESTS $VCODEC_TESTS $LAVF_FATE_TESTS $LAVF_TESTS $LAVFI_TESTS $SEEK_TESTS"
  
  pcm_test_deps=$(map 'echo ${v%_*}_decoder $v' $(filter pcm_* $ENCODER_LIST))
  
@@@ -2049,7 -1870,7 +2049,7 @@@ don
  
  disabled logging && logfile=/dev/null
  
 -echo "# $0 $LIBAV_CONFIGURATION" > $logfile
 +echo "# $0 $FFMPEG_CONFIGURATION" > $logfile
  set >> $logfile
  
  test -n "$cross_prefix" && enable cross_compile
@@@ -2059,29 -1880,17 +2059,29 @@@ if enabled cross_compile; the
          die "Must specify target arch and OS when cross-compiling"
  fi
  
 -set_default arch target_os
 +set_default arch target_os postproc_version
 +
 +# Check if we should build alternative libpostproc version instead of current
 +if   test "$postproc_version" = $ALT_PP_VER; then
 +  LIBPOSTPROC_VERSION=$ALT_PP_VER
 +  LIBPOSTPROC_VERSION_MAJOR=$ALT_PP_VER_MAJOR
 +  LIBPOSTPROC_VERSION_MINOR=$ALT_PP_VER_MINOR
 +  LIBPOSTPROC_VERSION_MICRO=$ALT_PP_VER_MICRO
 +elif test "$postproc_version" != current; then
 +  die "Invalid argument to --postproc-version. See --help output."
 +fi
  
  ar_default="${cross_prefix}${ar_default}"
  cc_default="${cross_prefix}${cc_default}"
 +cxx_default="${cross_prefix}${cxx_default}"
  nm_default="${cross_prefix}${nm_default}"
  pkg_config_default="${cross_prefix}${pkg_config_default}"
  ranlib="${cross_prefix}${ranlib}"
 +strip_default="${cross_prefix}${strip_default}"
  
  sysinclude_default="${sysroot}/usr/include"
  
 -set_default cc nm pkg_config sysinclude
 +set_default cc cxx nm pkg_config strip sysinclude yasmexe
  enabled cross_compile || host_cc_default=$cc
  set_default host_cc
  
@@@ -2124,7 -1933,6 +2124,7 @@@ trap 'rm -f -- $TMPFILES' EXI
  
  tmpfile TMPASM .asm
  tmpfile TMPC   .c
 +tmpfile TMPCPP .cpp
  tmpfile TMPE   $EXESUF
  tmpfile TMPH   .h
  tmpfile TMPO   .o
@@@ -2341,11 -2149,9 +2341,11 @@@ test -n "$cc_type" && enable $cc_type |
  set_default ar as dep_cc ld
  
  test -n "$CC_DEPFLAGS" || CCDEP=$DEPEND_CMD
 +test -n "$CXX_DEPFLAGS" || CXXDEP=$DEPEND_CMD
  test -n "$AS_DEPFLAGS" || ASDEP=$DEPEND_CMD
  
  add_cflags $extra_cflags
 +add_cxxflags $extra_cxxflags
  add_asflags $extra_cflags
  
  if test -n "$sysroot"; then
  
  # Deal with common $arch aliases
  case "$arch" in
 -    arm*)
 +    arm*|iPad*)
          arch="arm"
      ;;
      mips|mipsel|IP*)
          arch="parisc"
          subarch="parisc64"
      ;;
 -    "Power Macintosh"|ppc|powerpc)
 +    "Power Macintosh"|ppc|powerpc|ppc64|powerpc64)
          arch="ppc"
      ;;
 -    ppc64|powerpc64)
 -        arch="ppc"
 -        subarch="ppc64"
 -    ;;
      s390|s390x)
          arch="s390"
      ;;
          arch="sparc"
          subarch="sparc64"
      ;;
 -    i[3-6]86|i86pc|BePC|x86pc|x86_64|amd64)
 +    i[3-6]86|i86pc|BePC|x86pc|x86_64|x86_32|amd64)
          arch="x86"
      ;;
  esac
@@@ -2576,7 -2386,6 +2576,7 @@@ if test "$?" != 0; the
  fi
  
  add_cppflags -D_ISOC99_SOURCE
 +add_cxxflags -D__STDC_CONSTANT_MACROS
  check_cflags -std=c99
  check_cc -D_FILE_OFFSET_BITS=64 <<EOF && add_cppflags -D_FILE_OFFSET_BITS=64
  #include <stdlib.h>
              spic=$shared
          fi
      ;;
 +    ppc)
 +        check_cc <<EOF && subarch="ppc64"
 +        int test[(int)sizeof(char*) - 7];
 +EOF
 +    ;;
  esac
  
  enable $subarch
@@@ -2619,7 -2423,7 +2619,7 @@@ case $target_os i
          host_libs=
          ;;
      sunos)
 -        AVSERVERLDFLAGS=""
 +        FFSERVERLDFLAGS=""
          SHFLAGS='-shared -Wl,-h,$$(@F)'
          enabled x86 && SHFLAGS="-mimpure-text $SHFLAGS"
          network_extralibs="-lsocket -lnsl"
      openbsd)
          enable malloc_aligned
          # On OpenBSD 4.5. the compiler does not use PIC unless
 -        # explicitly using -fPIC. Libav builds fine without PIC,
 +        # explicitly using -fPIC. FFmpeg builds fine without PIC,
          # however the generated executable will not do anything
          # (simply quits with exit-code 1, no crash, no output).
          # Thus explicitly enable PIC here.
          ;;
      bsd/os)
          add_extralibs -lpoll -lgnugetopt
 +        strip="strip -d"
          ;;
      darwin)
          enable malloc_aligned
          enabled ppc && add_asflags -force_cpusubtype_ALL
          SHFLAGS='-dynamiclib -Wl,-single_module -Wl,-install_name,$(SHLIBDIR)/$(SLIBNAME_WITH_MAJOR),-current_version,$(LIBVERSION),-compatibility_version,$(LIBMAJOR)'
          enabled x86_32 && append SHFLAGS -Wl,-read_only_relocs,suppress
 +        strip="${strip} -x"
          add_ldflags -Wl,-dynamic,-search_paths_first
          SLIBSUF=".dylib"
          SLIBNAME_WITH_VERSION='$(SLIBPREF)$(FULLNAME).$(LIBVERSION)$(SLIBSUF)'
          SLIBNAME_WITH_MAJOR='$(SLIBPREF)$(FULLNAME).$(LIBMAJOR)$(SLIBSUF)'
 -        AVSERVERLDFLAGS=-Wl,-bind_at_load
 +        FFSERVERLDFLAGS=-Wl,-bind_at_load
          objformat="macho"
          enabled x86_64 && objformat="macho64"
          enabled_any pic shared ||
          LIBTARGET=i386
          if enabled x86_64; then
              enable malloc_aligned
 -            LIBTARGET="i386:x86-64"
 +            LIBTARGET=x64
          elif enabled arm; then
              LIBTARGET=arm-wince
          fi
          SLIBSUF=".dll"
          SLIBNAME_WITH_VERSION='$(SLIBPREF)$(FULLNAME)-$(LIBVERSION)$(SLIBSUF)'
          SLIBNAME_WITH_MAJOR='$(SLIBPREF)$(FULLNAME)-$(LIBMAJOR)$(SLIBSUF)'
 -        SLIB_EXTRA_CMD=-'$(DLLTOOL) -m $(LIBTARGET) -d $$(@:$(SLIBSUF)=.def) -l $(SUBDIR)$(SLIBNAME:$(SLIBSUF)=.lib) -D $(SLIBNAME_WITH_MAJOR)'
 +        SLIB_EXTRA_CMD='-lib.exe /machine:$(LIBTARGET) /def:$$(@:$(SLIBSUF)=.def) /out:$(SUBDIR)$(SLIBNAME:$(SLIBSUF)=.lib)'
          SLIB_INSTALL_NAME='$(SLIBNAME_WITH_MAJOR)'
          SLIB_INSTALL_LINKS=
          SLIB_INSTALL_EXTRA_SHLIB='$(SLIBNAME:$(SLIBSUF)=.lib)'
          SLIB_INSTALL_EXTRA_LIB='lib$(SLIBNAME:$(SLIBSUF)=.dll.a) $(SLIBNAME_WITH_MAJOR:$(SLIBSUF)=.def)'
          SHFLAGS='-shared -Wl,--output-def,$$(@:$(SLIBSUF)=.def) -Wl,--out-implib,$(SUBDIR)lib$(SLIBNAME:$(SLIBSUF)=.dll.a) -Wl,--enable-runtime-pseudo-reloc -Wl,--enable-auto-image-base'
          objformat="win32"
 -        dlltool="${cross_prefix}dlltool"
          enable dos_paths
          check_cflags -fno-common
          check_cpp_condition _mingw.h "defined (__MINGW64_VERSION_MAJOR) || (__MINGW32_MAJOR_VERSION > 3) \
          ranlib="echo ignoring ranlib"
          ;;
      os/2*)
 +        strip="lxlite -CS"
          ln_s="cp -f"
          objformat="aout"
          add_cppflags -D_GNU_SOURCE
          add_ldflags -Zomf -Zbin-files -Zargs-wild -Zmap
          SHFLAGS='$(SUBDIR)$(NAME).def -Zdll -Zomf'
 -        AVSERVERLDFLAGS=""
 +        FFSERVERLDFLAGS=""
          LIBSUF="_s.a"
          SLIBPREF=""
          SLIBSUF=".dll"
            emximp -o $(SUBDIR)$(LIBPREF)$(NAME)_dll.lib $(SUBDIR)$(NAME).def;'
          SLIB_INSTALL_EXTRA_LIB='$(LIBPREF)$(NAME)_dll.a $(LIBPREF)$(NAME)_dll.lib'
          enable dos_paths
 +        enable_weak os2threads
          ;;
      gnu/kfreebsd)
          add_cppflags -D_POSIX_C_SOURCE=200112 -D_XOPEN_SOURCE=600 -D_BSD_SOURCE
          ;;
  esac
  
 -echo "config:$arch:$subarch:$cpu:$target_os:$cc_ident:$LIBAV_CONFIGURATION" >config.fate
 +echo "config:$arch:$subarch:$cpu:$target_os:$cc_ident:$FFMPEG_CONFIGURATION" >config.fate
  
  check_cpp_condition stdlib.h "defined(__PIC__) || defined(__pic__) || defined(PIC)" && enable pic
  
@@@ -2813,13 -2614,11 +2813,13 @@@ die_license_disabled() 
  }
  
  die_license_disabled gpl libcdio
 +die_license_disabled gpl libutvideo
  die_license_disabled gpl libx264
  die_license_disabled gpl libxavs
  die_license_disabled gpl libxvid
  die_license_disabled gpl x11grab
  
 +die_license_disabled nonfree libaacplus
  die_license_disabled nonfree libfaac
  die_license_disabled nonfree openssl
  
@@@ -2885,7 -2684,7 +2885,7 @@@ elif enabled arm; the
      elif ! check_cpp_condition stddef.h "defined __ARM_PCS || defined __SOFTFP__"; then
          case "${cross_prefix:-$cc}" in
              *hardfloat*)         enable vfp_args;   fpabi=vfp ;;
 -            *) check_ld <<EOF && enable vfp_args && fpabi=vfp || fpabi=soft ;;
 +            *) check_ld "cc" <<EOF && enable vfp_args && fpabi=vfp || fpabi=soft ;;
  __asm__ (".eabi_attribute 28, 1");
  int main(void) { return 0; }
  EOF
@@@ -3063,13 -2862,11 +3063,13 @@@ check_func  ${malloc_prefix}posix_memal
  check_func  setrlimit
  check_func  strerror_r
  check_func  strptime
 -check_func  strtok_r
  check_func  sched_getaffinity
  check_func  sysconf
  check_func  sysctl
 +check_func_headers conio.h kbhit
 +check_func_headers windows.h PeekNamedPipe
  check_func_headers io.h setmode
 +check_func_headers lzo/lzo1x.h lzo1x_999_compress
  check_lib2 "windows.h psapi.h" GetProcessMemoryInfo -lpsapi
  check_func_headers windows.h GetProcessAffinityMask
  check_func_headers windows.h GetProcessTimes
@@@ -3077,38 -2874,27 +3077,38 @@@ check_func_headers windows.h MapViewOfF
  check_func_headers windows.h VirtualAlloc
  
  check_header dlfcn.h
 -check_header dxva2api.h
 +check_header dxva2api.h -D_WIN32_WINNT=0x0600
 +check_header libcrystalhd/libcrystalhd_if.h
  check_header malloc.h
  check_header poll.h
  check_header sys/mman.h
  check_header sys/param.h
  check_header sys/resource.h
  check_header sys/select.h
 +check_header termios.h
  check_header vdpau/vdpau.h
  check_header vdpau/vdpau_x11.h
  check_header X11/extensions/XvMClib.h
 +check_header asm/types.h
  
  disabled  zlib || check_lib   zlib.h      zlibVersion -lz   || disable  zlib
  disabled bzlib || check_lib2 bzlib.h BZ2_bzlibVersion -lbz2 || disable bzlib
  
 +# check for VDA header
 +if ! disabled vda; then
 +    if check_header VideoDecodeAcceleration/VDADecoder.h; then
 +        enable vda
 +        add_extralibs -framework CoreFoundation -framework VideoDecodeAcceleration -framework QuartzCore
 +    fi
 +fi
 +
  if ! disabled w32threads && ! enabled pthreads; then
      check_func _beginthreadex && enable w32threads
  fi
  
  # check for some common methods of building with pthread support
  # do this before the optional library checks as some of them require pthreads
 -if ! disabled pthreads && ! enabled w32threads; then
 +if ! disabled pthreads && ! enabled w32threads && ! enabled os2threads; then
      enable pthreads
      if check_func pthread_create; then
          :
@@@ -3134,10 -2920,8 +3134,10 @@@ for thread in $THREADS_LIST; d
  done
  
  check_lib math.h sin -lm && LIBM="-lm"
 +disabled crystalhd || check_lib libcrystalhd/libcrystalhd_if.h DtsCrystalHDVersion -lcrystalhd || disable crystalhd
  enabled vaapi && require vaapi va/va.h vaInitialize -lva
  
 +check_mathfunc cbrtf
  check_mathfunc exp2
  check_mathfunc exp2f
  check_mathfunc llrint
@@@ -3155,53 -2939,36 +3155,53 @@@ check_mathfunc trunc
  enabled avisynth   && require2 vfw32 "windows.h vfw.h" AVIFileInit -lavifil32
  enabled frei0r     && { check_header frei0r.h || die "ERROR: frei0r.h header not found"; }
  enabled gnutls     && require_pkg_config gnutls gnutls/gnutls.h gnutls_global_init
 +enabled libaacplus && require  "libaacplus >= 2.0.0" aacplus.h aacplusEncOpen -laacplus
 +enabled libass     && require_pkg_config libass ass/ass.h ass_library_init
 +enabled libbluray  && require libbluray libbluray/bluray.h bd_open -lbluray
 +enabled libcelt    && require libcelt celt/celt.h celt_decode -lcelt0 &&
 +                      { check_lib celt/celt.h celt_decoder_create_custom -lcelt0 ||
 +                        die "ERROR: libcelt version must be >= 0.11.0."; }
  enabled libdirac   && require_pkg_config dirac                          \
      "libdirac_decoder/dirac_parser.h"  \
      "dirac_decoder_init"
  enabled libfaac    && require2 libfaac "stdint.h faac.h" faacEncGetVersion -lfaac
  enabled libfreetype && require_pkg_config freetype2 "ft2build.h freetype/freetype.h" FT_Init_FreeType
  enabled libgsm     && require  libgsm gsm/gsm.h gsm_create -lgsm
 +enabled libmodplug && require  libmodplug libmodplug/modplug.h ModPlug_Load -lmodplug
  enabled libmp3lame && require  "libmp3lame >= 3.98.3" lame/lame.h lame_set_VBR_quality -lmp3lame
  enabled libnut     && require  libnut libnut.h nut_demuxer_init -lnut
  enabled libopencore_amrnb  && require libopencore_amrnb opencore-amrnb/interf_dec.h Decoder_Interface_init -lopencore-amrnb
  enabled libopencore_amrwb  && require libopencore_amrwb opencore-amrwb/dec_if.h D_IF_init -lopencore-amrwb
 -enabled libopencv  && require_pkg_config opencv opencv/cv.h cvCreateImageHeader
 +enabled libopencv  && require_pkg_config opencv opencv/cxcore.h cvCreateImageHeader
  enabled libopenjpeg && require libopenjpeg openjpeg.h opj_version -lopenjpeg
  enabled libpulse && require_pkg_config libpulse-simple pulse/simple.h pa_simple_new
  enabled librtmp    && require_pkg_config librtmp librtmp/rtmp.h RTMP_Socket
  enabled libschroedinger && require_pkg_config schroedinger-1.0 schroedinger/schro.h schro_init
  enabled libspeex   && require  libspeex speex/speex.h speex_decoder_init -lspeex
 +enabled libstagefright_h264  && require_cpp libstagefright_h264 "binder/ProcessState.h media/stagefright/MetaData.h
 +    media/stagefright/MediaBufferGroup.h media/stagefright/MediaDebug.h media/stagefright/MediaDefs.h
 +    media/stagefright/OMXClient.h media/stagefright/OMXCodec.h" android::OMXClient -lstagefright -lmedia -lutils -lbinder
  enabled libtheora  && require  libtheora theora/theoraenc.h th_info_init -ltheoraenc -ltheoradec -logg
 +enabled libutvideo    && require_cpp utvideo "stdint.h stdlib.h utvideo/utvideo.h utvideo/Codec.h" 'CCodec*' -lutvideo -lstdc++
 +enabled libv4l2    && require_pkg_config libv4l2 libv4l2.h v4l2_ioctl
  enabled libvo_aacenc && require libvo_aacenc vo-aacenc/voAAC.h voGetAACEncAPI -lvo-aacenc
  enabled libvo_amrwbenc && require libvo_amrwbenc vo-amrwbenc/enc_if.h E_IF_init -lvo-amrwbenc
  enabled libvorbis  && require  libvorbis vorbis/vorbisenc.h vorbis_info_init -lvorbisenc -lvorbis -logg
  enabled libvpx     && {
      enabled libvpx_decoder && { check_lib2 "vpx/vpx_decoder.h vpx/vp8dx.h" vpx_codec_dec_init_ver -lvpx ||
                                  die "ERROR: libvpx decoder version must be >=0.9.1"; }
 -    enabled libvpx_encoder && { check_lib2 "vpx/vpx_encoder.h vpx/vp8cx.h" vpx_codec_enc_init_ver -lvpx ||
 -                                die "ERROR: libvpx encoder version must be >=0.9.1"; } }
 +    enabled libvpx_encoder && { check_lib2 "vpx/vpx_encoder.h vpx/vp8cx.h" "vpx_codec_enc_init_ver VPX_CQ" -lvpx ||
 +                                die "ERROR: libvpx encoder version must be >=0.9.6"; } }
  enabled libx264    && require  libx264 x264.h x264_encoder_encode -lx264 &&
                        { check_cpp_condition x264.h "X264_BUILD >= 118" ||
                          die "ERROR: libx264 version must be >= 0.118."; }
  enabled libxavs    && require  libxavs xavs.h xavs_encoder_encode -lxavs
  enabled libxvid    && require  libxvid xvid.h xvid_global -lxvidcore
 +enabled openal     && { { for al_libs in "${OPENAL_LIBS}" "-lopenal" "-lOpenAL32"; do
 +                        check_lib 'AL/al.h' alGetError "${al_libs}" && break; done } ||
 +                        die "ERROR: openal not found"; } &&
 +                      { check_cpp_condition "AL/al.h" "defined(AL_VERSION_1_1)" ||
 +                        die "ERROR: openal version must be 1.1 or compatible"; }
  enabled openssl    && { check_lib openssl/ssl.h SSL_library_init -lssl -lcrypto ||
                          check_lib openssl/ssl.h SSL_library_init -lssl32 -leay32 ||
                          check_lib openssl/ssl.h SSL_library_init -lssl -lcrypto -lws2_32 -lgdi32 ||
@@@ -3216,28 -2983,15 +3216,28 @@@ if enabled libdc1394; the
      die "ERROR: No version of libdc1394 found "
  fi
  
 +SDL_CONFIG="${cross_prefix}sdl-config"
  if check_pkg_config sdl SDL_version.h SDL_Linked_Version; then
      check_cpp_condition SDL.h "(SDL_MAJOR_VERSION<<16 | SDL_MINOR_VERSION<<8 | SDL_PATCHLEVEL) >= 0x010201" $sdl_cflags &&
      enable sdl &&
      check_struct SDL.h SDL_VideoInfo current_w $sdl_cflags && enable sdl_video_size
 +else
 +  if "${SDL_CONFIG}" --version > /dev/null 2>&1; then
 +    sdl_cflags=$("${SDL_CONFIG}" --cflags)
 +    sdl_libs=$("${SDL_CONFIG}" --libs)
 +    check_func_headers SDL_version.h SDL_Linked_Version $sdl_cflags $sdl_libs &&
 +    check_cpp_condition SDL.h "(SDL_MAJOR_VERSION<<16 | SDL_MINOR_VERSION<<8 | SDL_PATCHLEVEL) >= 0x010201" $sdl_cflags &&
 +    enable sdl &&
 +    check_struct SDL.h SDL_VideoInfo current_w $sdl_cflags && enable sdl_video_size
 +  fi
  fi
 +enabled sdl && add_cflags $sdl_cflags && add_extralibs $sdl_libs
  
  texi2html -version > /dev/null 2>&1 && enable texi2html || disable texi2html
 +makeinfo --version > /dev/null 2>&1 && enable makeinfo  || disable makeinfo
  
  check_header linux/fb.h
 +check_header linux/videodev.h
  check_header linux/videodev2.h
  check_struct linux/videodev2.h "struct v4l2_frmivalenum" discrete
  
@@@ -3248,8 -3002,6 +3248,8 @@@ check_func_headers "windows.h vfw.h" ca
  # w32api 3.12 had it defined wrong
  check_cpp_condition vfw.h "WM_CAP_DRIVER_CONNECT > WM_USER" && enable vfwcap_defines
  
 +check_type "dshow.h" IBaseFilter
 +
  # check for ioctl_meteor.h, ioctl_bt848.h and alternatives
  { check_header dev/bktr/ioctl_meteor.h &&
    check_header dev/bktr/ioctl_bt848.h; } ||
  check_header dev/ic/bt8xx.h
  
  check_header sndio.h
 -check_header sys/soundcard.h
 +if check_struct sys/soundcard.h audio_buf_info bytes; then
 +    enable_safe sys/soundcard.h
 +else
 +    check_cc -D__BSD_VISIBLE -D__XSI_VISIBLE <<EOF && add_cppflags -D__BSD_VISIBLE -D__XSI_VISIBLE && enable_safe sys/soundcard.h
 +    #include <sys/soundcard.h>
 +    audio_buf_info abc;
 +EOF
 +fi
  check_header soundcard.h
  
  enabled_any alsa_indev alsa_outdev && check_lib2 alsa/asoundlib.h snd_pcm_htimestamp -lasound
  
 -enabled jack_indev && check_lib2 jack/jack.h jack_client_open -ljack
 +enabled jack_indev && check_lib2 jack/jack.h jack_client_open -ljack && check_func sem_timedwait
  
  enabled_any sndio_indev sndio_outdev && check_lib2 sndio.h sio_open -lsndio
  
@@@ -3284,11 -3029,9 +3284,11 @@@ require X11 X11/Xlib.h XOpenDisplay -lX
  require Xext X11/extensions/XShm.h XShmCreateImage -lXext &&
  require Xfixes X11/extensions/Xfixes.h XFixesGetCursorImage -lXfixes
  
 -# check for VDA header
 -if ! disabled vda && check_header VideoDecodeAcceleration/VDADecoder.h; then
 -    enable vda && add_extralibs -framework CoreFoundation -framework VideoDecodeAcceleration -framework QuartzCore
 +if ! disabled vaapi; then
 +    check_lib va/va.h vaInitialize -lva && {
 +        check_cpp_condition va/va_version.h "VA_CHECK_VERSION(0,32,0)" ||
 +        warn "Please upgrade to VA-API >= 0.32 if you would like full VA-API support.";
 +    } || disable vaapi
  fi
  
  if ! disabled vdpau && enabled vdpau_vdpau_h; then
@@@ -3299,8 -3042,6 +3299,8 @@@ check_cpp_condition 
  fi
  
  enabled debug && add_cflags -g"$debuglevel" && add_asflags -g"$debuglevel"
 +enabled coverage && add_cflags "-fprofile-arcs -ftest-coverage" && add_ldflags "-fprofile-arcs -ftest-coverage"
 +test -n "$valgrind" && target_exec="$valgrind --error-exitcode=1 --malloc-fill=0x2a --track-origins=yes --leak-check=full --gen-suppressions=all --suppressions=$source_path/tests/fate-valgrind.supp"
  
  # add some useful compiler flags if supported
  check_cflags -Wdeclaration-after-statement
@@@ -3317,13 -3058,12 +3317,13 @@@ check_cflags -Wwrite-string
  check_cflags -Wtype-limits
  check_cflags -Wundef
  check_cflags -Wmissing-prototypes
 +check_cflags -Wno-pointer-to-int-cast
  check_cflags -Wstrict-prototypes
  enabled extra_warnings && check_cflags -Winline
  
  # add some linker flags
  check_ldflags -Wl,--warn-common
 -check_ldflags -Wl,-rpath-link=libswscale:libavfilter:libavdevice:libavformat:libavcodec:libavutil
 +check_ldflags -Wl,-rpath-link=libpostproc:libswresample:libswscale:libavfilter:libavdevice:libavformat:libavcodec:libavutil
  test_ldflags -Wl,-Bsymbolic && append SHFLAGS -Wl,-Bsymbolic
  
  enabled xmm_clobber_test &&                             \
  fi
  check_cflags -fno-math-errno
  check_cflags -fno-signed-zeros
 +check_cc -mno-red-zone <<EOF && noredzone_flags="-mno-red-zone"
 +int x;
 +EOF
 +
  
  if enabled icc; then
      # Just warnings, no remarks
@@@ -3400,6 -3136,7 +3400,6 @@@ elif enabled gcc; the
      check_cflags -fno-tree-vectorize
      check_cflags -Werror=implicit-function-declaration
      check_cflags -Werror=missing-prototypes
 -    check_cflags -Werror=declaration-after-statement
  elif enabled llvm_gcc; then
      check_cflags -mllvm -stack-alignment=16
  elif enabled clang; then
@@@ -3429,41 -3166,9 +3429,41 @@@ check_deps $CONFIG_LIST       
  
  enabled asm || { arch=c; disable $ARCH_LIST $ARCH_EXT_LIST; }
  
 +if test $target_os = "haiku"; then
 +    disable memalign
 +    disable posix_memalign
 +fi
 +
  ! enabled_any memalign posix_memalign malloc_aligned &&
      enabled_any $need_memalign && enable memalign_hack
  
 +# add_dep lib dep
 +# -> enable ${lib}_deps_${dep}
 +# -> add $dep to ${lib}_deps only once
 +add_dep() {
 +    lib=$1
 +    dep=$2
 +    enabled "${lib}_deps_${dep}" && return 0
 +    enable  "${lib}_deps_${dep}"
 +    prepend "${lib}_deps" $dep
 +}
 +
 +# merge deps lib components
 +# merge all ${component}_deps into ${lib}_deps and ${lib}_deps_*
 +merge_deps() {
 +    lib=$1
 +    shift
 +    for comp in $*; do
 +        enabled $comp || continue
 +        eval "dep=\"\$${comp}_deps\""
 +        for d in $dep; do
 +            add_dep $lib $d
 +        done
 +    done
 +}
 +
 +merge_deps libavfilter $FILTER_LIST
 +
  echo "install prefix            $prefix"
  echo "source path               $source_path"
  echo "C compiler                $cc"
@@@ -3471,9 -3176,6 +3471,9 @@@ echo "ARCH                      $arch (
  if test "$build_suffix" != ""; then
      echo "build suffix              $build_suffix"
  fi
 +if test "$progs_suffix" != ""; then
 +    echo "progs suffix              $progs_suffix"
 +fi
  if test "$extra_version" != ""; then
      echo "version string suffix     $extra_version"
  fi
@@@ -3512,12 -3214,10 +3512,12 @@@ if enabled sparc; the
      echo "VIS enabled               ${vis-no}"
  fi
  echo "debug symbols             ${debug-no}"
 +echo "strip symbols             ${stripping-no}"
  echo "optimize for size         ${small-no}"
  echo "optimizations             ${optimizations-no}"
  echo "static                    ${static-no}"
  echo "shared                    ${shared-no}"
 +echo "postprocessing support    ${postproc-no}"
  echo "new filter support        ${avfilter-no}"
  echo "network support           ${network-no}"
  echo "threading support         ${thread_type-no}"
@@@ -3529,15 -3229,11 +3529,15 @@@ echo "libvdpau enabled          ${vdpau
  echo "AVISynth enabled          ${avisynth-no}"
  echo "frei0r enabled            ${frei0r-no}"
  echo "gnutls enabled            ${gnutls-no}"
 +echo "libaacplus enabled        ${libaacplus-no}"
 +echo "libass enabled            ${libass-no}"
  echo "libcdio support           ${libcdio-no}"
 +echo "libcelt enabled           ${libcelt-no}"
  echo "libdc1394 support         ${libdc1394-no}"
  echo "libdirac enabled          ${libdirac-no}"
  echo "libfaac enabled           ${libfaac-no}"
  echo "libgsm enabled            ${libgsm-no}"
 +echo "libmodplug enabled        ${libmodplug-no}"
  echo "libmp3lame enabled        ${libmp3lame-no}"
  echo "libnut enabled            ${libnut-no}"
  echo "libopencore-amrnb support ${libopencore_amrnb-no}"
@@@ -3548,10 -3244,7 +3548,10 @@@ echo "libpulse enabled          ${libpu
  echo "librtmp enabled           ${librtmp-no}"
  echo "libschroedinger enabled   ${libschroedinger-no}"
  echo "libspeex enabled          ${libspeex-no}"
 +echo "libstagefright-h264 enabled    ${libstagefright_h264-no}"
  echo "libtheora enabled         ${libtheora-no}"
 +echo "libutvideo enabled        ${libutvideo-no}"
 +echo "libv4l2 enabled           ${libv4l2-no}"
  echo "libvo-aacenc support      ${libvo_aacenc-no}"
  echo "libvo-amrwbenc support    ${libvo_amrwbenc-no}"
  echo "libvorbis enabled         ${libvorbis-no}"
@@@ -3559,7 -3252,6 +3559,7 @@@ echo "libvpx enabled            ${libvp
  echo "libx264 enabled           ${libx264-no}"
  echo "libxavs enabled           ${libxavs-no}"
  echo "libxvid enabled           ${libxvid-no}"
 +echo "openal enabled            ${openal-no}"
  echo "openssl enabled           ${openssl-no}"
  echo "zlib enabled              ${zlib-no}"
  echo "bzlib enabled             ${bzlib-no}"
@@@ -3589,15 -3281,11 +3589,15 @@@ echo "Creating config.mak and config.h.
  
  test -e Makefile || $ln_s "$source_path/Makefile" .
  
 +enabled stripping || strip="echo skipping strip"
 +
  config_files="$TMPH config.mak"
  
  cat > config.mak <<EOF
  # Automatically generated by configure - do not modify!
 -LIBAV_CONFIGURATION=$LIBAV_CONFIGURATION
 +ifndef FFMPEG_CONFIG_MAK
 +FFMPEG_CONFIG_MAK=1
 +FFMPEG_CONFIGURATION=$FFMPEG_CONFIGURATION
  prefix=$prefix
  LIBDIR=\$(DESTDIR)$libdir
  SHLIBDIR=\$(DESTDIR)$shlibdir
@@@ -3606,13 -3294,9 +3606,13 @@@ BINDIR=\$(DESTDIR)$bindi
  DATADIR=\$(DESTDIR)$datadir
  MANDIR=\$(DESTDIR)$mandir
  SRC_PATH=$source_path
 +ifndef MAIN_MAKEFILE
 +SRC_PATH:=\$(SRC_PATH:.%=..%)
 +endif
  CC_IDENT=$cc_ident
  ARCH=$arch
  CC=$cc
 +CXX=$cxx
  AS=$as
  LD=$ld
  DEPCC=$dep_cc
@@@ -3620,22 -3304,18 +3620,22 @@@ YASM=$yasmex
  YASMDEP=$yasmexe
  AR=$ar
  RANLIB=$ranlib
 +CP=cp -p
  LN_S=$ln_s
 +STRIP=$strip
  CPPFLAGS=$CPPFLAGS
  CFLAGS=$CFLAGS
 +CXXFLAGS=$CXXFLAGS
  ASFLAGS=$ASFLAGS
  AS_O=$CC_O
  CC_O=$CC_O
 -DLLTOOL=$dlltool
 +CXX_O=$CXX_O
  LDFLAGS=$LDFLAGS
 -AVSERVERLDFLAGS=$AVSERVERLDFLAGS
 +FFSERVERLDFLAGS=$FFSERVERLDFLAGS
  SHFLAGS=$SHFLAGS
  YASMFLAGS=$YASMFLAGS
  BUILDSUF=$build_suffix
 +PROGSSUF=$progs_suffix
  FULLNAME=$FULLNAME
  LIBPREF=$LIBPREF
  LIBSUF=$LIBSUF
@@@ -3646,7 -3326,6 +3646,7 @@@ EXESUF=$EXESU
  EXTRA_VERSION=$extra_version
  DEPFLAGS=$DEPFLAGS
  CCDEP=$CCDEP
 +CXXDEP=$CXXDEP
  ASDEP=$ASDEP
  CC_DEPFLAGS=$CC_DEPFLAGS
  AS_DEPFLAGS=$AS_DEPFLAGS
@@@ -3661,7 -3340,7 +3661,7 @@@ SDL_LIBS=$sdl_lib
  SDL_CFLAGS=$sdl_cflags
  LIB_INSTALL_EXTRA_CMD=$LIB_INSTALL_EXTRA_CMD
  EXTRALIBS=$extralibs
 -INSTALL=install
 +INSTALL=$install
  LIBTARGET=${LIBTARGET}
  SLIBNAME=${SLIBNAME}
  SLIBNAME_WITH_VERSION=${SLIBNAME_WITH_VERSION}
@@@ -3673,17 -3352,13 +3673,17 @@@ SLIB_INSTALL_LINKS=${SLIB_INSTALL_LINKS
  SLIB_INSTALL_EXTRA_LIB=${SLIB_INSTALL_EXTRA_LIB}
  SLIB_INSTALL_EXTRA_SHLIB=${SLIB_INSTALL_EXTRA_SHLIB}
  SAMPLES:=${samples:-\$(FATE_SAMPLES)}
 +NOREDZONE_FLAGS=$noredzone_flags
  EOF
  
  get_version(){
      name=$1
      file=$source_path/$2
 +# This condition will be removed when we stop supporting old libpostproc versions
 +if ! test "$name" = LIBPOSTPROC || test "$postproc_version" = current; then
      eval $(grep "#define ${name}_VERSION_M" "$file" | awk '{ print $2"="$3 }')
      eval ${name}_VERSION=\$${name}_VERSION_MAJOR.\$${name}_VERSION_MINOR.\$${name}_VERSION_MICRO
 +fi
      lcname=$(tolower $name)
      eval echo "${lcname}_VERSION=\$${name}_VERSION" >> config.mak
      eval echo "${lcname}_VERSION_MAJOR=\$${name}_VERSION_MAJOR" >> config.mak
@@@ -3694,17 -3369,14 +3694,17 @@@ get_version LIBAVDEVICE libavdevice/avd
  get_version LIBAVFILTER libavfilter/version.h
  get_version LIBAVFORMAT libavformat/version.h
  get_version LIBAVUTIL   libavutil/avutil.h
 +get_version LIBPOSTPROC libpostproc/postprocess.h
 +get_version LIBSWRESAMPLE libswresample/swresample.h
  get_version LIBSWSCALE  libswscale/swscale.h
  
  cat > $TMPH <<EOF
  /* Automatically generated by configure - do not modify! */
 -#ifndef LIBAV_CONFIG_H
 -#define LIBAV_CONFIG_H
 -#define LIBAV_CONFIGURATION "$(c_escape $LIBAV_CONFIGURATION)"
 -#define LIBAV_LICENSE "$(c_escape $license)"
 +#ifndef FFMPEG_CONFIG_H
 +#define FFMPEG_CONFIG_H
 +#define FFMPEG_CONFIGURATION "$(c_escape $FFMPEG_CONFIGURATION)"
 +#define FFMPEG_LICENSE "$(c_escape $license)"
 +#define FFMPEG_DATADIR "$(eval c_escape $datadir)"
  #define AVCONV_DATADIR "$(eval c_escape $datadir)"
  #define CC_TYPE "$cc_type"
  #define CC_VERSION $cc_version
@@@ -3740,14 -3412,12 +3740,14 @@@ print_config CONFIG_ "$config_files" $C
  cat >>config.mak <<EOF
  ACODEC_TESTS=$(print_enabled -n _test $ACODEC_TESTS)
  VCODEC_TESTS=$(print_enabled -n _test $VCODEC_TESTS)
 +LAVF_FATE_TESTS=$(print_enabled -n _test $LAVF_FATE_TESTS)
  LAVF_TESTS=$(print_enabled   -n _test $LAVF_TESTS)
  LAVFI_TESTS=$(print_enabled  -n _test $LAVFI_TESTS)
  SEEK_TESTS=$(print_enabled   -n _test $SEEK_TESTS)
  EOF
  
 -echo "#endif /* LIBAV_CONFIG_H */" >> $TMPH
 +echo "#endif /* FFMPEG_CONFIG_H */" >> $TMPH
 +echo "endif # FFMPEG_CONFIG_MAK" >> config.mak
  
  # Do not overwrite an unchanged config.h to avoid superfluous rebuilds.
  cp_if_changed $TMPH config.h
@@@ -3761,12 -3431,6 +3761,12 @@@ cat > $TMPH <<EO
  #define AVUTIL_AVCONFIG_H
  EOF
  
 +test "$postproc_version" != current && cat >> $TMPH <<EOF
 +#define LIBPOSTPROC_VERSION_MAJOR $LIBPOSTPROC_VERSION_MAJOR
 +#define LIBPOSTPROC_VERSION_MINOR $LIBPOSTPROC_VERSION_MINOR
 +#define LIBPOSTPROC_VERSION_MICRO $LIBPOSTPROC_VERSION_MICRO
 +EOF
 +
  print_config AV_HAVE_ $TMPH $HAVE_LIST_PUB
  
  echo "#endif /* AVUTIL_AVCONFIG_H */" >> $TMPH
@@@ -3818,22 -3482,9 +3818,22 @@@ Cflags: -I\${includedir
  EOF
  }
  
 -pkgconfig_generate libavutil "Libav utility library" "$LIBAVUTIL_VERSION" "$LIBM"
 -pkgconfig_generate libavcodec "Libav codec library" "$LIBAVCODEC_VERSION" "$extralibs" "libavutil = $LIBAVUTIL_VERSION"
 -pkgconfig_generate libavformat "Libav container format library" "$LIBAVFORMAT_VERSION" "$extralibs" "libavcodec = $LIBAVCODEC_VERSION"
 -pkgconfig_generate libavdevice "Libav device handling library" "$LIBAVDEVICE_VERSION" "$extralibs" "libavformat = $LIBAVFORMAT_VERSION"
 -pkgconfig_generate libavfilter "Libav video filtering library" "$LIBAVFILTER_VERSION" "$extralibs"
 -pkgconfig_generate libswscale "Libav image rescaling library" "$LIBSWSCALE_VERSION" "$LIBM" "libavutil = $LIBAVUTIL_VERSION"
 +libavfilter_pc_deps=""
 +enabled libavfilter_deps_avcodec    && prepend libavfilter_pc_deps "libavcodec = $LIBAVCODEC_VERSION,"
 +enabled libavfilter_deps_avformat   && prepend libavfilter_pc_deps "libavformat = $LIBAVFORMAT_VERSION,"
 +enabled libavfilter_deps_swscale    && prepend libavfilter_pc_deps "libswscale = $LIBSWSCALE_VERSION,"
 +enabled libavfilter_deps_swresample && prepend libavfilter_pc_deps "libswresample = $LIBSWRESAMPLE_VERSION,"
 +enabled libavfilter_deps_postproc   && prepend libavfilter_pc_deps "libpostproc = $LIBPOSTPROC_VERSION,"
 +libavfilter_pc_deps=${libavfilter_pc_deps%, }
 +
 +libavdevice_pc_deps="libavformat = $LIBAVFORMAT_VERSION"
 +enabled lavfi_indev && prepend libavdevice_pc_deps "libavfilter = $LIBAVFILTER_VERSION,"
 +
 +pkgconfig_generate libavutil "FFmpeg utility library" "$LIBAVUTIL_VERSION" "$LIBM"
 +pkgconfig_generate libavcodec "FFmpeg codec library" "$LIBAVCODEC_VERSION" "$extralibs" "libavutil = $LIBAVUTIL_VERSION"
 +pkgconfig_generate libavformat "FFmpeg container format library" "$LIBAVFORMAT_VERSION" "$extralibs" "libavcodec = $LIBAVCODEC_VERSION"
 +pkgconfig_generate libavdevice "FFmpeg device handling library" "$LIBAVDEVICE_VERSION" "$extralibs" "$libavdevice_pc_deps"
 +pkgconfig_generate libavfilter "FFmpeg video filtering library" "$LIBAVFILTER_VERSION" "$extralibs" "$libavfilter_pc_deps"
 +pkgconfig_generate libpostproc "FFmpeg postprocessing library" "$LIBPOSTPROC_VERSION" "" "libavutil = $LIBAVUTIL_VERSION"
 +pkgconfig_generate libswscale "FFmpeg image rescaling library" "$LIBSWSCALE_VERSION" "$LIBM" "libavutil = $LIBAVUTIL_VERSION"
 +pkgconfig_generate libswresample "FFmpeg audio rescaling library" "$LIBSWRESAMPLE_VERSION" "$LIBM" "libavutil = $LIBAVUTIL_VERSION"
diff --combined doc/Makefile
@@@ -9,24 -9,13 +9,24 @@@ HTMLPAGES   = $(PROGS-yes:%=doc/%.html
                doc/libavfilter.html                                      \
                doc/platform.html                                         \
  
 +TXTPAGES    = doc/fate.txt                                              \
 +
 +
  DOCS = $(HTMLPAGES) $(MANPAGES) $(PODPAGES)
 +ifdef HAVE_MAKEINFO
 +DOCS += $(TXTPAGES)
 +endif
  
  all-$(CONFIG_DOC): documentation
  
  documentation: $(DOCS)
  
 -TEXIDEP = awk '/^@include/ { printf "$@: $(@D)/%s\n", $$2 }' <$< >$(@:%=%.d)
 +TEXIDEP = awk '/^@(verbatim)?include/ { printf "$@: $(@D)/%s\n", $$2 }' <$< >$(@:%=%.d)
 +
 +doc/%.txt: TAG = TXT
 +doc/%.txt: doc/%.texi
 +      $(Q)$(TEXIDEP)
 +      $(M)makeinfo --force --no-headers -o $@ $< 2>/dev/null
  
  doc/print_options.o: libavformat/options_table.h libavcodec/options_table.h
  
@@@ -52,7 -41,6 +52,6 @@@ doc/%.1: doc/%.pod $(GENTEXI
        $(M)pod2man --section=1 --center=" " --release=" " $< > $@
  
  $(DOCS): | doc
- OBJDIRS += doc
  
  install-progs-$(CONFIG_DOC): install-man
  
@@@ -66,7 -54,7 +65,7 @@@ uninstall-man
        $(RM) $(addprefix "$(MANDIR)/man1/",$(ALLMANPAGES))
  
  clean::
 -      $(RM) doc/*.html doc/*.pod doc/*.1 $(CLEANSUFFIXES:%=doc/%) doc/avoptions_*.texi
 +      $(RM) $(TXTPAGES) doc/*.html doc/*.pod doc/*.1 $(CLEANSUFFIXES:%=doc/%) doc/avoptions_*.texi
  
  -include $(wildcard $(DOCS:%=%.d))
  
diff --combined libavcodec/Makefile
@@@ -1,5 -1,3 +1,5 @@@
 +include $(SUBDIR)../config.mak
 +
  NAME = avcodec
  FFLIBS = avutil
  
@@@ -18,7 -16,6 +18,7 @@@ OBJS = allcodecs.
         options.o                                                        \
         parser.o                                                         \
         raw.o                                                            \
 +       rawdec.o                                                         \
         resample.o                                                       \
         resample2.o                                                      \
         simple_idct.o                                                    \
@@@ -27,7 -24,6 +27,7 @@@
  # parts needed for many different codecs
  OBJS-$(CONFIG_AANDCT)                  += aandcttab.o
  OBJS-$(CONFIG_AC3DSP)                  += ac3dsp.o
 +OBJS-$(CONFIG_CRYSTALHD)               += crystalhd.o
  OBJS-$(CONFIG_ENCODERS)                += faandct.o jfdctfst.o jfdctint.o
  OBJS-$(CONFIG_DCT)                     += dct.o dct32_fixed.o dct32_float.o
  OBJS-$(CONFIG_DWT)                     += dwt.o
@@@ -83,7 -79,7 +83,7 @@@ OBJS-$(CONFIG_AMV_DECODER)             
  OBJS-$(CONFIG_ANM_DECODER)             += anm.o
  OBJS-$(CONFIG_ANSI_DECODER)            += ansi.o cga_data.o
  OBJS-$(CONFIG_APE_DECODER)             += apedec.o
 -OBJS-$(CONFIG_ASS_DECODER)             += assdec.o ass.o
 +OBJS-$(CONFIG_ASS_DECODER)             += assdec.o ass.o ass_split.o
  OBJS-$(CONFIG_ASS_ENCODER)             += assenc.o ass.o
  OBJS-$(CONFIG_ASV1_DECODER)            += asv1.o mpeg12data.o
  OBJS-$(CONFIG_ASV1_ENCODER)            += asv1.o mpeg12data.o
@@@ -93,17 -89,12 +93,17 @@@ OBJS-$(CONFIG_ATRAC1_DECODER)          
  OBJS-$(CONFIG_ATRAC3_DECODER)          += atrac3.o atrac.o
  OBJS-$(CONFIG_AURA_DECODER)            += cyuv.o
  OBJS-$(CONFIG_AURA2_DECODER)           += aura.o
 +OBJS-$(CONFIG_AVRP_DECODER)            += r210dec.o
 +OBJS-$(CONFIG_AVRP_ENCODER)            += r210enc.o
  OBJS-$(CONFIG_AVS_DECODER)             += avs.o
 +OBJS-$(CONFIG_AYUV_DECODER)            += v408dec.o
 +OBJS-$(CONFIG_AYUV_ENCODER)            += v408enc.o
  OBJS-$(CONFIG_BETHSOFTVID_DECODER)     += bethsoftvideo.o
  OBJS-$(CONFIG_BFI_DECODER)             += bfi.o
  OBJS-$(CONFIG_BINK_DECODER)            += bink.o binkdsp.o
  OBJS-$(CONFIG_BINKAUDIO_DCT_DECODER)   += binkaudio.o wma.o wma_common.o
  OBJS-$(CONFIG_BINKAUDIO_RDFT_DECODER)  += binkaudio.o wma.o wma_common.o
 +OBJS-$(CONFIG_BINTEXT_DECODER)         += bintext.o cga_data.o
  OBJS-$(CONFIG_BMP_DECODER)             += bmp.o msrledec.o
  OBJS-$(CONFIG_BMP_ENCODER)             += bmpenc.o
  OBJS-$(CONFIG_BMV_VIDEO_DECODER)       += bmv.o
@@@ -121,9 -112,6 +121,9 @@@ OBJS-$(CONFIG_CSCD_DECODER)            
  OBJS-$(CONFIG_CYUV_DECODER)            += cyuv.o
  OBJS-$(CONFIG_DCA_DECODER)             += dca.o synth_filter.o dcadsp.o \
                                            dca_parser.o
 +OBJS-$(CONFIG_DCA_ENCODER)             += dcaenc.o
 +OBJS-$(CONFIG_DIRAC_DECODER)           += diracdec.o dirac.o diracdsp.o \
 +                                          dirac_arith.o mpeg12data.o dwt.o
  OBJS-$(CONFIG_DFA_DECODER)             += dfa.o
  OBJS-$(CONFIG_DNXHD_DECODER)           += dnxhddec.o dnxhddata.o
  OBJS-$(CONFIG_DNXHD_ENCODER)           += dnxhdenc.o dnxhddata.o       \
@@@ -138,7 -126,7 +138,7 @@@ OBJS-$(CONFIG_DVBSUB_DECODER)          
  OBJS-$(CONFIG_DVBSUB_ENCODER)          += dvbsub.o
  OBJS-$(CONFIG_DVDSUB_DECODER)          += dvdsubdec.o
  OBJS-$(CONFIG_DVDSUB_ENCODER)          += dvdsubenc.o
- OBJS-$(CONFIG_DVVIDEO_DECODER)         += dv.o dvdata.o
+ OBJS-$(CONFIG_DVVIDEO_DECODER)         += dvdec.o dv.o dvdata.o
  OBJS-$(CONFIG_DVVIDEO_ENCODER)         += dv.o dvdata.o
  OBJS-$(CONFIG_DXA_DECODER)             += dxa.o
  OBJS-$(CONFIG_DXTORY_DECODER)          += dxtory.o
@@@ -157,28 -145,20 +157,28 @@@ OBJS-$(CONFIG_EATQI_DECODER)           
  OBJS-$(CONFIG_EIGHTBPS_DECODER)        += 8bps.o
  OBJS-$(CONFIG_EIGHTSVX_EXP_DECODER)    += 8svx.o
  OBJS-$(CONFIG_EIGHTSVX_FIB_DECODER)    += 8svx.o
 +OBJS-$(CONFIG_EIGHTSVX_RAW_DECODER)    += 8svx.o
  OBJS-$(CONFIG_ESCAPE124_DECODER)       += escape124.o
 +OBJS-$(CONFIG_ESCAPE130_DECODER)       += escape130.o
  OBJS-$(CONFIG_FFV1_DECODER)            += ffv1.o rangecoder.o
  OBJS-$(CONFIG_FFV1_ENCODER)            += ffv1.o rangecoder.o
  OBJS-$(CONFIG_FFVHUFF_DECODER)         += huffyuv.o
  OBJS-$(CONFIG_FFVHUFF_ENCODER)         += huffyuv.o
 +OBJS-$(CONFIG_FFWAVESYNTH_DECODER)     += ffwavesynth.o
  OBJS-$(CONFIG_FLAC_DECODER)            += flacdec.o flacdata.o flac.o
 -OBJS-$(CONFIG_FLAC_ENCODER)            += flacenc.o flacdata.o flac.o
 +OBJS-$(CONFIG_FLAC_ENCODER)            += flacenc.o flacdata.o flac.o vorbis_data.o
  OBJS-$(CONFIG_FLASHSV_DECODER)         += flashsv.o
  OBJS-$(CONFIG_FLASHSV_ENCODER)         += flashsvenc.o
 +OBJS-$(CONFIG_FLASHSV2_ENCODER)        += flashsv2enc.o
  OBJS-$(CONFIG_FLASHSV2_DECODER)        += flashsv.o
  OBJS-$(CONFIG_FLIC_DECODER)            += flicvideo.o
  OBJS-$(CONFIG_FOURXM_DECODER)          += 4xm.o
  OBJS-$(CONFIG_FRAPS_DECODER)           += fraps.o
  OBJS-$(CONFIG_FRWU_DECODER)            += frwu.o
 +OBJS-$(CONFIG_G723_1_DECODER)          += g723_1.o acelp_vectors.o \
 +                                          celp_filters.o celp_math.o
 +OBJS-$(CONFIG_G723_1_ENCODER)          += g723_1.o
 +OBJS-$(CONFIG_G729_DECODER)            += g729dec.o lsp.o celp_math.o acelp_filters.o acelp_pitch_delay.o acelp_vectors.o g729postfilter.o
  OBJS-$(CONFIG_GIF_DECODER)             += gifdec.o lzw.o
  OBJS-$(CONFIG_GIF_ENCODER)             += gif.o lzwenc.o
  OBJS-$(CONFIG_GSM_DECODER)             += gsmdec.o gsmdec_data.o msgsmdec.o
@@@ -210,7 -190,6 +210,7 @@@ OBJS-$(CONFIG_H264_VDA_HWACCEL)        
  OBJS-$(CONFIG_HUFFYUV_DECODER)         += huffyuv.o
  OBJS-$(CONFIG_HUFFYUV_ENCODER)         += huffyuv.o
  OBJS-$(CONFIG_IDCIN_DECODER)           += idcinvideo.o
 +OBJS-$(CONFIG_IDF_DECODER)             += bintext.o cga_data.o
  OBJS-$(CONFIG_IFF_BYTERUN1_DECODER)    += iff.o
  OBJS-$(CONFIG_IFF_ILBM_DECODER)        += iff.o
  OBJS-$(CONFIG_IMC_DECODER)             += imc.o
@@@ -220,8 -199,6 +220,8 @@@ OBJS-$(CONFIG_INDEO4_DECODER)          
  OBJS-$(CONFIG_INDEO5_DECODER)          += indeo5.o ivi_common.o ivi_dsp.o
  OBJS-$(CONFIG_INTERPLAY_DPCM_DECODER)  += dpcm.o
  OBJS-$(CONFIG_INTERPLAY_VIDEO_DECODER) += interplayvideo.o
 +OBJS-$(CONFIG_JPEG2000_DECODER)        += j2kdec.o mqcdec.o mqc.o j2k.o j2k_dwt.o
 +OBJS-$(CONFIG_JPEG2000_ENCODER)        += j2kenc.o mqcenc.o mqc.o j2k.o j2k_dwt.o
  OBJS-$(CONFIG_JPEGLS_DECODER)          += jpeglsdec.o jpegls.o \
                                            mjpegdec.o mjpeg.o
  OBJS-$(CONFIG_JPEGLS_ENCODER)          += jpeglsenc.o jpegls.o
@@@ -278,13 -255,10 +278,13 @@@ OBJS-$(CONFIG_MPC7_DECODER)            
  OBJS-$(CONFIG_MPC8_DECODER)            += mpc8.o mpc.o mpegaudiodec.o      \
                                            mpegaudiodecheader.o mpegaudio.o \
                                            mpegaudiodata.o
 +OBJS-$(CONFIG_MPEGVIDEO_DECODER)       += mpeg12.o mpeg12data.o \
 +                                          mpegvideo.o error_resilience.o
  OBJS-$(CONFIG_MPEG_XVMC_DECODER)       += mpegvideo_xvmc.o
  OBJS-$(CONFIG_MPEG1VIDEO_DECODER)      += mpeg12.o mpeg12data.o \
                                            mpegvideo.o error_resilience.o
  OBJS-$(CONFIG_MPEG1VIDEO_ENCODER)      += mpeg12enc.o mpegvideo_enc.o \
 +                                          timecode.o                  \
                                            motion_est.o ratecontrol.o  \
                                            mpeg12.o mpeg12data.o       \
                                            mpegvideo.o error_resilience.o
@@@ -293,7 -267,6 +293,7 @@@ OBJS-$(CONFIG_MPEG2_VAAPI_HWACCEL)     
  OBJS-$(CONFIG_MPEG2VIDEO_DECODER)      += mpeg12.o mpeg12data.o \
                                            mpegvideo.o error_resilience.o
  OBJS-$(CONFIG_MPEG2VIDEO_ENCODER)      += mpeg12enc.o mpegvideo_enc.o \
 +                                          timecode.o                  \
                                            motion_est.o ratecontrol.o  \
                                            mpeg12.o mpeg12data.o       \
                                            mpegvideo.o error_resilience.o
@@@ -311,7 -284,6 +311,7 @@@ OBJS-$(CONFIG_MSMPEG4V3_ENCODER)       
                                            mpeg4videodec.o
  OBJS-$(CONFIG_MSRLE_DECODER)           += msrle.o msrledec.o
  OBJS-$(CONFIG_MSVIDEO1_DECODER)        += msvideo1.o
 +OBJS-$(CONFIG_MSVIDEO1_ENCODER)        += msvideo1enc.o elbg.o
  OBJS-$(CONFIG_MSZH_DECODER)            += lcldec.o
  OBJS-$(CONFIG_MXPEG_DECODER)           += mxpegdec.o mjpegdec.o mjpeg.o
  OBJS-$(CONFIG_NELLYMOSER_DECODER)      += nellymoserdec.o nellymoser.o
@@@ -334,11 -306,8 +334,11 @@@ OBJS-$(CONFIG_PNG_DECODER)             
  OBJS-$(CONFIG_PNG_ENCODER)             += png.o pngenc.o
  OBJS-$(CONFIG_PPM_DECODER)             += pnmdec.o pnm.o
  OBJS-$(CONFIG_PPM_ENCODER)             += pnmenc.o pnm.o
 -OBJS-$(CONFIG_PRORES_DECODER)          += proresdec.o proresdata.o proresdsp.o
 -OBJS-$(CONFIG_PRORES_ENCODER)          += proresenc.o proresdata.o proresdsp.o
 +OBJS-$(CONFIG_PRORES_DECODER)          += proresdec2.o
 +OBJS-$(CONFIG_PRORES_LGPL_DECODER)     += proresdec_lgpl.o proresdsp.o proresdata.o
 +OBJS-$(CONFIG_PRORES_ENCODER)          += proresenc_anatoliy.o
 +OBJS-$(CONFIG_PRORES_ANATOLIY_ENCODER) += proresenc_anatoliy.o
 +OBJS-$(CONFIG_PRORES_KOSTYA_ENCODER)   += proresenc_kostya.o proresdata.o proresdsp.o
  OBJS-$(CONFIG_PTX_DECODER)             += ptx.o
  OBJS-$(CONFIG_QCELP_DECODER)           += qcelpdec.o celp_math.o         \
                                            celp_filters.o acelp_vectors.o \
@@@ -351,9 -320,7 +351,9 @@@ OBJS-$(CONFIG_QPEG_DECODER)            
  OBJS-$(CONFIG_QTRLE_DECODER)           += qtrle.o
  OBJS-$(CONFIG_QTRLE_ENCODER)           += qtrleenc.o
  OBJS-$(CONFIG_R10K_DECODER)            += r210dec.o
 +OBJS-$(CONFIG_R10K_ENCODER)            += r210enc.o
  OBJS-$(CONFIG_R210_DECODER)            += r210dec.o
 +OBJS-$(CONFIG_R210_ENCODER)            += r210enc.o
  OBJS-$(CONFIG_RA_144_DECODER)          += ra144dec.o ra144.o celp_filters.o
  OBJS-$(CONFIG_RA_144_ENCODER)          += ra144enc.o ra144.o celp_filters.o \
                                            audio_frame_queue.o
@@@ -393,12 -360,8 +393,12 @@@ OBJS-$(CONFIG_SNOW_ENCODER)            
                                            error_resilience.o ituh263enc.o  \
                                            mpegvideo_enc.o mpeg12data.o
  OBJS-$(CONFIG_SOL_DPCM_DECODER)        += dpcm.o
 +OBJS-$(CONFIG_SONIC_DECODER)           += sonic.o
 +OBJS-$(CONFIG_SONIC_ENCODER)           += sonic.o
 +OBJS-$(CONFIG_SONIC_LS_ENCODER)        += sonic.o
  OBJS-$(CONFIG_SP5X_DECODER)            += sp5xdec.o mjpegdec.o mjpeg.o
  OBJS-$(CONFIG_SRT_DECODER)             += srtdec.o ass.o
 +OBJS-$(CONFIG_SRT_ENCODER)             += srtenc.o ass_split.o
  OBJS-$(CONFIG_SUNRAST_DECODER)         += sunrast.o
  OBJS-$(CONFIG_SUNRAST_ENCODER)         += sunrastenc.o
  OBJS-$(CONFIG_SVQ1_DECODER)            += svq1dec.o svq1.o h263.o \
@@@ -433,10 -396,6 +433,10 @@@ OBJS-$(CONFIG_ULTI_DECODER)            
  OBJS-$(CONFIG_UTVIDEO_DECODER)         += utvideo.o
  OBJS-$(CONFIG_V210_DECODER)            += v210dec.o
  OBJS-$(CONFIG_V210_ENCODER)            += v210enc.o
 +OBJS-$(CONFIG_V308_DECODER)            += v308dec.o
 +OBJS-$(CONFIG_V308_ENCODER)            += v308enc.o
 +OBJS-$(CONFIG_V408_DECODER)            += v408dec.o
 +OBJS-$(CONFIG_V408_ENCODER)            += v408enc.o
  OBJS-$(CONFIG_V410_DECODER)            += v410dec.o
  OBJS-$(CONFIG_V410_ENCODER)            += v410enc.o
  OBJS-$(CONFIG_V210X_DECODER)           += v210x.o
@@@ -485,19 -444,13 +485,19 @@@ OBJS-$(CONFIG_WS_SND1_DECODER)         
  OBJS-$(CONFIG_XAN_DPCM_DECODER)        += dpcm.o
  OBJS-$(CONFIG_XAN_WC3_DECODER)         += xan.o
  OBJS-$(CONFIG_XAN_WC4_DECODER)         += xxan.o
 +OBJS-$(CONFIG_XBIN_DECODER)            += bintext.o cga_data.o
 +OBJS-$(CONFIG_XBM_DECODER)             += xbmdec.o
  OBJS-$(CONFIG_XBM_ENCODER)             += xbmenc.o
  OBJS-$(CONFIG_XL_DECODER)              += xl.o
  OBJS-$(CONFIG_XSUB_DECODER)            += xsubdec.o
  OBJS-$(CONFIG_XSUB_ENCODER)            += xsubenc.o
  OBJS-$(CONFIG_XWD_DECODER)             += xwddec.o
  OBJS-$(CONFIG_XWD_ENCODER)             += xwdenc.o
 +OBJS-$(CONFIG_Y41P_DECODER)            += y41pdec.o
 +OBJS-$(CONFIG_Y41P_ENCODER)            += y41penc.o
  OBJS-$(CONFIG_YOP_DECODER)             += yop.o
 +OBJS-$(CONFIG_YUV4_DECODER)            += yuv4dec.o
 +OBJS-$(CONFIG_YUV4_ENCODER)            += yuv4enc.o
  OBJS-$(CONFIG_ZEROCODEC_DECODER)       += zerocodec.o
  OBJS-$(CONFIG_ZLIB_DECODER)            += lcldec.o
  OBJS-$(CONFIG_ZLIB_ENCODER)            += lclenc.o
@@@ -599,40 -552,36 +599,40 @@@ OBJS-$(CONFIG_ADTS_MUXER)              
  OBJS-$(CONFIG_ADX_DEMUXER)             += adx.o
  OBJS-$(CONFIG_CAF_DEMUXER)             += mpeg4audio.o mpegaudiodata.o
  OBJS-$(CONFIG_DV_DEMUXER)              += dvdata.o
 -OBJS-$(CONFIG_DV_MUXER)                += dvdata.o
 -OBJS-$(CONFIG_FLAC_DEMUXER)            += flacdec.o flacdata.o flac.o
 -OBJS-$(CONFIG_FLAC_MUXER)              += flacdec.o flacdata.o flac.o
 +OBJS-$(CONFIG_DV_MUXER)                += dvdata.o timecode.o
 +OBJS-$(CONFIG_FLAC_DEMUXER)            += flacdec.o flacdata.o flac.o vorbis_data.o
 +OBJS-$(CONFIG_FLAC_MUXER)              += flacdec.o flacdata.o flac.o vorbis_data.o
  OBJS-$(CONFIG_FLV_DEMUXER)             += mpeg4audio.o
  OBJS-$(CONFIG_GXF_DEMUXER)             += mpeg12data.o
  OBJS-$(CONFIG_IFF_DEMUXER)             += iff.o
  OBJS-$(CONFIG_LATM_MUXER)              += mpeg4audio.o
 -OBJS-$(CONFIG_MATROSKA_AUDIO_MUXER)    += xiph.o mpeg4audio.o \
 +OBJS-$(CONFIG_MATROSKA_AUDIO_MUXER)    += xiph.o mpeg4audio.o vorbis_data.o \
                                            flacdec.o flacdata.o flac.o
  OBJS-$(CONFIG_MATROSKA_DEMUXER)        += mpeg4audio.o mpegaudiodata.o
  OBJS-$(CONFIG_MATROSKA_MUXER)          += xiph.o mpeg4audio.o \
                                            flacdec.o flacdata.o flac.o \
 -                                          mpegaudiodata.o
 +                                          mpegaudiodata.o vorbis_data.o
  OBJS-$(CONFIG_MP3_MUXER)               += mpegaudiodata.o mpegaudiodecheader.o
 -OBJS-$(CONFIG_MOV_DEMUXER)             += mpeg4audio.o mpegaudiodata.o ac3tab.o
 +OBJS-$(CONFIG_MOV_DEMUXER)             += mpeg4audio.o mpegaudiodata.o ac3tab.o timecode.o
  OBJS-$(CONFIG_MOV_MUXER)               += mpeg4audio.o mpegaudiodata.o
  OBJS-$(CONFIG_MPEGTS_MUXER)            += mpegvideo.o mpeg4audio.o
  OBJS-$(CONFIG_MPEGTS_DEMUXER)          += mpeg4audio.o mpegaudiodata.o
 +OBJS-$(CONFIG_MXF_MUXER)               += timecode.o
  OBJS-$(CONFIG_NUT_MUXER)               += mpegaudiodata.o
  OBJS-$(CONFIG_OGG_DEMUXER)             += flacdec.o flacdata.o flac.o \
 -                                          dirac.o mpeg12data.o vorbis_parser.o
 -OBJS-$(CONFIG_OGG_MUXER)               += xiph.o flacdec.o flacdata.o flac.o
 +                                          dirac.o mpeg12data.o vorbis_parser.o vorbis_data.o
 +OBJS-$(CONFIG_OGG_MUXER)               += xiph.o flacdec.o flacdata.o flac.o \
 +                                          vorbis_data.o
  OBJS-$(CONFIG_RTP_MUXER)               += mpeg4audio.o mpegvideo.o xiph.o
  OBJS-$(CONFIG_SPDIF_DEMUXER)           += aacadtsdec.o mpeg4audio.o
  OBJS-$(CONFIG_WEBM_MUXER)              += xiph.o mpeg4audio.o \
                                            flacdec.o flacdata.o flac.o \
 -                                          mpegaudiodata.o
 +                                          mpegaudiodata.o vorbis_data.o
  OBJS-$(CONFIG_WTV_DEMUXER)             += mpeg4audio.o mpegaudiodata.o
  
  # external codec libraries
 +OBJS-$(CONFIG_LIBAACPLUS_ENCODER)         += libaacplus.o
 +OBJS-$(CONFIG_LIBCELT_DECODER)            += libcelt_dec.o
  OBJS-$(CONFIG_LIBDIRAC_DECODER)           += libdiracdec.o
  OBJS-$(CONFIG_LIBFAAC_ENCODER)            += libfaac.o audio_frame_queue.o
  OBJS-$(CONFIG_LIBGSM_DECODER)             += libgsm.o
@@@ -644,8 -593,7 +644,8 @@@ OBJS-$(CONFIG_LIBMP3LAME_ENCODER
  OBJS-$(CONFIG_LIBOPENCORE_AMRNB_DECODER)  += libopencore-amr.o
  OBJS-$(CONFIG_LIBOPENCORE_AMRNB_ENCODER)  += libopencore-amr.o
  OBJS-$(CONFIG_LIBOPENCORE_AMRWB_DECODER)  += libopencore-amr.o
 -OBJS-$(CONFIG_LIBOPENJPEG_DECODER)        += libopenjpeg.o
 +OBJS-$(CONFIG_LIBOPENJPEG_DECODER)        += libopenjpegdec.o
 +OBJS-$(CONFIG_LIBOPENJPEG_ENCODER)        += libopenjpegenc.o
  OBJS-$(CONFIG_LIBSCHROEDINGER_DECODER)    += libschroedingerdec.o \
                                               libschroedinger.o    \
                                               libdirac_libschro.o
@@@ -654,10 -602,7 +654,10 @@@ OBJS-$(CONFIG_LIBSCHROEDINGER_ENCODER
                                               libdirac_libschro.o
  OBJS-$(CONFIG_LIBSPEEX_DECODER)           += libspeexdec.o
  OBJS-$(CONFIG_LIBSPEEX_ENCODER)           += libspeexenc.o audio_frame_queue.o
 +OBJS-$(CONFIG_LIBSTAGEFRIGHT_H264_DECODER)+= libstagefright.o
  OBJS-$(CONFIG_LIBTHEORA_ENCODER)          += libtheoraenc.o
 +OBJS-$(CONFIG_LIBUTVIDEO_DECODER)         += libutvideodec.o
 +OBJS-$(CONFIG_LIBUTVIDEO_ENCODER)         += libutvideoenc.o
  OBJS-$(CONFIG_LIBVO_AACENC_ENCODER)       += libvo-aacenc.o mpeg4audio.o
  OBJS-$(CONFIG_LIBVO_AMRWBENC_ENCODER)     += libvo-amrwbenc.o
  OBJS-$(CONFIG_LIBVORBIS_ENCODER)          += libvorbis.o audio_frame_queue.o \
@@@ -680,8 -625,7 +680,8 @@@ OBJS-$(CONFIG_DIRAC_PARSER)            
  OBJS-$(CONFIG_DNXHD_PARSER)            += dnxhd_parser.o
  OBJS-$(CONFIG_DVBSUB_PARSER)           += dvbsub_parser.o
  OBJS-$(CONFIG_DVDSUB_PARSER)           += dvdsub_parser.o
 -OBJS-$(CONFIG_FLAC_PARSER)             += flac_parser.o flacdata.o flac.o
 +OBJS-$(CONFIG_FLAC_PARSER)             += flac_parser.o flacdata.o flac.o \
 +                                          vorbis_data.o
  OBJS-$(CONFIG_GSM_PARSER)              += gsm_parser.o
  OBJS-$(CONFIG_H261_PARSER)             += h261_parser.o
  OBJS-$(CONFIG_H263_PARSER)             += h263_parser.o
@@@ -733,7 -677,6 +733,7 @@@ OBJS-$(CONFIG_TEXT2MOVSUB_BSF
  # thread libraries
  OBJS-$(HAVE_PTHREADS)                  += pthread.o
  OBJS-$(HAVE_W32THREADS)                += pthread.o
 +OBJS-$(HAVE_OS2THREADS)                += pthread.o
  
  # inverse.o contains the ff_inverse table definition, which is used by
  # the FASTDIV macro (from libavutil); since referencing the external
@@@ -752,11 -695,13 +752,11 @@@ SKIPHEADERS-$(CONFIG_LIBDIRAC)         
  SKIPHEADERS-$(CONFIG_LIBSCHROEDINGER)  += libschroedinger.h
  SKIPHEADERS-$(CONFIG_MPEG_XVMC_DECODER) += xvmc.h
  SKIPHEADERS-$(CONFIG_VAAPI)            += vaapi_internal.h
 -SKIPHEADERS-$(CONFIG_VDA)              += vda.h vda_internal.h
 +SKIPHEADERS-$(CONFIG_VDA)              += vda_internal.h
  SKIPHEADERS-$(CONFIG_VDPAU)            += vdpau.h
  SKIPHEADERS-$(HAVE_W32THREADS)         += w32pthreads.h
  
 -EXAMPLES = api
 -
 -TESTPROGS = cabac dct fft fft-fixed golomb iirfilter rangecoder
 +TESTPROGS = cabac dct fft fft-fixed golomb iirfilter rangecoder snowenc
  TESTPROGS-$(HAVE_MMX) += motion
  TESTOBJS = dctref.o
  
@@@ -800,10 -745,3 +800,10 @@@ $(SUBDIR)motionpixels.o: $(SUBDIR)motio
  $(SUBDIR)pcm.o: $(SUBDIR)pcm_tables.h
  $(SUBDIR)qdm2.o: $(SUBDIR)qdm2_tables.h
  endif
 +
 +CODEC_NAMES_SH := $(SRC_PATH)/$(SUBDIR)codec_names.sh
 +AVCODEC_H      := $(SRC_PATH)/$(SUBDIR)avcodec.h
 +$(SUBDIR)codec_names.h: $(CODEC_NAMES_SH) config.h $(AVCODEC_H)
 +      $(CC) $(CPPFLAGS) $(CFLAGS) -E $(AVCODEC_H) | \
 +      $(CODEC_NAMES_SH) config.h $@
 +$(SUBDIR)utils.o: $(SUBDIR)codec_names.h
diff --combined libavcodec/dv.c
   * Many thanks to Dan Dennedy <dan@dennedy.org> for providing wealth
   * of DV technical info.
   *
 - * 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
   */
  
  #include "dvquant.h"
  #include "dv_tablegen.h"
  
- //#undef NDEBUG
- //#include <assert.h>
- typedef struct DVVideoContext {
-     const DVprofile *sys;
-     AVFrame          picture;
-     AVCodecContext  *avctx;
-     uint8_t         *buf;
-     uint8_t  dv_zigzag[2][64];
-     void (*get_pixels)(DCTELEM *block, const uint8_t *pixels, int line_size);
-     void (*fdct[2])(DCTELEM *block);
-     void (*idct_put[2])(uint8_t *dest, int line_size, DCTELEM *block);
-     me_cmp_func ildct_cmp;
- } DVVideoContext;
- #define TEX_VLC_BITS 9
  /* XXX: also include quantization */
- static RL_VLC_ELEM dv_rl_vlc[1184];
- static inline int dv_work_pool_size(const DVprofile *d)
- {
-     int size = d->n_difchan*d->difseg_size*27;
-     if (DV_PROFILE_IS_1080i50(d))
-         size -= 3*27;
-     if (DV_PROFILE_IS_720p50(d))
-         size -= 4*27;
-     return size;
- }
+ RL_VLC_ELEM ff_dv_rl_vlc[1184];
  
  static inline void dv_calc_mb_coordinates(const DVprofile *d, int chan, int seq, int slot,
                                            uint16_t *tbl)
      }
  }
  
static int dv_init_dynamic_tables(const DVprofile *d)
int ff_dv_init_dynamic_tables(const DVprofile *d)
  {
      int j,i,c,s,p;
      uint32_t *factor1, *factor2;
      return 0;
  }
  
static av_cold int dvvideo_init(AVCodecContext *avctx)
av_cold int ff_dvvideo_init(AVCodecContext *avctx)
  {
      DVVideoContext *s = avctx->priv_data;
      DSPContext dsp;
                  run   = new_dv_vlc_run  [code] + 1;
                  level = new_dv_vlc_level[code];
              }
-             dv_rl_vlc[i].len   = len;
-             dv_rl_vlc[i].level = level;
-             dv_rl_vlc[i].run   = run;
+             ff_dv_rl_vlc[i].len   = len;
+             ff_dv_rl_vlc[i].level = level;
+             ff_dv_rl_vlc[i].run   = run;
          }
          ff_free_vlc(&dv_vlc);
  
@@@ -357,19 -328,9 +328,9 @@@ static av_cold int dvvideo_init_encoder
          return -1;
      }
  
-     return dvvideo_init(avctx);
+     return ff_dvvideo_init(avctx);
  }
  
- typedef struct BlockInfo {
-     const uint32_t *factor_table;
-     const uint8_t *scan_table;
-     uint8_t pos; /* position in block */
-     void (*idct_put)(uint8_t *dest, int line_size, DCTELEM *block);
-     uint8_t partial_bit_count;
-     uint32_t partial_bit_buffer;
-     int shift_offset;
- } BlockInfo;
  /* bit budget for AC only in 5 MBs */
  static const int vs_total_ac_bits = (100 * 4 + 68*2) * 5;
  static const int mb_area_start[5] = { 1, 6, 21, 43, 64 };
@@@ -379,268 -340,6 +340,6 @@@ static inline int put_bits_left(PutBitC
      return (s->buf_end - s->buf) * 8 - put_bits_count(s);
  }
  
- /* decode AC coefficients */
- static void dv_decode_ac(GetBitContext *gb, BlockInfo *mb, DCTELEM *block)
- {
-     int last_index = gb->size_in_bits;
-     const uint8_t  *scan_table   = mb->scan_table;
-     const uint32_t *factor_table = mb->factor_table;
-     int pos               = mb->pos;
-     int partial_bit_count = mb->partial_bit_count;
-     int level, run, vlc_len, index;
-     OPEN_READER(re, gb);
-     UPDATE_CACHE(re, gb);
-     /* if we must parse a partial VLC, we do it here */
-     if (partial_bit_count > 0) {
-         re_cache = re_cache >> partial_bit_count | mb->partial_bit_buffer;
-         re_index -= partial_bit_count;
-         mb->partial_bit_count = 0;
-     }
-     /* get the AC coefficients until last_index is reached */
-     for (;;) {
-         av_dlog(NULL, "%2d: bits=%04x index=%d\n", pos, SHOW_UBITS(re, gb, 16),
-                 re_index);
-         /* our own optimized GET_RL_VLC */
-         index   = NEG_USR32(re_cache, TEX_VLC_BITS);
-         vlc_len = dv_rl_vlc[index].len;
-         if (vlc_len < 0) {
-             index = NEG_USR32((unsigned)re_cache << TEX_VLC_BITS, -vlc_len) + dv_rl_vlc[index].level;
-             vlc_len = TEX_VLC_BITS - vlc_len;
-         }
-         level = dv_rl_vlc[index].level;
-         run   = dv_rl_vlc[index].run;
-         /* gotta check if we're still within gb boundaries */
-         if (re_index + vlc_len > last_index) {
-             /* should be < 16 bits otherwise a codeword could have been parsed */
-             mb->partial_bit_count = last_index - re_index;
-             mb->partial_bit_buffer = re_cache & ~(-1u >> mb->partial_bit_count);
-             re_index = last_index;
-             break;
-         }
-         re_index += vlc_len;
-         av_dlog(NULL, "run=%d level=%d\n", run, level);
-         pos += run;
-         if (pos >= 64)
-             break;
-         level = (level * factor_table[pos] + (1 << (dv_iweight_bits - 1))) >> dv_iweight_bits;
-         block[scan_table[pos]] = level;
-         UPDATE_CACHE(re, gb);
-     }
-     CLOSE_READER(re, gb);
-     mb->pos = pos;
- }
- static inline void bit_copy(PutBitContext *pb, GetBitContext *gb)
- {
-     int bits_left = get_bits_left(gb);
-     while (bits_left >= MIN_CACHE_BITS) {
-         put_bits(pb, MIN_CACHE_BITS, get_bits(gb, MIN_CACHE_BITS));
-         bits_left -= MIN_CACHE_BITS;
-     }
-     if (bits_left > 0) {
-         put_bits(pb, bits_left, get_bits(gb, bits_left));
-     }
- }
- static inline void dv_calculate_mb_xy(DVVideoContext *s, DVwork_chunk *work_chunk, int m, int *mb_x, int *mb_y)
- {
-      *mb_x = work_chunk->mb_coordinates[m] & 0xff;
-      *mb_y = work_chunk->mb_coordinates[m] >> 8;
-      /* We work with 720p frames split in half. The odd half-frame (chan==2,3) is displaced :-( */
-      if (s->sys->height == 720 && !(s->buf[1]&0x0C)) {
-          *mb_y -= (*mb_y>17)?18:-72; /* shifting the Y coordinate down by 72/2 macro blocks */
-      }
- }
- /* mb_x and mb_y are in units of 8 pixels */
- static int dv_decode_video_segment(AVCodecContext *avctx, void *arg)
- {
-     DVVideoContext *s = avctx->priv_data;
-     DVwork_chunk *work_chunk = arg;
-     int quant, dc, dct_mode, class1, j;
-     int mb_index, mb_x, mb_y, last_index;
-     int y_stride, linesize;
-     DCTELEM *block, *block1;
-     int c_offset;
-     uint8_t *y_ptr;
-     const uint8_t *buf_ptr;
-     PutBitContext pb, vs_pb;
-     GetBitContext gb;
-     BlockInfo mb_data[5 * DV_MAX_BPM], *mb, *mb1;
-     LOCAL_ALIGNED_16(DCTELEM, sblock, [5*DV_MAX_BPM], [64]);
-     LOCAL_ALIGNED_16(uint8_t, mb_bit_buffer, [  80 + FF_INPUT_BUFFER_PADDING_SIZE]); /* allow some slack */
-     LOCAL_ALIGNED_16(uint8_t, vs_bit_buffer, [5*80 + FF_INPUT_BUFFER_PADDING_SIZE]); /* allow some slack */
-     const int log2_blocksize = 3-s->avctx->lowres;
-     int is_field_mode[5];
-     assert((((int)mb_bit_buffer) & 7) == 0);
-     assert((((int)vs_bit_buffer) & 7) == 0);
-     memset(sblock, 0, 5*DV_MAX_BPM*sizeof(*sblock));
-     /* pass 1: read DC and AC coefficients in blocks */
-     buf_ptr = &s->buf[work_chunk->buf_offset*80];
-     block1  = &sblock[0][0];
-     mb1     = mb_data;
-     init_put_bits(&vs_pb, vs_bit_buffer, 5 * 80);
-     for (mb_index = 0; mb_index < 5; mb_index++, mb1 += s->sys->bpm, block1 += s->sys->bpm * 64) {
-         /* skip header */
-         quant = buf_ptr[3] & 0x0f;
-         buf_ptr += 4;
-         init_put_bits(&pb, mb_bit_buffer, 80);
-         mb    = mb1;
-         block = block1;
-         is_field_mode[mb_index] = 0;
-         for (j = 0; j < s->sys->bpm; j++) {
-             last_index = s->sys->block_sizes[j];
-             init_get_bits(&gb, buf_ptr, last_index);
-             /* get the DC */
-             dc       = get_sbits(&gb, 9);
-             dct_mode = get_bits1(&gb);
-             class1   = get_bits(&gb, 2);
-             if (DV_PROFILE_IS_HD(s->sys)) {
-                 mb->idct_put     = s->idct_put[0];
-                 mb->scan_table   = s->dv_zigzag[0];
-                 mb->factor_table = &s->sys->idct_factor[(j >= 4)*4*16*64 + class1*16*64 + quant*64];
-                 is_field_mode[mb_index] |= !j && dct_mode;
-             } else {
-                 mb->idct_put     = s->idct_put[dct_mode && log2_blocksize == 3];
-                 mb->scan_table   = s->dv_zigzag[dct_mode];
-                 mb->factor_table = &s->sys->idct_factor[(class1 == 3)*2*22*64 + dct_mode*22*64 +
-                                                         (quant + dv_quant_offset[class1])*64];
-             }
-             dc = dc << 2;
-             /* convert to unsigned because 128 is not added in the
-                standard IDCT */
-             dc += 1024;
-             block[0] = dc;
-             buf_ptr += last_index >> 3;
-             mb->pos               = 0;
-             mb->partial_bit_count = 0;
-             av_dlog(avctx, "MB block: %d, %d ", mb_index, j);
-             dv_decode_ac(&gb, mb, block);
-             /* write the remaining bits in a new buffer only if the
-                block is finished */
-             if (mb->pos >= 64)
-                 bit_copy(&pb, &gb);
-             block += 64;
-             mb++;
-         }
-         /* pass 2: we can do it just after */
-         av_dlog(avctx, "***pass 2 size=%d MB#=%d\n", put_bits_count(&pb), mb_index);
-         block = block1;
-         mb    = mb1;
-         init_get_bits(&gb, mb_bit_buffer, put_bits_count(&pb));
-         put_bits32(&pb, 0); // padding must be zeroed
-         flush_put_bits(&pb);
-         for (j = 0; j < s->sys->bpm; j++, block += 64, mb++) {
-             if (mb->pos < 64 && get_bits_left(&gb) > 0) {
-                 dv_decode_ac(&gb, mb, block);
-                 /* if still not finished, no need to parse other blocks */
-                 if (mb->pos < 64)
-                     break;
-             }
-         }
-         /* all blocks are finished, so the extra bytes can be used at
-            the video segment level */
-         if (j >= s->sys->bpm)
-             bit_copy(&vs_pb, &gb);
-     }
-     /* we need a pass over the whole video segment */
-     av_dlog(avctx, "***pass 3 size=%d\n", put_bits_count(&vs_pb));
-     block = &sblock[0][0];
-     mb    = mb_data;
-     init_get_bits(&gb, vs_bit_buffer, put_bits_count(&vs_pb));
-     put_bits32(&vs_pb, 0); // padding must be zeroed
-     flush_put_bits(&vs_pb);
-     for (mb_index = 0; mb_index < 5; mb_index++) {
-         for (j = 0; j < s->sys->bpm; j++) {
-             if (mb->pos < 64) {
-                 av_dlog(avctx, "start %d:%d\n", mb_index, j);
-                 dv_decode_ac(&gb, mb, block);
-             }
-             if (mb->pos >= 64 && mb->pos < 127)
-                 av_log(avctx, AV_LOG_ERROR, "AC EOB marker is absent pos=%d\n", mb->pos);
-             block += 64;
-             mb++;
-         }
-     }
-     /* compute idct and place blocks */
-     block = &sblock[0][0];
-     mb    = mb_data;
-     for (mb_index = 0; mb_index < 5; mb_index++) {
-         dv_calculate_mb_xy(s, work_chunk, mb_index, &mb_x, &mb_y);
-         /* idct_put'ting luminance */
-         if ((s->sys->pix_fmt == PIX_FMT_YUV420P) ||
-             (s->sys->pix_fmt == PIX_FMT_YUV411P && mb_x >= (704 / 8)) ||
-             (s->sys->height >= 720 && mb_y != 134)) {
-             y_stride = (s->picture.linesize[0] << ((!is_field_mode[mb_index]) * log2_blocksize));
-         } else {
-             y_stride = (2 << log2_blocksize);
-         }
-         y_ptr = s->picture.data[0] + ((mb_y * s->picture.linesize[0] + mb_x) << log2_blocksize);
-         linesize = s->picture.linesize[0] << is_field_mode[mb_index];
-         mb[0]    .idct_put(y_ptr                                   , linesize, block + 0*64);
-         if (s->sys->video_stype == 4) { /* SD 422 */
-             mb[2].idct_put(y_ptr + (1 << log2_blocksize)           , linesize, block + 2*64);
-         } else {
-             mb[1].idct_put(y_ptr + (1 << log2_blocksize)           , linesize, block + 1*64);
-             mb[2].idct_put(y_ptr                         + y_stride, linesize, block + 2*64);
-             mb[3].idct_put(y_ptr + (1 << log2_blocksize) + y_stride, linesize, block + 3*64);
-         }
-         mb += 4;
-         block += 4*64;
-         /* idct_put'ting chrominance */
-         c_offset = (((mb_y >>  (s->sys->pix_fmt == PIX_FMT_YUV420P)) * s->picture.linesize[1] +
-                      (mb_x >> ((s->sys->pix_fmt == PIX_FMT_YUV411P) ? 2 : 1))) << log2_blocksize);
-         for (j = 2; j; j--) {
-             uint8_t *c_ptr = s->picture.data[j] + c_offset;
-             if (s->sys->pix_fmt == PIX_FMT_YUV411P && mb_x >= (704 / 8)) {
-                   uint64_t aligned_pixels[64/8];
-                   uint8_t *pixels = (uint8_t*)aligned_pixels;
-                   uint8_t *c_ptr1, *ptr1;
-                   int x, y;
-                   mb->idct_put(pixels, 8, block);
-                   for (y = 0; y < (1 << log2_blocksize); y++, c_ptr += s->picture.linesize[j], pixels += 8) {
-                       ptr1   = pixels + (1 << (log2_blocksize - 1));
-                       c_ptr1 = c_ptr + (s->picture.linesize[j] << log2_blocksize);
-                       for (x = 0; x < (1 << (log2_blocksize - 1)); x++) {
-                           c_ptr[x]  = pixels[x];
-                           c_ptr1[x] = ptr1[x];
-                       }
-                   }
-                   block += 64; mb++;
-             } else {
-                   y_stride = (mb_y == 134) ? (1 << log2_blocksize) :
-                                              s->picture.linesize[j] << ((!is_field_mode[mb_index]) * log2_blocksize);
-                   linesize = s->picture.linesize[j] << is_field_mode[mb_index];
-                   (mb++)->    idct_put(c_ptr           , linesize, block); block += 64;
-                   if (s->sys->bpm == 8) {
-                       (mb++)->idct_put(c_ptr + y_stride, linesize, block); block += 64;
-                   }
-             }
-         }
-     }
-     return 0;
- }
  #if CONFIG_SMALL
  /* Converts run and level (where level != 0) pair into VLC, returning bit size */
  static av_always_inline int dv_rl2vlc(int run, int level, int sign, uint32_t* vlc)
@@@ -776,7 -475,7 +475,7 @@@ static av_always_inline int dv_init_enc
         method suggested in SMPTE 314M Table 22, and an improved
         method. The SMPTE method is very conservative; it assigns class
         3 (i.e. severe quantization) to any block where the largest AC
 -       component is greater than 36. Libav's DV encoder tracks AC bit
 +       component is greater than 36. FFmpeg's DV encoder tracks AC bit
         consumption precisely, so there is no need to bias most blocks
         towards strongly lossy compression. Instead, we assign class 2
         to most blocks, and use class 3 only when strictly necessary
  
  #if 0 /* SMPTE spec method */
      static const int classes[] = {12, 24, 36, 0xffff};
 -#else /* improved Libav method */
 +#else /* improved FFmpeg method */
      static const int classes[] = {-1, -1, 255, 0xffff};
  #endif
      int max  = classes[0];
@@@ -1060,65 -759,6 +759,6 @@@ static int dv_encode_video_segment(AVCo
      return 0;
  }
  
- #if CONFIG_DVVIDEO_DECODER
- /* NOTE: exactly one frame must be given (120000 bytes for NTSC,
-    144000 bytes for PAL - or twice those for 50Mbps) */
- static int dvvideo_decode_frame(AVCodecContext *avctx,
-                                  void *data, int *data_size,
-                                  AVPacket *avpkt)
- {
-     const uint8_t *buf = avpkt->data;
-     int buf_size = avpkt->size;
-     DVVideoContext *s = avctx->priv_data;
-     const uint8_t* vsc_pack;
-     int apt, is16_9;
-     s->sys = avpriv_dv_frame_profile2(avctx, s->sys, buf, buf_size);
-     if (!s->sys || buf_size < s->sys->frame_size || dv_init_dynamic_tables(s->sys)) {
-         av_log(avctx, AV_LOG_ERROR, "could not find dv frame profile\n");
-         return -1; /* NOTE: we only accept several full frames */
-     }
-     if (s->picture.data[0])
-         avctx->release_buffer(avctx, &s->picture);
-     avcodec_get_frame_defaults(&s->picture);
-     s->picture.reference = 0;
-     s->picture.key_frame = 1;
-     s->picture.pict_type = AV_PICTURE_TYPE_I;
-     avctx->pix_fmt   = s->sys->pix_fmt;
-     avctx->time_base = s->sys->time_base;
-     avcodec_set_dimensions(avctx, s->sys->width, s->sys->height);
-     if (avctx->get_buffer(avctx, &s->picture) < 0) {
-         av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
-         return -1;
-     }
-     s->picture.interlaced_frame = 1;
-     s->picture.top_field_first  = 0;
-     s->buf = buf;
-     avctx->execute(avctx, dv_decode_video_segment, s->sys->work_chunks, NULL,
-                    dv_work_pool_size(s->sys), sizeof(DVwork_chunk));
-     emms_c();
-     /* return image */
-     *data_size = sizeof(AVFrame);
-     *(AVFrame*)data = s->picture;
-     /* Determine the codec's sample_aspect ratio from the packet */
-     vsc_pack = buf + 80*5 + 48 + 5;
-     if ( *vsc_pack == dv_video_control ) {
-         apt = buf[4] & 0x07;
-         is16_9 = (vsc_pack[2] & 0x07) == 0x02 || (!apt && (vsc_pack[2] & 0x07) == 0x07);
-         avctx->sample_aspect_ratio = s->sys->sar[is16_9];
-     }
-     return s->sys->frame_size;
- }
- #endif /* CONFIG_DVVIDEO_DECODER */
  static inline int dv_write_pack(enum dv_pack_type pack_id, DVVideoContext *c,
                                  uint8_t* buf)
  {
@@@ -1284,10 -924,12 +924,10 @@@ static int dvvideo_encode_frame(AVCodec
      int ret;
  
      s->sys = avpriv_dv_codec_profile(c);
-     if (!s->sys || dv_init_dynamic_tables(s->sys))
+     if (!s->sys || ff_dv_init_dynamic_tables(s->sys))
          return -1;
 -    if ((ret = ff_alloc_packet(pkt, s->sys->frame_size)) < 0) {
 -        av_log(c, AV_LOG_ERROR, "Error getting output packet.\n");
 +    if ((ret = ff_alloc_packet2(c, pkt, s->sys->frame_size)) < 0)
          return ret;
 -    }
  
      c->pix_fmt           = s->sys->pix_fmt;
      s->picture           = *frame;
  
      return 0;
  }
- #endif
- static int dvvideo_close(AVCodecContext *c)
- {
-     DVVideoContext *s = c->priv_data;
-     if (s->picture.data[0])
-         c->release_buffer(c, &s->picture);
  
-     return 0;
- }
- #if CONFIG_DVVIDEO_ENCODER
  AVCodec ff_dvvideo_encoder = {
      .name           = "dvvideo",
      .type           = AVMEDIA_TYPE_VIDEO,
      .long_name = NULL_IF_CONFIG_SMALL("DV (Digital Video)"),
  };
  #endif // CONFIG_DVVIDEO_ENCODER
- #if CONFIG_DVVIDEO_DECODER
- AVCodec ff_dvvideo_decoder = {
-     .name           = "dvvideo",
-     .type           = AVMEDIA_TYPE_VIDEO,
-     .id             = CODEC_ID_DVVIDEO,
-     .priv_data_size = sizeof(DVVideoContext),
-     .init           = dvvideo_init,
-     .close          = dvvideo_close,
-     .decode         = dvvideo_decode_frame,
-     .capabilities   = CODEC_CAP_DR1 | CODEC_CAP_SLICE_THREADS,
-     .max_lowres = 3,
-     .long_name = NULL_IF_CONFIG_SMALL("DV (Digital Video)"),
- };
- #endif
diff --combined libavcodec/dv_tablegen.h
@@@ -3,20 -3,20 +3,20 @@@
   *
   * Copyright (c) 2010 Reimar Döffinger <Reimar.Doeffinger@gmx.de>
   *
 - * 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
   */
  
@@@ -24,6 -24,8 +24,8 @@@
  #define AVCODEC_DV_TABLEGEN_H
  
  #include <stdint.h>
+ #include "libavutil/attributes.h"
  #include "dv_vlc_data.h"
  
  #if CONFIG_SMALL
@@@ -46,7 -48,7 +48,7 @@@ typedef struct dv_vlc_pair 
  #else
  static struct dv_vlc_pair dv_vlc_map[DV_VLC_MAP_RUN_SIZE][DV_VLC_MAP_LEV_SIZE];
  
- static void dv_vlc_map_tableinit(void)
+ static void av_unused dv_vlc_map_tableinit(void)
  {
      int i, j;
      for (i = 0; i < NB_DV_VLC - 1; i++) {
diff --combined libavcodec/dvdata.h
@@@ -2,20 -2,20 +2,20 @@@
   * Constants for DV codec
   * Copyright (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
   */
  
@@@ -29,6 -29,8 +29,8 @@@
  
  #include "libavutil/rational.h"
  #include "avcodec.h"
+ #include "dsputil.h"
+ #include "get_bits.h"
  
  typedef struct DVwork_chunk {
      uint16_t  buf_offset;
@@@ -65,6 -67,20 +67,20 @@@ typedef struct DVprofile 
      const uint8_t  (*audio_shuffle)[9];     /* PCM shuffling table */
  } DVprofile;
  
+ typedef struct DVVideoContext {
+     const DVprofile *sys;
+     AVFrame          picture;
+     AVCodecContext  *avctx;
+     uint8_t         *buf;
+     uint8_t  dv_zigzag[2][64];
+     void (*get_pixels)(DCTELEM *block, const uint8_t *pixels, int line_size);
+     void (*fdct[2])(DCTELEM *block);
+     void (*idct_put[2])(uint8_t *dest, int line_size, DCTELEM *block);
+     me_cmp_func ildct_cmp;
+ } DVVideoContext;
  enum dv_section_type {
       dv_sect_header  = 0x1f,
       dv_sect_subcode = 0x3f,
@@@ -106,10 -122,36 +122,38 @@@ enum dv_pack_type 
   */
  #define DV_MAX_BPM 8
  
+ #define TEX_VLC_BITS 9
+ extern RL_VLC_ELEM ff_dv_rl_vlc[1184];
  const DVprofile* avpriv_dv_frame_profile(const DVprofile *sys,
 -                                         const uint8_t* frame, unsigned buf_size);
 +                                  const uint8_t* frame, unsigned buf_size);
 +const DVprofile* avpriv_dv_frame_profile2(AVCodecContext* codec, const DVprofile *sys,
 +                                  const uint8_t* frame, unsigned buf_size);
  const DVprofile* avpriv_dv_codec_profile(AVCodecContext* codec);
  
+ int ff_dv_init_dynamic_tables(const DVprofile *d);
+ int ff_dvvideo_init(AVCodecContext *avctx);
+ static inline int dv_work_pool_size(const DVprofile *d)
+ {
+     int size = d->n_difchan*d->difseg_size*27;
+     if (DV_PROFILE_IS_1080i50(d))
+         size -= 3*27;
+     if (DV_PROFILE_IS_720p50(d))
+         size -= 4*27;
+     return size;
+ }
+ static inline void dv_calculate_mb_xy(DVVideoContext *s, DVwork_chunk *work_chunk, int m, int *mb_x, int *mb_y)
+ {
+      *mb_x = work_chunk->mb_coordinates[m] & 0xff;
+      *mb_y = work_chunk->mb_coordinates[m] >> 8;
+      /* We work with 720p frames split in half. The odd half-frame (chan==2,3) is displaced :-( */
+      if (s->sys->height == 720 && !(s->buf[1]&0x0C)) {
+          *mb_y -= (*mb_y>17)?18:-72; /* shifting the Y coordinate down by 72/2 macro blocks */
+      }
+ }
  #endif /* AVCODEC_DVDATA_H */
diff --combined libavcodec/dvdec.c
index 0000000,689ae7c..8e0ee65
mode 000000,100644..100644
--- /dev/null
@@@ -1,0 -1,386 +1,387 @@@
 - * This file is part of Libav.
+ /*
+  * DV decoder
+  * Copyright (c) 2002 Fabrice Bellard
+  * Copyright (c) 2004 Roman Shaposhnik
+  *
+  * 50 Mbps (DVCPRO50) support
+  * Copyright (c) 2006 Daniel Maas <dmaas@maasdigital.com>
+  *
+  * 100 Mbps (DVCPRO HD) support
+  * Initial code by Daniel Maas <dmaas@maasdigital.com> (funded by BBC R&D)
+  * Final code by Roman Shaposhnik
+  *
+  * Many thanks to Dan Dennedy <dan@dennedy.org> for providing wealth
+  * of DV technical info.
+  *
 - * Libav is free software; you can redistribute it and/or
++ * This file is part of FFmpeg.
+  *
 - * Libav is distributed in the hope that it will be useful,
++ * 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.
+  *
 - * License along with Libav; if not, write to the Free Software
++ * 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
 -    s->sys = avpriv_dv_frame_profile(s->sys, buf, buf_size);
++ * License along with FFmpeg; if not, write to the Free Software
+  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+  */
+ /**
+  * @file
+  * DV decoder
+  */
+ #include "libavutil/pixdesc.h"
+ #include "avcodec.h"
+ #include "dsputil.h"
+ #include "get_bits.h"
+ #include "put_bits.h"
+ #include "simple_idct.h"
+ #include "dvdata.h"
+ #include "dvquant.h"
+ #include "dv_tablegen.h"
+ typedef struct BlockInfo {
+     const uint32_t *factor_table;
+     const uint8_t *scan_table;
+     uint8_t pos; /* position in block */
+     void (*idct_put)(uint8_t *dest, int line_size, DCTELEM *block);
+     uint8_t partial_bit_count;
+     uint32_t partial_bit_buffer;
+     int shift_offset;
+ } BlockInfo;
+ /* decode AC coefficients */
+ static void dv_decode_ac(GetBitContext *gb, BlockInfo *mb, DCTELEM *block)
+ {
+     int last_index = gb->size_in_bits;
+     const uint8_t  *scan_table   = mb->scan_table;
+     const uint32_t *factor_table = mb->factor_table;
+     int pos               = mb->pos;
+     int partial_bit_count = mb->partial_bit_count;
+     int level, run, vlc_len, index;
+     OPEN_READER(re, gb);
+     UPDATE_CACHE(re, gb);
+     /* if we must parse a partial VLC, we do it here */
+     if (partial_bit_count > 0) {
+         re_cache = re_cache >> partial_bit_count | mb->partial_bit_buffer;
+         re_index -= partial_bit_count;
+         mb->partial_bit_count = 0;
+     }
+     /* get the AC coefficients until last_index is reached */
+     for (;;) {
+         av_dlog(NULL, "%2d: bits=%04x index=%d\n", pos, SHOW_UBITS(re, gb, 16),
+                 re_index);
+         /* our own optimized GET_RL_VLC */
+         index   = NEG_USR32(re_cache, TEX_VLC_BITS);
+         vlc_len = ff_dv_rl_vlc[index].len;
+         if (vlc_len < 0) {
+             index = NEG_USR32((unsigned)re_cache << TEX_VLC_BITS, -vlc_len) +
+                     ff_dv_rl_vlc[index].level;
+             vlc_len = TEX_VLC_BITS - vlc_len;
+         }
+         level = ff_dv_rl_vlc[index].level;
+         run   = ff_dv_rl_vlc[index].run;
+         /* gotta check if we're still within gb boundaries */
+         if (re_index + vlc_len > last_index) {
+             /* should be < 16 bits otherwise a codeword could have been parsed */
+             mb->partial_bit_count = last_index - re_index;
+             mb->partial_bit_buffer = re_cache & ~(-1u >> mb->partial_bit_count);
+             re_index = last_index;
+             break;
+         }
+         re_index += vlc_len;
+         av_dlog(NULL, "run=%d level=%d\n", run, level);
+         pos += run;
+         if (pos >= 64)
+             break;
+         level = (level * factor_table[pos] + (1 << (dv_iweight_bits - 1))) >> dv_iweight_bits;
+         block[scan_table[pos]] = level;
+         UPDATE_CACHE(re, gb);
+     }
+     CLOSE_READER(re, gb);
+     mb->pos = pos;
+ }
+ static inline void bit_copy(PutBitContext *pb, GetBitContext *gb)
+ {
+     int bits_left = get_bits_left(gb);
+     while (bits_left >= MIN_CACHE_BITS) {
+         put_bits(pb, MIN_CACHE_BITS, get_bits(gb, MIN_CACHE_BITS));
+         bits_left -= MIN_CACHE_BITS;
+     }
+     if (bits_left > 0) {
+         put_bits(pb, bits_left, get_bits(gb, bits_left));
+     }
+ }
+ /* mb_x and mb_y are in units of 8 pixels */
+ static int dv_decode_video_segment(AVCodecContext *avctx, void *arg)
+ {
+     DVVideoContext *s = avctx->priv_data;
+     DVwork_chunk *work_chunk = arg;
+     int quant, dc, dct_mode, class1, j;
+     int mb_index, mb_x, mb_y, last_index;
+     int y_stride, linesize;
+     DCTELEM *block, *block1;
+     int c_offset;
+     uint8_t *y_ptr;
+     const uint8_t *buf_ptr;
+     PutBitContext pb, vs_pb;
+     GetBitContext gb;
+     BlockInfo mb_data[5 * DV_MAX_BPM], *mb, *mb1;
+     LOCAL_ALIGNED_16(DCTELEM, sblock, [5*DV_MAX_BPM], [64]);
+     LOCAL_ALIGNED_16(uint8_t, mb_bit_buffer, [  80 + FF_INPUT_BUFFER_PADDING_SIZE]); /* allow some slack */
+     LOCAL_ALIGNED_16(uint8_t, vs_bit_buffer, [5*80 + FF_INPUT_BUFFER_PADDING_SIZE]); /* allow some slack */
+     const int log2_blocksize = 3-s->avctx->lowres;
+     int is_field_mode[5];
+     assert((((int)mb_bit_buffer) & 7) == 0);
+     assert((((int)vs_bit_buffer) & 7) == 0);
+     memset(sblock, 0, 5*DV_MAX_BPM*sizeof(*sblock));
+     /* pass 1: read DC and AC coefficients in blocks */
+     buf_ptr = &s->buf[work_chunk->buf_offset*80];
+     block1  = &sblock[0][0];
+     mb1     = mb_data;
+     init_put_bits(&vs_pb, vs_bit_buffer, 5 * 80);
+     for (mb_index = 0; mb_index < 5; mb_index++, mb1 += s->sys->bpm, block1 += s->sys->bpm * 64) {
+         /* skip header */
+         quant = buf_ptr[3] & 0x0f;
+         buf_ptr += 4;
+         init_put_bits(&pb, mb_bit_buffer, 80);
+         mb    = mb1;
+         block = block1;
+         is_field_mode[mb_index] = 0;
+         for (j = 0; j < s->sys->bpm; j++) {
+             last_index = s->sys->block_sizes[j];
+             init_get_bits(&gb, buf_ptr, last_index);
+             /* get the DC */
+             dc       = get_sbits(&gb, 9);
+             dct_mode = get_bits1(&gb);
+             class1   = get_bits(&gb, 2);
+             if (DV_PROFILE_IS_HD(s->sys)) {
+                 mb->idct_put     = s->idct_put[0];
+                 mb->scan_table   = s->dv_zigzag[0];
+                 mb->factor_table = &s->sys->idct_factor[(j >= 4)*4*16*64 + class1*16*64 + quant*64];
+                 is_field_mode[mb_index] |= !j && dct_mode;
+             } else {
+                 mb->idct_put     = s->idct_put[dct_mode && log2_blocksize == 3];
+                 mb->scan_table   = s->dv_zigzag[dct_mode];
+                 mb->factor_table = &s->sys->idct_factor[(class1 == 3)*2*22*64 + dct_mode*22*64 +
+                                                         (quant + dv_quant_offset[class1])*64];
+             }
+             dc = dc << 2;
+             /* convert to unsigned because 128 is not added in the
+                standard IDCT */
+             dc += 1024;
+             block[0] = dc;
+             buf_ptr += last_index >> 3;
+             mb->pos               = 0;
+             mb->partial_bit_count = 0;
+             av_dlog(avctx, "MB block: %d, %d ", mb_index, j);
+             dv_decode_ac(&gb, mb, block);
+             /* write the remaining bits in a new buffer only if the
+                block is finished */
+             if (mb->pos >= 64)
+                 bit_copy(&pb, &gb);
+             block += 64;
+             mb++;
+         }
+         /* pass 2: we can do it just after */
+         av_dlog(avctx, "***pass 2 size=%d MB#=%d\n", put_bits_count(&pb), mb_index);
+         block = block1;
+         mb    = mb1;
+         init_get_bits(&gb, mb_bit_buffer, put_bits_count(&pb));
+         put_bits32(&pb, 0); // padding must be zeroed
+         flush_put_bits(&pb);
+         for (j = 0; j < s->sys->bpm; j++, block += 64, mb++) {
+             if (mb->pos < 64 && get_bits_left(&gb) > 0) {
+                 dv_decode_ac(&gb, mb, block);
+                 /* if still not finished, no need to parse other blocks */
+                 if (mb->pos < 64)
+                     break;
+             }
+         }
+         /* all blocks are finished, so the extra bytes can be used at
+            the video segment level */
+         if (j >= s->sys->bpm)
+             bit_copy(&vs_pb, &gb);
+     }
+     /* we need a pass over the whole video segment */
+     av_dlog(avctx, "***pass 3 size=%d\n", put_bits_count(&vs_pb));
+     block = &sblock[0][0];
+     mb    = mb_data;
+     init_get_bits(&gb, vs_bit_buffer, put_bits_count(&vs_pb));
+     put_bits32(&vs_pb, 0); // padding must be zeroed
+     flush_put_bits(&vs_pb);
+     for (mb_index = 0; mb_index < 5; mb_index++) {
+         for (j = 0; j < s->sys->bpm; j++) {
+             if (mb->pos < 64) {
+                 av_dlog(avctx, "start %d:%d\n", mb_index, j);
+                 dv_decode_ac(&gb, mb, block);
+             }
+             if (mb->pos >= 64 && mb->pos < 127)
+                 av_log(avctx, AV_LOG_ERROR, "AC EOB marker is absent pos=%d\n", mb->pos);
+             block += 64;
+             mb++;
+         }
+     }
+     /* compute idct and place blocks */
+     block = &sblock[0][0];
+     mb    = mb_data;
+     for (mb_index = 0; mb_index < 5; mb_index++) {
+         dv_calculate_mb_xy(s, work_chunk, mb_index, &mb_x, &mb_y);
+         /* idct_put'ting luminance */
+         if ((s->sys->pix_fmt == PIX_FMT_YUV420P) ||
+             (s->sys->pix_fmt == PIX_FMT_YUV411P && mb_x >= (704 / 8)) ||
+             (s->sys->height >= 720 && mb_y != 134)) {
+             y_stride = (s->picture.linesize[0] << ((!is_field_mode[mb_index]) * log2_blocksize));
+         } else {
+             y_stride = (2 << log2_blocksize);
+         }
+         y_ptr = s->picture.data[0] + ((mb_y * s->picture.linesize[0] + mb_x) << log2_blocksize);
+         linesize = s->picture.linesize[0] << is_field_mode[mb_index];
+         mb[0]    .idct_put(y_ptr                                   , linesize, block + 0*64);
+         if (s->sys->video_stype == 4) { /* SD 422 */
+             mb[2].idct_put(y_ptr + (1 << log2_blocksize)           , linesize, block + 2*64);
+         } else {
+             mb[1].idct_put(y_ptr + (1 << log2_blocksize)           , linesize, block + 1*64);
+             mb[2].idct_put(y_ptr                         + y_stride, linesize, block + 2*64);
+             mb[3].idct_put(y_ptr + (1 << log2_blocksize) + y_stride, linesize, block + 3*64);
+         }
+         mb += 4;
+         block += 4*64;
+         /* idct_put'ting chrominance */
+         c_offset = (((mb_y >>  (s->sys->pix_fmt == PIX_FMT_YUV420P)) * s->picture.linesize[1] +
+                      (mb_x >> ((s->sys->pix_fmt == PIX_FMT_YUV411P) ? 2 : 1))) << log2_blocksize);
+         for (j = 2; j; j--) {
+             uint8_t *c_ptr = s->picture.data[j] + c_offset;
+             if (s->sys->pix_fmt == PIX_FMT_YUV411P && mb_x >= (704 / 8)) {
+                   uint64_t aligned_pixels[64/8];
+                   uint8_t *pixels = (uint8_t*)aligned_pixels;
+                   uint8_t *c_ptr1, *ptr1;
+                   int x, y;
+                   mb->idct_put(pixels, 8, block);
+                   for (y = 0; y < (1 << log2_blocksize); y++, c_ptr += s->picture.linesize[j], pixels += 8) {
+                       ptr1   = pixels + (1 << (log2_blocksize - 1));
+                       c_ptr1 = c_ptr + (s->picture.linesize[j] << log2_blocksize);
+                       for (x = 0; x < (1 << (log2_blocksize - 1)); x++) {
+                           c_ptr[x]  = pixels[x];
+                           c_ptr1[x] = ptr1[x];
+                       }
+                   }
+                   block += 64; mb++;
+             } else {
+                   y_stride = (mb_y == 134) ? (1 << log2_blocksize) :
+                                              s->picture.linesize[j] << ((!is_field_mode[mb_index]) * log2_blocksize);
+                   linesize = s->picture.linesize[j] << is_field_mode[mb_index];
+                   (mb++)->    idct_put(c_ptr           , linesize, block); block += 64;
+                   if (s->sys->bpm == 8) {
+                       (mb++)->idct_put(c_ptr + y_stride, linesize, block); block += 64;
+                   }
+             }
+         }
+     }
+     return 0;
+ }
+ /* NOTE: exactly one frame must be given (120000 bytes for NTSC,
+    144000 bytes for PAL - or twice those for 50Mbps) */
+ static int dvvideo_decode_frame(AVCodecContext *avctx,
+                                  void *data, int *data_size,
+                                  AVPacket *avpkt)
+ {
+     const uint8_t *buf = avpkt->data;
+     int buf_size = avpkt->size;
+     DVVideoContext *s = avctx->priv_data;
+     const uint8_t* vsc_pack;
+     int apt, is16_9;
 -        is16_9 = (vsc_pack && ((vsc_pack[2] & 0x07) == 0x02 || (!apt && (vsc_pack[2] & 0x07) == 0x07)));
++    s->sys = avpriv_dv_frame_profile2(avctx, s->sys, buf, buf_size);
+     if (!s->sys || buf_size < s->sys->frame_size || ff_dv_init_dynamic_tables(s->sys)) {
+         av_log(avctx, AV_LOG_ERROR, "could not find dv frame profile\n");
+         return -1; /* NOTE: we only accept several full frames */
+     }
+     if (s->picture.data[0])
+         avctx->release_buffer(avctx, &s->picture);
++    avcodec_get_frame_defaults(&s->picture);
+     s->picture.reference = 0;
+     s->picture.key_frame = 1;
+     s->picture.pict_type = AV_PICTURE_TYPE_I;
+     avctx->pix_fmt   = s->sys->pix_fmt;
+     avctx->time_base = s->sys->time_base;
+     avcodec_set_dimensions(avctx, s->sys->width, s->sys->height);
+     if (avctx->get_buffer(avctx, &s->picture) < 0) {
+         av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
+         return -1;
+     }
+     s->picture.interlaced_frame = 1;
+     s->picture.top_field_first  = 0;
+     s->buf = buf;
+     avctx->execute(avctx, dv_decode_video_segment, s->sys->work_chunks, NULL,
+                    dv_work_pool_size(s->sys), sizeof(DVwork_chunk));
+     emms_c();
+     /* return image */
+     *data_size = sizeof(AVFrame);
+     *(AVFrame*)data = s->picture;
+     /* Determine the codec's sample_aspect ratio from the packet */
+     vsc_pack = buf + 80*5 + 48 + 5;
+     if ( *vsc_pack == dv_video_control ) {
+         apt = buf[4] & 0x07;
++        is16_9 = (vsc_pack[2] & 0x07) == 0x02 || (!apt && (vsc_pack[2] & 0x07) == 0x07);
+         avctx->sample_aspect_ratio = s->sys->sar[is16_9];
+     }
+     return s->sys->frame_size;
+ }
+ static int dvvideo_close(AVCodecContext *c)
+ {
+     DVVideoContext *s = c->priv_data;
+     if (s->picture.data[0])
+         c->release_buffer(c, &s->picture);
+     return 0;
+ }
+ AVCodec ff_dvvideo_decoder = {
+     .name           = "dvvideo",
+     .type           = AVMEDIA_TYPE_VIDEO,
+     .id             = CODEC_ID_DVVIDEO,
+     .priv_data_size = sizeof(DVVideoContext),
+     .init           = ff_dvvideo_init,
+     .close          = dvvideo_close,
+     .decode         = dvvideo_decode_frame,
+     .capabilities   = CODEC_CAP_DR1 | CODEC_CAP_SLICE_THREADS,
+     .max_lowres = 3,
+     .long_name = NULL_IF_CONFIG_SMALL("DV (Digital Video)"),
+ };
diff --combined libavcodec/rawdec.c
@@@ -2,20 -2,20 +2,20 @@@
   * Raw Video Decoder
   * Copyright (c) 2001 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
   */
  
  #include "raw.h"
  #include "libavutil/intreadwrite.h"
  #include "libavutil/imgutils.h"
 +#include "libavutil/opt.h"
  
  typedef struct RawVideoContext {
 +    AVClass *av_class;
      uint32_t palette[AVPALETTE_COUNT];
      unsigned char * buffer;  /* block of memory for holding one frame */
      int             length;  /* number of bytes in buffer */
      int flip;
      AVFrame pic;             ///< AVCodecContext.coded_frame
 +    int tff;
  } RawVideoContext;
  
 +static const AVOption options[]={
 +{"top", "top field first", offsetof(RawVideoContext, tff), AV_OPT_TYPE_INT, {.dbl = -1}, -1, 1, AV_OPT_FLAG_DECODING_PARAM|AV_OPT_FLAG_VIDEO_PARAM},
 +{NULL}
 +};
 +static const AVClass class = { "rawdec", NULL, options, LIBAVUTIL_VERSION_INT };
 +
  static const PixelFormatTag pix_fmt_bps_avi[] = {
 +    { PIX_FMT_MONOWHITE, 1 },
 +    { PIX_FMT_PAL8,    2 },
      { PIX_FMT_PAL8,    4 },
      { PIX_FMT_PAL8,    8 },
      { PIX_FMT_RGB444, 12 },
      { PIX_FMT_RGB555, 15 },
      { PIX_FMT_RGB555, 16 },
      { PIX_FMT_BGR24,  24 },
 -    { PIX_FMT_RGB32,  32 },
 +    { PIX_FMT_BGRA,   32 },
      { PIX_FMT_NONE, 0 },
  };
  
@@@ -74,7 -63,7 +74,7 @@@ static const PixelFormatTag pix_fmt_bps
      { PIX_FMT_NONE, 0 },
  };
  
 -static enum PixelFormat find_pix_fmt(const PixelFormatTag *tags, unsigned int fourcc)
 +enum PixelFormat ff_find_pix_fmt(const PixelFormatTag *tags, unsigned int fourcc)
  {
      while (tags->pix_fmt >= 0) {
          if (tags->fourcc == fourcc)
@@@ -89,29 -78,22 +89,29 @@@ static av_cold int raw_init_decoder(AVC
      RawVideoContext *context = avctx->priv_data;
  
      if (avctx->codec_tag == MKTAG('r','a','w',' '))
 -        avctx->pix_fmt = find_pix_fmt(pix_fmt_bps_mov, avctx->bits_per_coded_sample);
 +        avctx->pix_fmt = ff_find_pix_fmt(pix_fmt_bps_mov, avctx->bits_per_coded_sample);
      else if (avctx->codec_tag == MKTAG('W','R','A','W'))
 -        avctx->pix_fmt = find_pix_fmt(pix_fmt_bps_avi, avctx->bits_per_coded_sample);
 +        avctx->pix_fmt = ff_find_pix_fmt(pix_fmt_bps_avi, avctx->bits_per_coded_sample);
      else if (avctx->codec_tag)
 -        avctx->pix_fmt = find_pix_fmt(ff_raw_pix_fmt_tags, avctx->codec_tag);
 +        avctx->pix_fmt = ff_find_pix_fmt(ff_raw_pix_fmt_tags, avctx->codec_tag);
      else if (avctx->pix_fmt == PIX_FMT_NONE && avctx->bits_per_coded_sample)
 -        avctx->pix_fmt = find_pix_fmt(pix_fmt_bps_avi, avctx->bits_per_coded_sample);
 +        avctx->pix_fmt = ff_find_pix_fmt(pix_fmt_bps_avi, avctx->bits_per_coded_sample);
 +
 +    if (avctx->pix_fmt == PIX_FMT_NONE) {
 +        av_log(avctx, AV_LOG_ERROR, "Pixel format was not specified and cannot be detected\n");
 +        return AVERROR(EINVAL);
 +    }
  
      ff_set_systematic_pal2(context->palette, avctx->pix_fmt);
 -    context->length = avpicture_get_size(avctx->pix_fmt, avctx->width, avctx->height);
      if((avctx->bits_per_coded_sample == 4 || avctx->bits_per_coded_sample == 2) &&
         avctx->pix_fmt==PIX_FMT_PAL8 &&
         (!avctx->codec_tag || avctx->codec_tag == MKTAG('r','a','w',' '))){
 +        context->length = avpicture_get_size(avctx->pix_fmt, FFALIGN(avctx->width, 16), avctx->height);
          context->buffer = av_malloc(context->length);
          if (!context->buffer)
              return -1;
 +    } else {
 +        context->length = avpicture_get_size(avctx->pix_fmt, avctx->width, avctx->height);
      }
      context->pic.pict_type = AV_PICTURE_TYPE_I;
      context->pic.key_frame = 1;
      avctx->coded_frame= &context->pic;
  
      if((avctx->extradata_size >= 9 && !memcmp(avctx->extradata + avctx->extradata_size - 9, "BottomUp", 9)) ||
 +        avctx->codec_tag == MKTAG('c','y','u','v') ||
          avctx->codec_tag == MKTAG(3, 0, 0, 0) || avctx->codec_tag == MKTAG('W','R','A','W'))
          context->flip=1;
  
@@@ -137,8 -118,8 +137,9 @@@ static int raw_decode(AVCodecContext *a
  {
      const uint8_t *buf = avpkt->data;
      int buf_size = avpkt->size;
 +    int linesize_align = 4;
      RawVideoContext *context = avctx->priv_data;
+     int res;
  
      AVFrame   *frame   = data;
      AVPicture *picture = data;
      frame->top_field_first = avctx->coded_frame->top_field_first;
      frame->reordered_opaque = avctx->reordered_opaque;
      frame->pkt_pts          = avctx->pkt->pts;
 +    frame->pkt_pos          = avctx->pkt->pos;
  
 -    if(buf_size < context->length - (avctx->pix_fmt==PIX_FMT_PAL8 ? 256*4 : 0))
 -        return -1;
 +    if(context->tff>=0){
 +        frame->interlaced_frame = 1;
 +        frame->top_field_first  = context->tff;
 +    }
 +
 +    if (avctx->width <= 0 || avctx->height <= 0) {
 +        av_log(avctx, AV_LOG_ERROR, "w/h is invalid\n");
 +        return AVERROR(EINVAL);
 +    }
  
      //2bpp and 4bpp raw in avi and mov (yes this is ugly ...)
      if (context->buffer) {
          uint8_t *dst = context->buffer;
          buf_size = context->length - 256*4;
          if (avctx->bits_per_coded_sample == 4){
 -            for(i=0; 2*i+1 < buf_size; i++){
 +            for(i=0; 2*i+1 < buf_size && i<avpkt->size; i++){
                  dst[2*i+0]= buf[i]>>4;
                  dst[2*i+1]= buf[i]&15;
              }
 -        } else
 -            for(i=0; 4*i+3 < buf_size; i++){
 +            linesize_align = 8;
 +        } else {
 +            for(i=0; 4*i+3 < buf_size && i<avpkt->size; i++){
                  dst[4*i+0]= buf[i]>>6;
                  dst[4*i+1]= buf[i]>>4&3;
                  dst[4*i+2]= buf[i]>>2&3;
                  dst[4*i+3]= buf[i]   &3;
              }
 +            linesize_align = 16;
 +        }
          buf= dst;
      }
  
         avctx->codec_tag == MKTAG('A', 'V', 'u', 'p'))
          buf += buf_size - context->length;
  
-     avpicture_fill(picture, buf, avctx->pix_fmt, avctx->width, avctx->height);
 +    if(buf_size < context->length - (avctx->pix_fmt==PIX_FMT_PAL8 ? 256*4 : 0))
 +        return -1;
 +
+     if ((res = avpicture_fill(picture, buf, avctx->pix_fmt,
+                               avctx->width, avctx->height)) < 0)
+         return res;
      if((avctx->pix_fmt==PIX_FMT_PAL8 && buf_size < context->length) ||
         (av_pix_fmt_descriptors[avctx->pix_fmt].flags & PIX_FMT_PSEUDOPAL)) {
          frame->data[1]= context->palette;
              frame->palette_has_changed = 1;
          }
      }
 -    if(avctx->pix_fmt==PIX_FMT_BGR24 && ((frame->linesize[0]+3)&~3)*avctx->height <= buf_size)
 -        frame->linesize[0] = (frame->linesize[0]+3)&~3;
 +    if((avctx->pix_fmt==PIX_FMT_BGR24    ||
 +        avctx->pix_fmt==PIX_FMT_GRAY8    ||
 +        avctx->pix_fmt==PIX_FMT_RGB555LE ||
 +        avctx->pix_fmt==PIX_FMT_RGB555BE ||
 +        avctx->pix_fmt==PIX_FMT_RGB565LE ||
 +        avctx->pix_fmt==PIX_FMT_MONOWHITE ||
 +        avctx->pix_fmt==PIX_FMT_PAL8) &&
 +        FFALIGN(frame->linesize[0], linesize_align)*avctx->height <= buf_size)
 +        frame->linesize[0] = FFALIGN(frame->linesize[0], linesize_align);
  
      if(context->flip)
          flip(avctx, picture);
  
      if (   avctx->codec_tag == MKTAG('Y', 'V', '1', '2')
 +        || avctx->codec_tag == MKTAG('Y', 'V', '1', '6')
 +        || avctx->codec_tag == MKTAG('Y', 'V', '2', '4')
          || avctx->codec_tag == MKTAG('Y', 'V', 'U', '9'))
          FFSWAP(uint8_t *, picture->data[1], picture->data[2]);
  
@@@ -254,5 -214,4 +257,5 @@@ AVCodec ff_rawvideo_decoder = 
      .close          = raw_close_decoder,
      .decode         = raw_decode,
      .long_name = NULL_IF_CONFIG_SMALL("raw video"),
 +    .priv_class= &class,
  };