Merge remote-tracking branch 'qatar/master'
authorMichael Niedermayer <michaelni@gmx.at>
Sun, 15 Jul 2012 23:32:52 +0000 (01:32 +0200)
committerMichael Niedermayer <michaelni@gmx.at>
Sun, 15 Jul 2012 23:32:52 +0000 (01:32 +0200)
* qatar/master:
  configure: Check for CommandLineToArgvW
  vc1dec: Do not use random pred_flag if motion vector data is skipped
  vp8: Enclose pthread function calls in ifdefs
  snow: refactor code to work around a compiler bug in MSVC.
  vp8: Include the thread headers before using the pthread types
  configure: Check for getaddrinfo in ws2tcpip.h, too
  vp8: implement sliced threading
  vp8: move data from VP8Context->VP8Macroblock
  vp8: refactor decoding a single mb_row
  doc: update api changes with the right commit hashes
  mem: introduce av_malloc_array and av_mallocz_array

Conflicts:
configure
doc/APIchanges
libavcodec/vp8.c
libavutil/mem.h
libavutil/version.h

Merged-by: Michael Niedermayer <michaelni@gmx.at>
1  2 
configure
doc/APIchanges
libavcodec/snowenc.c
libavcodec/vc1dec.c
libavcodec/vp8.c
libavcodec/vp8.h
libavutil/mem.h
libavutil/version.h

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,21 -101,18 +101,21 @@@ 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-avresample     disable libavresample build [no]
 +  --enable-avresample      enable libavresample build [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-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
  External library support:
    --enable-avisynth        enable reading of AVISynth script files [no]
    --enable-bzlib           enable bzlib [autodetect]
 +  --enable-fontconfig      enable fontconfig
    --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-libcdio         enable audio CD grabbing with libcdio
    --enable-libdc1394       enable IIDC-1394 grabbing using libdc1394
                             and libraw1394 [no]
    --enable-libfdk-aac      enable AAC support via libfdk-aac [no]
    --enable-libfreetype     enable libfreetype [no]
    --enable-libgsm          enable GSM support via libgsm [no]
 +  --enable-libiec61883     enable iec61883 via libiec61883 [no]
    --enable-libilbc         enable iLBC de/encoding via libilbc [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-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-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-libvorbis       enable Vorbis en/decoding via libvorbis,
                             native implementation exists [no]
    --enable-libvpx          enable VP8 support via libvpx [no]
    --enable-libx264         enable H.264 encoding via x264 [no]
    --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]
  
@@@ -220,26 -204,22 +220,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)
@@@ -271,39 -251,16 +271,39 @@@ Optimization options (experts only)
    --disable-neon           disable NEON optimizations
    --disable-vis            disable VIS optimizations
    --disable-yasm           disable use of yasm assembler
 -
 -Developer options (useful when working on Libav itself):
 +  --disable-mips32r2       disable MIPS32R2 optimizations
 +  --disable-mipsdspr1      disable MIPS DSP ASE R1 optimizations
 +  --disable-mipsdspr2      disable MIPS DSP ASE R2 optimizations
 +  --disable-mipsfpu        disable floating point MIPS optimizations
 +  --disable-fast-unaligned consider unaligned accesses slow
 +  --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 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
 +  --assert-level=level     0(default), 1 or 2, amount of assertion testing,
 +                           2 causes a slowdown at runtime.
 +  --enable-memory-poisoning fill heap uninitialized allocated space with arbitrary data
 +  --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
 -                           \$LIBAV_SAMPLES at make invocation time.
 +                           \$FATE_SAMPLES at make invocation time.
    --enable-xmm-clobber-test check XMM registers for clobbering (Win64-only;
                             should be used only for debugging purposes)
 +  --enable-random          randomly enable/disable components
 +  --disable-random
 +  --enable-random=LIST     randomly enable/disable specific components or
 +  --disable-random=LIST    component groups. LIST is a comma-separated list
 +                           of NAME[:PROB] entries where NAME is a component
 +                           (group) and PROB the probability associated with
 +                           NAME (default 0.5).
 +  --random-seed=VALUE      seed value for --enable/disable-random
  
  NOTE: Object files are built at the place where configure is launched.
  EOF
@@@ -338,7 -295,7 +338,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
@@@ -636,10 -593,6 +636,10 @@@ add_cflags()
      append CFLAGS $($filter_cflags "$@")
  }
  
 +add_cxxflags(){
 +    append CXXFLAGS $($filter_cflags "$@")
 +}
 +
  add_asflags(){
      append ASFLAGS $($filter_asflags "$@")
  }
@@@ -664,13 -617,6 +664,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
@@@ -706,14 -652,12 +706,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
  }
  
@@@ -747,17 -691,9 +747,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
  }
@@@ -783,7 -719,7 +783,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
@@@ -794,10 -730,10 +794,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
  }
  
@@@ -814,26 -750,7 +814,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(){
@@@ -865,21 -782,13 +865,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
  }
@@@ -957,14 -862,6 +957,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"
@@@ -1016,10 -913,10 +1016,10 @@@ COMPONENT_LIST=
  "
  
  PROGRAM_LIST="
 -    avconv
 -    avplay
 -    avprobe
 -    avserver
 +    ffplay
 +    ffprobe
 +    ffserver
 +    ffmpeg
  "
  
  CONFIG_LIST="
      avresample
      avisynth
      bzlib
 +    crystalhd
      dct
      doc
      dwt
      dxva2
 +    fast_unaligned
      fastdiv
      fft
 +    fontconfig
      frei0r
      gnutls
      gpl
      gray
      hardcoded_tables
 +    libaacplus
 +    libass
 +    libbluray
      libcdio
 +    libcelt
      libdc1394
      libfaac
      libfdk_aac
      libfreetype
      libgsm
 +    libiec61883
      libilbc
 +    libmodplug
      libmp3lame
 +    libnut
      libopencore_amrnb
      libopencore_amrwb
      libopencv
      librtmp
      libschroedinger
      libspeex
 +    libstagefright_h264
      libtheora
 +    libutvideo
 +    libv4l2
      libvo_aacenc
      libvo_amrwbenc
      libvorbis
      lsp
      mdct
      memalign_hack
 +    memory_poisoning
      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='
@@@ -1162,10 -1041,6 +1162,10 @@@ ARCH_EXT_LIST=
      ssse3
      vfpv3
      vis
 +    mipsfpu
 +    mips32r2
 +    mipsdspr1
 +    mipsdspr2
  '
  
  HAVE_LIST_PUB='
@@@ -1183,13 -1058,12 +1183,14 @@@ HAVE_LIST=
      altivec_h
      arpa_inet_h
      asm_mod_y
 +    asm_types_h
      attribute_may_alias
      attribute_packed
      cbrtf
 +    clock_gettime
      closesocket
      cmov
+     CommandLineToArgvW
      cpuid
      dcbzl
      dev_bktr_ioctl_bt848_h
      GetSystemTimeAsFileTime
      getrusage
      gettimeofday
 +    glob
      gnu_as
      ibm_asm
      inet_aton
      inline_asm
 -    io_h
      isatty
      isinf
      isnan
      jack_port_get_latency_range
 +    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
      mmap
      nanosleep
      netinet_sctp_h
 +    PeekNamedPipe
 +    pod2man
      poll_h
      posix_memalign
 +    pthread_cancel
      rdtsc
      rint
      round
      soundcard_h
      strerror_r
      strptime
 -    strtok_r
      struct_addrinfo
      struct_group_source_req
      struct_ip_mreq_source
      sys_soundcard_h
      sys_time_h
      sys_videoio_h
 +    termios_h
 +    texi2html
      threads
      trunc
      truncf
@@@ -1334,13 -1201,11 +1335,13 @@@ CMDLINE_SELECT=
      $CONFIG_LIST
      $THREADS_LIST
      asm
 +    coverage
      cross_compile
      debug
      extra_warnings
      logging
      optimizations
 +    stripping
      symver
      yasm
  "
@@@ -1360,12 -1225,10 +1361,12 @@@ CMDLINE_SET=
      ar
      arch
      as
 +    assert_level
      build_suffix
      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
 +    random_seed
      samples
 +    strip
      sysinclude
      sysroot
      target_exec
      target_os
      target_path
 +    valgrind
 +    yasmexe
  "
  
  CMDLINE_APPEND="
      extra_cflags
 +    extra_cxxflags
  "
  
  # code dependency declarations
@@@ -1410,10 -1265,6 +1411,10 @@@ armvfp_deps="arm
  neon_deps="arm"
  vfpv3_deps="armvfp"
  
 +mipsfpu_deps="mips"
 +mips32r2_deps="mips"
 +mipsdspr1_deps="mips"
 +mipsdspr2_deps="mips"
  mmi_deps="mips"
  
  altivec_deps="ppc"
@@@ -1456,7 -1307,6 +1457,7 @@@ ac3_fixed_encoder_select="mdct ac3dsp
  alac_encoder_select="lpc"
  amrnb_decoder_select="lsp"
  amrwb_decoder_select="lsp"
 +amv_encoder_select="aandct"
  atrac1_decoder_select="mdct sinewin"
  atrac3_decoder_select="mdct"
  binkaudio_dct_decoder_select="mdct rdft dct sinewin"
@@@ -1465,7 -1315,6 +1466,7 @@@ cavs_decoder_select="golomb
  cook_decoder_select="mdct sinewin"
  cscd_decoder_suggest="zlib"
  dca_decoder_select="mdct"
 +dirac_decoder_select="dwt golomb"
  dnxhd_encoder_select="aandct"
  dxa_decoder_select="zlib"
  eac3_decoder_select="ac3_decoder"
@@@ -1473,13 -1322,11 +1474,13 @@@ eac3_encoder_select="mdct ac3dsp
  eamad_decoder_select="aandct"
  eatgq_decoder_select="aandct"
  eatqi_decoder_select="aandct"
 +exr_decoder_select="zlib"
  ffv1_decoder_select="golomb"
  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"
@@@ -1490,12 -1337,10 +1491,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"
  iac_decoder_select="fft mdct sinewin"
@@@ -1522,20 -1367,15 +1523,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"
@@@ -1560,18 -1400,15 +1561,18 @@@ 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"
  theora_decoder_select="vp3_decoder"
  tiff_decoder_suggest="zlib"
  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"
@@@ -1595,7 -1432,6 +1596,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"
@@@ -1606,7 -1442,6 +1607,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"
  libfaac_encoder_deps="libfaac"
  libfdk_aac_encoder_deps="libfdk_aac"
  libgsm_decoder_deps="libgsm"
@@@ -1625,31 -1458,24 +1626,31 @@@ libgsm_ms_decoder_deps="libgsm
  libgsm_ms_encoder_deps="libgsm"
  libilbc_decoder_deps="libilbc"
  libilbc_encoder_deps="libilbc"
 +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"
 +libvorbis_decoder_deps="libvorbis"
  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"
@@@ -1659,8 -1485,6 +1660,8 @@@ dirac_demuxer_select="dirac_parser
  eac3_demuxer_select="ac3_parser"
  flac_demuxer_select="flac_parser"
  ipod_muxer_select="mov_muxer"
 +libnut_demuxer_deps="libnut"
 +libnut_muxer_deps="libnut"
  matroska_audio_muxer_select="matroska_muxer"
  matroska_demuxer_suggest="zlib bzlib"
  mov_demuxer_suggest="zlib"
@@@ -1687,31 -1511,22 +1688,31 @@@ 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"
 +iec61883_indev_deps="libiec61883"
 +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"
@@@ -1739,54 -1554,36 +1740,54 @@@ 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"
 +asyncts_filter_deps="avresample"
 +atempo_filter_deps="avcodec rdft"
  blackframe_filter_deps="gpl"
  boxblur_filter_deps="gpl"
 +colormatrix_filter_deps="gpl"
  cropdetect_filter_deps="gpl"
  delogo_filter_deps="gpl"
 +deshake_filter_deps="avcodec"
  drawtext_filter_deps="libfreetype"
 -frei0r_filter_deps="frei0r dlopen strtok_r"
 +frei0r_filter_deps="frei0r dlopen"
  frei0r_filter_extralibs='$ldl'
 -frei0r_src_filter_deps="frei0r dlopen strtok_r"
 +frei0r_src_filter_deps="frei0r dlopen"
  frei0r_src_filter_extralibs='$ldl'
  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"
  resample_filter_deps="avresample"
  ocv_filter_deps="libopencv"
 +pan_filter_deps="swresample"
 +removelogo_filter_deps="avcodec avformat swscale"
  scale_filter_deps="swscale"
 +select_filter_deps="avcodec"
 +super2xsai_filter_deps="gpl"
 +tinterlace_filter_deps="gpl"
  yadif_filter_deps="gpl"
  
  # libraries
  avdevice_deps="avcodec avformat"
  avformat_deps="avcodec"
 +postproc_deps="gpl"
  
  # programs
 -avconv_deps="avcodec avfilter avformat avresample swscale
 -             aformat_filter asyncts_filter
 -             format_filter fps_filter scale_filter setpts_filter"
 -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'
 +ffmpeg_deps="avcodec avfilter avformat swscale swresample"
 +ffmpeg_select="buffersink_filter format_filter aformat_filter
 +               setpts_filter null_filter anull_filter abuffersink_filter"
 +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'
  
 -doc_deps="texi2html"
 +doc_deps_any="texi2html makeinfo pod2man"
  
  # tests
  
@@@ -1817,11 -1614,11 +1818,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                                                                 \
      wav                                                                 \
      yuv4mpegpipe=yuv4mpeg                                               \
  
 +colormatrix1_test_deps="colormatrix_filter"
 +colormatrix2_test_deps="colormatrix_filter"
 +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
  
@@@ -1851,27 -1636,23 +1852,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=":"
@@@ -1884,12 -1665,6 +1885,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
  
@@@ -1897,10 -1672,8 +1898,10 @@@ enable avcode
  enable avdevice
  enable avfilter
  enable avformat
 -enable avresample
  enable avutil
 +enable postproc
 +enable stripping
 +enable swresample
  enable swscale
  
  enable asm
@@@ -1915,7 -1688,7 +1916,7 @@@ enable swscale_alph
  
  # build settings
  SHFLAGS='-shared -Wl,-soname,$$(@F)'
 -AVSERVERLDFLAGS=-Wl,-E
 +FFSERVERLDFLAGS=-Wl,-E
  LIBPREF="lib"
  LIBSUF=".a"
  FULLNAME='$(NAME)$(BUILDSUF)'
@@@ -1931,7 -1704,6 +1932,7 @@@ SLIB_INSTALL_LINKS='$(SLIBNAME_WITH_MAJ
  
  AS_O='-o $@'
  CC_O='-o $@'
 +CXX_O='-o $@'
  
  host_cflags='-D_ISOC99_SOURCE -D_XOPEN_SOURCE=600 -O3 -g'
  host_libs='-lm'
@@@ -1958,7 -1730,7 +1959,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(){
@@@ -1998,12 -1770,11 +1999,12 @@@ find_tests()
      map "echo ${2}\${v}_test" $(ls "$source_path"/tests/ref/$1 | grep -v '[^-a-z0-9_]')
  }
  
 +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="$LAVF_TESTS $LAVFI_TESTS $SEEK_TESTS"
 +ALL_TESTS="$LAVF_FATE_TESTS $LAVF_TESTS $LAVFI_TESTS $SEEK_TESTS"
  
  for n in $COMPONENT_LIST; do
      v=$(toupper ${n%s})_LIST
@@@ -2026,27 -1797,6 +2027,27 @@@ show_list() 
      exit 0
  }
  
 +rand_list(){
 +    IFS=', '
 +    set -- $*
 +    unset IFS
 +    for thing; do
 +        comp=${thing%:*}
 +        prob=${thing#$comp}
 +        prob=${prob#:}
 +        is_in ${comp} $COMPONENT_LIST && eval comp=\$$(toupper ${comp%s})_LIST
 +        echo "prob ${prob:-0.5}"
 +        printf '%s\n' $comp
 +    done
 +}
 +
 +do_random(){
 +    action=$1
 +    shift
 +    random_seed=$(awk "BEGIN { srand($random_seed); print srand() }")
 +    $action $(rand_list "$@" | awk "BEGIN { srand($random_seed) } \$1 == \"prob\" { prob = \$2; next } rand() < prob { print }")
 +}
 +
  for opt do
      optval="${opt#*=}"
      case "$opt" in
      --disable-everything)
      map 'eval unset \${$(toupper ${v%s})_LIST}' $COMPONENT_LIST
      ;;
 +    --enable-random|--disable-random)
 +    action=${opt%%-random}
 +    do_random ${action#--} $COMPONENT_LIST
 +    ;;
 +    --enable-random=*|--disable-random=*)
 +    action=${opt%%-random=*}
 +    do_random ${action#--} $optval
 +    ;;
      --enable-*=*|--disable-*=*)
      eval $(echo "${opt%%=*}" | sed 's/--/action=/;s/-/ thing=/')
      is_in "${thing}s" $COMPONENT_LIST || die_unknown "$opt"
@@@ -2112,7 -1854,7 +2113,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
@@@ -2122,29 -1864,17 +2123,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
  
@@@ -2187,7 -1917,6 +2188,7 @@@ trap 'rm -f -- $TMPFILES' EXI
  
  tmpfile TMPASM .asm
  tmpfile TMPC   .c
 +tmpfile TMPCPP .cpp
  tmpfile TMPE   $EXESUF
  tmpfile TMPH   .h
  tmpfile TMPO   .o
@@@ -2422,11 -2151,9 +2423,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
@@@ -2620,28 -2351,6 +2621,28 @@@ elif enabled mips; the
  
      cpuflags="-march=$cpu"
  
 +    case $cpu in
 +        24kc)
 +            disable mipsfpu
 +            disable mipsdspr1
 +            disable mipsdspr2
 +        ;;
 +        24kf*)
 +            disable mipsdspr1
 +            disable mipsdspr2
 +        ;;
 +        24kec|34kc|1004kc)
 +            disable mipsfpu
 +            disable mipsdspr2
 +        ;;
 +        24kef*|34kf*|1004kf*)
 +            disable mipsdspr2
 +        ;;
 +        74kc)
 +            disable mipsfpu
 +        ;;
 +    esac
 +
  elif enabled avr32; then
  
      case $cpu in
@@@ -2682,7 -2391,6 +2683,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>
@@@ -2705,11 -2413,6 +2706,11 @@@ case "$arch" i
              spic=$shared
          fi
      ;;
 +    ppc)
 +        check_cc <<EOF && subarch="ppc64"
 +        int test[(int)sizeof(char*) - 7];
 +EOF
 +    ;;
  esac
  
  enable $subarch
@@@ -2723,7 -2426,7 +2724,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"
          oss_indev_extralibs="-lossaudio"
          oss_outdev_extralibs="-lossaudio"
          ;;
 -    openbsd)
 +    openbsd|bitrig)
          # 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.
          enable pic
          disable symver
          SHFLAGS='-shared'
 +        SLIBNAME_WITH_MAJOR='$(SLIBNAME).$(LIBVERSION)'
          oss_indev_extralibs="-lossaudio"
          oss_outdev_extralibs="-lossaudio"
          ;;
          ;;
      bsd/os)
          add_extralibs -lpoll -lgnugetopt
 +        strip="strip -d"
          ;;
      darwin)
          gas="gas-preprocessor.pl $cc"
          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 ||
          fi
          LIBTARGET=i386
          if enabled x86_64; then
 -            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
@@@ -2895,7 -2594,7 +2896,7 @@@ esc()
      echo "$*" | sed 's/%/%25/g;s/:/%3a/g'
  }
  
 -echo "config:$arch:$subarch:$cpu:$target_os:$(esc $cc_ident):$(esc $LIBAV_CONFIGURATION)" >config.fate
 +echo "config:$arch:$subarch:$cpu:$target_os:$(esc $cc_ident):$(esc $FFMPEG_CONFIGURATION)" >config.fate
  
  check_cpp_condition stdlib.h "defined(__PIC__) || defined(__pic__) || defined(PIC)" && enable pic
  
@@@ -2916,21 -2615,14 +2917,21 @@@ die_license_disabled() 
      enabled $1 || { enabled $2 && die "$2 is $1 and --enable-$1 is not specified."; }
  }
  
 +die_license_disabled_gpl() {
 +    enabled $1 || { enabled $2 && die "$2 is incompatible with the gpl and --enable-$1 is not specified."; }
 +}
 +
  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
 +enabled gpl && die_license_disabled_gpl nonfree openssl
 +enabled gpl && die_license_disabled_gpl nonfree libfdk_aac
  
  die_license_disabled version3 libopencore_amrnb
  die_license_disabled version3 libopencore_amrwb
@@@ -2994,7 -2686,7 +2995,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
@@@ -3017,15 -2709,6 +3018,15 @@@ elif enabled mips; the
  
      check_asm loongson '"dmult.g $1, $2, $3"'
      enabled mmi     && check_asm mmi     '"lq $2, 0($2)"'
 +    enabled mips32r2  && add_cflags "-mips32r2" &&
 +     check_asm mips32r2  '"rotr $t0, $t1, 1"'
 +    enabled mipsdspr1 && add_cflags "-mdsp" && add_asflags "-mdsp" &&
 +     check_asm mipsdspr1 '"addu.qb $t0, $t1, $t2"'
 +    enabled mipsdspr2 && add_cflags "-mdspr2" && add_asflags "-mdspr2" &&
 +     check_asm mipsdspr2 '"absq_s.qb $t0, $t1"'
 +    enabled mipsfpu   && add_cflags "-mhard-float" &&
 +     check_asm mipsfpu   '"madd.d $f0, $f2, $f4, $f6"'
 +
  
  elif enabled ppc; then
  
@@@ -3067,12 -2750,12 +3068,12 @@@ elif enabled sparc; the
  
  elif enabled x86; then
  
 -    check_code ld immintrin.h "__xgetbv(0)" && enable xgetbv
 -    check_code ld intrin.h "int info[4]; __cpuid(info, 0)" && enable cpuid
 -    check_code ld intrin.h "__rdtsc()" && enable rdtsc
 -    check_code ld intrin.h "unsigned int x = __readeflags()" && enable rweflags
 +    check_code ld immintrin.h "__xgetbv(0)" "cc" && enable xgetbv
 +    check_code ld intrin.h "int info[4]; __cpuid(info, 0)" "cc" && enable cpuid
 +    check_code ld intrin.h "__rdtsc()" "cc" && enable rdtsc
 +    check_code ld intrin.h "unsigned int x = __readeflags()" "cc" && enable rweflags
  
 -    check_code ld mmintrin.h "_mm_empty()" && enable mm_empty
 +    check_code ld mmintrin.h "_mm_empty()" "cc" && enable mm_empty
  
      enable local_aligned_8 local_aligned_16
  
  # Solaris has nanosleep in -lrt, OpenSolaris no longer needs that
  check_func nanosleep || { check_func nanosleep -lrt && add_extralibs -lrt; }
  
 +check_func  clock_gettime || { check_func clock_gettime -lrt && add_extralibs -lrt; }
  check_func  fcntl
  check_func  fork
- check_func  getaddrinfo $network_extralibs
+ check_func  getaddrinfo $network_extralibs ||
+     check_func_headers ws2tcpip.h getaddrinfo $network_extralibs
  check_func  gethrtime
  check_func  getopt
  check_func  getrusage
@@@ -3199,14 -2882,13 +3201,15 @@@ check_func_headers malloc.h _aligned_ma
  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  usleep
 +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 shellapi.h" CommandLineToArgvW -lshell32
  check_lib2 "windows.h psapi.h" GetProcessMemoryInfo -lpsapi
  check_func_headers windows.h GetProcessAffinityMask
  check_func_headers windows.h GetProcessTimes
@@@ -3214,12 -2896,11 +3217,12 @@@ check_func_headers windows.h GetSystemT
  check_func_headers windows.h MapViewOfFile
  check_func_headers windows.h Sleep
  check_func_headers windows.h VirtualAlloc
 +check_func_headers glob.h glob
  
  check_header dlfcn.h
  check_header dxva.h
 -check_header dxva2api.h
 -check_header io.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
@@@ -3227,32 -2908,22 +3230,32 @@@ check_header sys/param.
  check_header sys/resource.h
  check_header sys/select.h
  check_header sys/time.h
 +check_header termios.h
  check_header unistd.h
  check_header vdpau/vdpau.h
  check_header vdpau/vdpau_x11.h
  check_header windows.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
          :
@@@ -3277,12 -2948,7 +3280,12 @@@ for thread in $THREADS_LIST; d
      fi
  done
  
 +if enabled pthreads; then
 +  check_func pthread_cancel
 +fi
 +
  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
@@@ -3304,56 -2970,36 +3307,56 @@@ check_mathfunc trunc
  
  # these are off by default, so fail if requested and not available
  enabled avisynth   && require2 vfw32 "windows.h vfw.h" AVIFileInit -lavifil32
 +enabled fontconfig && require_pkg_config fontconfig "fontconfig/fontconfig.h" FcInit
  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 libiec61883 && require libiec61883 libiec61883/iec61883.h iec61883_cmp_connect -lraw1394 -lavc1394 -lrom1394 -liec61883
 +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 libfaac    && require2 libfaac "stdint.h faac.h" faacEncGetVersion -lfaac
  enabled libfdk_aac && require  libfdk_aac fdk-aac/aacenc_lib.h aacEncOpen -lfdk-aac
  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 libilbc    && require  libilbc ilbc.h WebRtcIlbcfix_InitDecode -lilbc
 +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 -lgnustl_static
  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 VP8E_SET_MAX_INTRA_BITRATE_PCT" -lvpx ||
 +                                die "ERROR: libvpx encoder version must be >=0.9.7"; } }
  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 ||
@@@ -3368,29 -3014,15 +3371,29 @@@ if enabled libdc1394; the
      die "ERROR: No version of libdc1394 found "
  fi
  
 +SDL_CONFIG="${cross_prefix}sdl-config"
  if check_pkg_config sdl SDL_events.h SDL_PollEvent; 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
 +texi2html --help 2> /dev/null | grep -q 'init-file' && enable texi2html || disable texi2html
 +makeinfo --version > /dev/null 2>&1 && enable makeinfo  || disable makeinfo
 +pod2man --help > /dev/null 2>&1 && enable pod2man || disable pod2man
  
  check_header linux/fb.h
 +check_header linux/videodev.h
  check_header linux/videodev2.h
  check_struct linux/videodev2.h "struct v4l2_frmivalenum" discrete
  
@@@ -3401,8 -3033,6 +3404,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 &&
      check_func jack_port_get_latency_range -ljack
  
  enabled_any sndio_indev sndio_outdev && check_lib2 sndio.h sio_open -lsndio
@@@ -3438,11 -3061,9 +3441,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
@@@ -3453,8 -3074,6 +3456,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
@@@ -3466,17 -3085,17 +3469,17 @@@ check_cflags -Wdisabled-optimizatio
  check_cflags -Wpointer-arith
  check_cflags -Wredundant-decls
  check_cflags -Wno-pointer-sign
 -check_cflags -Wcast-qual
  check_cflags -Wwrite-strings
  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:libavresample
 +check_ldflags -Wl,-rpath-link=libpostproc:libswresample:libswscale:libavfilter:libavdevice:libavformat:libavcodec:libavutil:libavresample
  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
@@@ -3554,6 -3169,7 +3557,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
@@@ -3583,41 -3199,9 +3586,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 aligned_malloc &&
      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"
@@@ -3625,9 -3209,6 +3628,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
@@@ -3656,10 -3237,6 +3659,10 @@@ if enabled arm; the
  fi
  if enabled mips; then
      echo "MMI enabled               ${mmi-no}"
 +    echo "MIPS FPU enabled          ${mipsfpu-no}"
 +    echo "MIPS32R2 enabled          ${mips32r2-no}"
 +    echo "MIPS DSP R1 enabled       ${mipsdspr1-no}"
 +    echo "MIPS DSP R2 enabled       ${mipsdspr2-no}"
  fi
  if enabled ppc; then
      echo "AltiVec enabled           ${altivec-no}"
@@@ -3670,12 -3247,10 +3673,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}"
@@@ -3687,19 -3262,13 +3690,19 @@@ 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 "libfaac enabled           ${libfaac-no}"
  echo "libfdk-aac enabled        ${libfdk_aac-no}"
  echo "libgsm enabled            ${libgsm-no}"
 +echo "libiec61883 support       ${libiec61883-no}"
  echo "libilbc enabled           ${libilbc-no}"
 +echo "libmodplug enabled        ${libmodplug-no}"
  echo "libmp3lame enabled        ${libmp3lame-no}"
 +echo "libnut enabled            ${libnut-no}"
  echo "libopencore-amrnb support ${libopencore_amrnb-no}"
  echo "libopencore-amrwb support ${libopencore_amrwb-no}"
  echo "libopencv support         ${libopencv-no}"
@@@ -3708,10 -3277,7 +3711,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}"
@@@ -3719,12 -3285,9 +3722,12 @@@ 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}"
 +test -n "$random_seed" &&
 +    echo "random seed               ${random_seed}"
  echo
  
  for type in decoder encoder hwaccel parser demuxer muxer protocol filter bsf indev outdev; do
@@@ -3751,15 -3314,11 +3754,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
@@@ -3768,13 -3327,9 +3771,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
@@@ -3782,22 -3337,18 +3785,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
@@@ -3808,7 -3359,6 +3811,7 @@@ EXESUF=$EXESU
  EXTRA_VERSION=$extra_version
  DEPFLAGS=$DEPFLAGS
  CCDEP=$CCDEP
 +CXXDEP=$CXXDEP
  ASDEP=$ASDEP
  CC_DEPFLAGS=$CC_DEPFLAGS
  AS_DEPFLAGS=$AS_DEPFLAGS
@@@ -3823,7 -3373,7 +3826,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}
@@@ -3834,8 -3384,7 +3837,8 @@@ SLIB_INSTALL_NAME=${SLIB_INSTALL_NAME
  SLIB_INSTALL_LINKS=${SLIB_INSTALL_LINKS}
  SLIB_INSTALL_EXTRA_LIB=${SLIB_INSTALL_EXTRA_LIB}
  SLIB_INSTALL_EXTRA_SHLIB=${SLIB_INSTALL_EXTRA_SHLIB}
 -SAMPLES:=${samples:-\$(LIBAV_SAMPLES)}
 +SAMPLES:=${samples:-\$(FATE_SAMPLES)}
 +NOREDZONE_FLAGS=$noredzone_flags
  EOF
  
  get_version(){
      eval echo "${lcname}_VERSION_MAJOR=\$${name}_VERSION_MAJOR" >> config.mak
  }
  
 +get_version_old(){
 +    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
 +}
 +
 +get_version_old LIBPOSTPROC libpostproc/postprocess.h
 +get_version_old LIBSWRESAMPLE libswresample/swresample.h
 +
  get_version libavcodec
  get_version libavdevice
  get_version libavfilter
@@@ -3874,23 -3407,19 +3877,23 @@@ get_version libswscal
  
  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
 -#define restrict $_restrict
 +#define av_restrict $_restrict
  #define EXTERN_PREFIX "${extern_prefix}"
  #define EXTERN_ASM ${extern_prefix}
  #define SLIBSUF "$SLIBSUF"
  EOF
  
 +test -n "$assert_level" &&
 +    echo "#define ASSERT_LEVEL $assert_level" >>$TMPH
 +
  test -n "$malloc_prefix" &&
      echo "#define MALLOC_PREFIX $malloc_prefix" >>$TMPH
  
@@@ -3906,14 -3435,12 +3909,14 @@@ print_config CONFIG_ "$config_files" $C
                                       $ALL_COMPONENTS    \
  
  cat >>config.mak <<EOF
 +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
@@@ -3927,12 -3454,6 +3930,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
@@@ -3968,43 -3489,26 +3971,43 @@@ Libs: -L\${libdir} -l${shortname} $(ena
  Libs.private: $(enabled shared && echo $libs)
  Cflags: -I\${includedir}
  EOF
 -cat <<EOF > $name/$name-uninstalled.pc
 +
 +mkdir -p doc/examples/pc-uninstalled
 +includedir=${source_path}
 +[ "$includedir" = . ] && includedir="\${pcfiledir}/../../.."
 +cat <<EOF > doc/examples/pc-uninstalled/$name.pc
  prefix=
  exec_prefix=
 -libdir=\${pcfiledir}
 -includedir=${source_path}
 +libdir=\${pcfiledir}/../../../$name
 +includedir=${includedir}
  
  Name: $name
  Description: $comment
  Version: $version
  Requires: $requires
  Conflicts:
 -Libs: \${libdir}/${LIBPREF}${shortname}${LIBSUF} $libs
 +Libs: -L\${libdir} -l${shortname} $(enabled shared || echo $libs)
  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"
 +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 libavresample "Libav audio resampling library" "$LIBAVRESAMPLE_VERSION" "$extralibs"
 -pkgconfig_generate libswscale "Libav image rescaling library" "$LIBSWSCALE_VERSION" "$LIBM" "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/APIchanges
@@@ -7,81 -7,44 +7,84 @@@ libavdevice:   2011-04-1
  libavfilter:   2012-06-22
  libavformat:   2012-01-27
  libavresample: 2012-04-24
 +libpostproc:   2011-04-18
 +libswresample: 2011-09-19
  libswscale:    2011-06-20
  libavutil:     2011-04-18
  
  
  API changes, most recent first:
  
- 2012-06-22 - xxxxxxx - lavu 51.34.0
 +2012-07-14 - xxxxxxx - lavc 54.38.100 - avcodec.h
 +  Add metadata to AVFrame, and the accessor functions
 +  av_frame_get_metadata() and av_frame_set_metadata().
 +
 +2012-07-10 - xxxxxxx - lavc 54.33.100
 +  Add av_fast_padded_mallocz().
 +
 +2012-07-10 - xxxxxxx - lavfi 3.2.0 - avfilter.h
 +  Add init_opaque() callback to AVFilter struct.
 +
 +2012-06-26 - xxxxxxx - lavu 51.63.100 - imgutils.h
 +  Add functions to libavutil/imgutils.h:
 +  av_image_get_buffer_size()
 +  av_image_fill_arrays()
 +  av_image_copy_to_buffer()
 +
 +2012-06-24 - xxxxxxx - lavu 51.62.100 - version.h
 +  version moved from avutil.h to version.h
 +
 +2012-04-11 - xxxxxxx - lavu 51.58.100 - error.h
 +  Add av_make_error_string() and av_err2str() utilities to
 +  libavutil/error.h.
 +
 +2012-06-05 - xxxxxxx - lavc 54.24.100
 +  Add pkt_duration field to AVFrame.
 +
 +2012-05-24 - xxxxxxx - lavu 51.54.100
 +  Move AVPALETTE_SIZE and AVPALETTE_COUNT macros from
 +  libavcodec/avcodec.h to libavutil/pixfmt.h.
 +
 +2012-05-07 - xxxxxxx - lavf 54.5.100
 +  Add av_guess_sample_aspect_ratio() function.
 +
 +2012-04-20 - xxxxxxx - lavfi 2.70.100
 +  Add avfilter_unref_bufferp() to avfilter.h.
 +
 +2012-04-12 - xxxxxxx - lavfi 2.68.100
 +  Install libavfilter/asrc_abuffer.h public header.
 +
 +2012-03-26 - a67d9cf - lavfi 2.66.100
 +  Add avfilter_fill_frame_from_{audio_,}buffer_ref() functions.
 +
+ 2012-07-10 - 5fade8a - lavu 51.37.0
+   Add av_malloc_array() and av_mallocz_array()
+ 2012-06-22 - d3d3a32 - lavu 51.34.0
    Add av_usleep()
  
  2012-06-20 - ae0a301 - lavu 51.33.0
    Move av_gettime() to libavutil, add libavutil/time.h
  
- 2012-xx-xx - xxxxxxx - lavr 0.0.3
+ 2012-06-09 - 3971be0 - lavr 0.0.3
    Add a parameter to avresample_build_matrix() for Dolby/DPLII downmixing.
  
- 2012-xx-xx - xxxxxxx - lavfi 2.23.0 - avfilter.h
+ 2012-06-12 - 9baeff9 - lavfi 2.23.0 - avfilter.h
    Add AVFilterContext.nb_inputs/outputs. Deprecate
    AVFilterContext.input/output_count.
  
- 2012-xx-xx - xxxxxxx - lavfi 2.22.0 - avfilter.h
+ 2012-06-12 - 84b9fbe - lavfi 2.22.0 - avfilter.h
    Add avfilter_pad_get_type() and avfilter_pad_get_name(). Those
    should now be used instead of accessing AVFilterPad members
    directly.
  
- 2012-xx-xx - xxxxxxx - lavu 51.32.0 - audioconvert.h
+ 2012-06-12 - b0f0dfc - lavu 51.32.0 - audioconvert.h
    Add av_get_channel_layout_channel_index(), av_get_channel_name()
    and av_channel_layout_extract_channel().
  
- 2012-05-25 - e0e0793 - lavu 51.31.0 - opt.h
+ 2012-05-25 - 154486f - lavu 51.31.0 - opt.h
    Add av_opt_set_bin()
  
 -2012-05-26 - e9cef89 - lavf 54.3.0
 -  Add AVFMT_TS_NONSTRICT format flag to indicate that a muxer supports
 -  non-increasing monotone timestamps.
 -
  2012-05-15 - lavfi 2.17.0
    Add support for audio filters
    ac71230/a2cd9be - add video/audio buffer sink in a new installed
  
  2012-04-14 - lavfi 2.16.0 - avfiltergraph.h
    d7bcc71 Add avfilter_graph_parse2().
 -  91d3cbe Add avfilter_inout_alloc() and avfilter_inout_free().
  
  2012-04-08 - 4d693b0 - lavu 51.27.0 - samplefmt.h
    Add av_get_packed_sample_fmt() and av_get_planar_sample_fmt()
  
 -2012-04-05 - 5cc51a5 - lavu 51.26.0 - audioconvert.h
 -  Add av_get_default_channel_layout()
 +2012-03-21 - b75c67d - lavu 51.43.100
 +  Add bprint.h for bprint API.
 +
 +2012-02-21 - 9cbf17e - lavc 54.4.100
 +  Add av_get_pcm_codec() function.
 +
 +2012-02-16 - 560b224 - libswr 0.7.100
 +  Add swr_set_matrix() function.
 +
 +2012-02-09 - c28e7af - lavu 51.39.100
 +  Add a new installed header libavutil/timestamp.h with timestamp
 +  utilities.
  
 -2012-03-06 - 4d851f8 - lavu 51.25.0 - cpu.h
 -  Add av_set_cpu_flags_mask().
 +2012-02-06 - 70ffda3 - lavu 51.38.100
 +  Add av_parse_ratio() function to parseutils.h.
 +
 +2012-02-06 - 70ffda3 - lavu 51.38.100
 +  Add AV_LOG_MAX_OFFSET macro to log.h.
 +
 +2012-02-02 - 0eaa123 - lavu 51.37.100
 +  Add public timecode helpers.
 +
 +2012-01-24 - 0c3577b - lavfi 2.60.100
 +  Add avfilter_graph_dump.
  
  2012-03-05 - lavc 54.8.0
    6699d07 Add av_get_exact_bits_per_sample()
            muxers supporting it (av_write_frame makes sure it is called
            only for muxers with this flag).
  
 -------------------------------8<-------------------------------------
 -                   0.8 branch was cut here
 ------------------------------>8--------------------------------------
 -
  2012-01-15 - lavc 53.34.0
    New audio encoding API:
    b2c75b6 Add CODEC_CAP_VARIABLE_FRAME_SIZE capability for use by audio
  2012-01-12 - 3167dc9 - lavfi 2.15.0
    Add a new installed header -- libavfilter/version.h -- with version macros.
  
 -2011-01-03 - b73ec05 - lavu 51.21.0
 -  Add av_popcount64
 +2011-12-08 - a502939 - lavfi 2.52.0
 +  Add av_buffersink_poll_frame() to buffersink.h.
 +
 +2011-12-08 - 26c6fec - lavu 51.31.0
 +  Add av_log_format_line.
 +
 +2011-12-03 - 976b095 - lavu 51.30.0
 +  Add AVERROR_BUG.
 +
 +2011-11-24 - 573ffbb - lavu 51.28.1
 +  Add av_get_alt_sample_fmt() to samplefmt.h.
 +
 +2011-11-03 - 96949da - lavu 51.23.0
 +  Add av_strcasecmp() and av_strncasecmp() to avstring.h.
  
 -2011-12-25 - lavfi 2.14.0
 -  e1d9dbf Add a new installed header - buffersrc.h
 -  It contains a new function av_buffersrc_buffer() that allows passing
 -  frames to the 'buffer' filter, but unlike av_vsrc_buffer_add_frame()
 -  it allows for direct rendering.
 -  1c9e340 Add avfilter_copy_frame_props() for copying properties from
 -  AVFrame to AVFilterBufferRef.
 +2011-10-20 - b35e9e1 - lavu 51.22.0
 +  Add av_strtok() to avstring.h.
  
 -2011-12-25 - lavc 53.31.0
 -  Add the following new fields to AVFrame:
 -    b58dbb5 sample_aspect_ratio
 -    3a2ddf7 width, height
 -    8a4a5f6 format
 +2011-01-03 - b73ec05 - lavu 51.21.0
 +  Add av_popcount64
  
  2011-12-18 - 8400b12 - lavc 53.28.1
    Deprecate AVFrame.age. The field is unused.
    - 641c7af new functions - av_opt_child_next, av_opt_child_class_next
      and av_opt_find2()
  
 -2011-09-03 - fb4ca26 - lavc 53.10.0
 -                       lavf 53.6.0
 +2011-09-22 - a70e787 - lavu 51.17.0
 +  Add av_x_if_null().
 +
 +2011-09-18 - 645cebb - lavc 53.16.0
 +  Add showall flag2
 +
 +2011-09-16 - ea8de10 - lavfi 2.42.0
 +  Add avfilter_all_channel_layouts.
 +
 +2011-09-16 - 9899037 - lavfi 2.41.0
 +  Rename avfilter_all_* function names to avfilter_make_all_*.
 +
 +  In particular, apply the renames:
 +  avfilter_all_formats         -> avfilter_make_all_formats
 +  avfilter_all_channel_layouts -> avfilter_make_all_channel_layouts
 +  avfilter_all_packing_formats -> avfilter_make_all_packing_formats
 +
 +2011-09-12 - 4381bdd - lavfi 2.40.0
 +  Change AVFilterBufferRefAudioProps.sample_rate type from uint32_t to int.
 +
 +2011-09-12 - 2c03174 - lavfi 2.40.0
 +  Simplify signature for avfilter_get_audio_buffer(), make it
 +  consistent with avfilter_get_video_buffer().
 +
 +2011-09-06 - 4f7dfe1 - lavfi 2.39.0
 +  Rename libavfilter/vsink_buffer.h to libavfilter/buffersink.h.
 +
 +2011-09-06 - c4415f6 - lavfi 2.38.0
 +  Unify video and audio sink API.
 +
 +  In particular, add av_buffersink_get_buffer_ref(), deprecate
 +  av_vsink_buffer_get_video_buffer_ref() and change the value for the
 +  opaque field passed to the abuffersink init function.
 +
 +2011-09-04 - 61e2e29 - lavu 51.16.0
 +  Add av_asprintf().
 +
 +2011-08-22 - dacd827 - lavf 53.10.0
 +  Add av_find_program_from_stream().
 +
 +2011-08-20 - 69e2c1a - lavu 51.13.0
 +  Add av_get_media_type_string().
 +
 +2011-09-03 - fb4ca26 - lavc 53.13.0
 +                       lavf 53.11.0
                         lsws  2.1.0
    Add {avcodec,avformat,sws}_get_class().
  
 -2011-09-03 - c11fb82 - lavu 51.10.0
 +2011-08-03 - c11fb82 - lavu 51.15.0
    Add AV_OPT_SEARCH_FAKE_OBJ flag for av_opt_find() function.
  
 +2011-08-14 - 323b930 - lavu 51.12.0
 +  Add av_fifo_peek2(), deprecate av_fifo_peek().
 +
  2011-08-26 - lavu 51.9.0
 -  - f2011ed Add av_fifo_peek2(), deprecate av_fifo_peek().
    - add41de..abc78a5 Do not include intfloat_readwrite.h,
      mathematics.h, rational.h, pixfmt.h, or log.h from avutil.h.
  
 -2011-08-16 - 48f9e45 - lavf 53.4.0
 +2011-08-16 - 48f9e45 - lavf 53.8.0
    Add avformat_query_codec().
  
 -2011-08-16 - bca06e7 - lavc 53.8.0
 +2011-08-16 - bca06e7 - lavc 53.11.0
    Add avcodec_get_type().
  
 -2011-08-06 - 2f63440 - lavf 53.4.0
 +2011-08-06 - 2f63440 - lavf 53.7.0
    Add error_recognition to AVFormatContext.
  
 -2011-08-02 - 9d39cbf - lavc 53.7.1
 +2011-08-02 - 9d39cbf - lavc 53.9.1
    Add AV_PKT_FLAG_CORRUPT AVPacket flag.
  
 -2011-07-10 - a67c061 - lavf 53.3.0
 +2011-07-16 - b57df29 - lavfi 2.27.0
 +  Add audio packing negotiation fields and helper functions.
 +
 +  In particular, add AVFilterPacking enum, planar, in_packings and
 +  out_packings fields to AVFilterLink, and the functions:
 +  avfilter_set_common_packing_formats()
 +  avfilter_all_packing_formats()
 +
 +2011-07-10 - a67c061 - lavf 53.6.0
    Add avformat_find_stream_info(), deprecate av_find_stream_info().
    NOTE: this was backported to 0.7
  
 -2011-07-10 - 0b950fe - lavc 53.6.0
 +2011-07-10 - 0b950fe - lavc 53.8.0
    Add avcodec_open2(), deprecate avcodec_open().
    NOTE: this was backported to 0.7
  
    Add avcodec_alloc_context3. Deprecate avcodec_alloc_context() and
    avcodec_alloc_context2().
  
 +2011-07-01 - b442ca6 - lavf 53.5.0 - avformat.h
 +  Add function av_get_output_timestamp().
 +
 +2011-06-28 - 5129336 - lavu 51.11.0 - avutil.h
 +  Define the AV_PICTURE_TYPE_NONE value in AVPictureType enum.
 +
 +2011-06-19 - fd2c0a5 - lavfi 2.23.0 - avfilter.h
 +  Add layout negotiation fields and helper functions.
 +
 +  In particular, add in_chlayouts and out_chlayouts to AVFilterLink,
 +  and the functions:
 +  avfilter_set_common_sample_formats()
 +  avfilter_set_common_channel_layouts()
 +  avfilter_all_channel_layouts()
 +
 +2011-06-19 - 527ca39 - lavfi 2.22.0 - AVFilterFormats
 +  Change type of AVFilterFormats.formats from int * to int64_t *,
 +  and update formats handling API accordingly.
 +
 +  avfilter_make_format_list() still takes a int32_t array and converts
 +  it to int64_t. A new function, avfilter_make_format64_list(), that
 +  takes int64_t arrays has been added.
 +
 +2011-06-19 - 44f669e - lavfi 2.21.0 - vsink_buffer.h
 +  Add video sink buffer and vsink_buffer.h public header.
 +
 +2011-06-12 - 9fdf772 - lavfi 2.18.0 - avcodec.h
 +  Add avfilter_get_video_buffer_ref_from_frame() function in
 +  libavfilter/avcodec.h.
 +
 +2011-06-12 - c535494 - lavfi 2.17.0 - avfiltergraph.h
 +  Add avfilter_inout_alloc() and avfilter_inout_free() functions.
 +
 +2011-06-12 - 6119b23 - lavfi 2.16.0 - avfilter_graph_parse()
 +  Change avfilter_graph_parse() signature.
 +
  2011-06-23 - 67e9ae1 - lavu 51.8.0 - attributes.h
    Add av_printf_format().
  
 -------------------------------8<-------------------------------------
 -                   0.7 branch was cut here
 ------------------------------>8--------------------------------------
 -
  2011-06-16 - 05e84c9, 25de595 - lavf 53.2.0 - avformat.h
    Add avformat_open_input and avformat_write_header().
    Deprecate av_open_input_stream, av_open_input_file,
  2011-06-10 - cb7c11c - lavu 51.6.0 - opt.h
    Add av_opt_flag_is_set().
  
 -2011-06-08 - d9f80ea - lavu 51.5.0 - AVMetadata
 +2011-06-10 - c381960 - lavfi 2.15.0 - avfilter_get_audio_buffer_ref_from_arrays
 +  Add avfilter_get_audio_buffer_ref_from_arrays() to avfilter.h.
 +
 +2011-06-09 - d9f80ea - lavu 51.8.0 - AVMetadata
    Move AVMetadata from lavf to lavu and rename it to
    AVDictionary -- new installed header dict.h.
    All av_metadata_* functions renamed to av_dict_*.
  
 -2011-06-07 - a6703fa - lavu 51.4.0 - av_get_bytes_per_sample()
 +2011-06-07 - a6703fa - lavu 51.8.0 - av_get_bytes_per_sample()
    Add av_get_bytes_per_sample() in libavutil/samplefmt.h.
    Deprecate av_get_bits_per_sample_fmt().
  
 -2011-06-05 - b39b062 - lavu 51.3.0 - opt.h
 +2011-06-05 - b39b062 - lavu 51.8.0 - opt.h
    Add av_opt_free convenience function.
  
 -2011-05-28 - 0420bd7 - lavu 51.2.0 - pixdesc.h
 +2011-06-06 - 95a0242 - lavfi 2.14.0 - AVFilterBufferRefAudioProps
 +  Remove AVFilterBufferRefAudioProps.size, and use nb_samples in
 +  avfilter_get_audio_buffer() and avfilter_default_get_audio_buffer() in
 +  place of size.
 +
 +2011-06-06 - 0bc2cca - lavu 51.6.0 - av_samples_alloc()
 +  Switch nb_channels and nb_samples parameters order in
 +  av_samples_alloc().
 +
 +2011-06-06 - e1c7414 - lavu 51.5.0 - av_samples_*
 +  Change the data layout created by av_samples_fill_arrays() and
 +  av_samples_alloc().
 +
 +2011-06-06 - 27bcf55 - lavfi 2.13.0 - vsrc_buffer.h
 +  Make av_vsrc_buffer_add_video_buffer_ref() accepts an additional
 +  flags parameter in input.
 +
 +2011-06-03 - e977ca2 - lavfi 2.12.0 - avfilter_link_free()
 +  Add avfilter_link_free() function.
 +
 +2011-06-02 - 5ad38d9 - lavu 51.4.0 - av_force_cpu_flags()
 +  Add av_cpu_flags() in libavutil/cpu.h.
 +
 +2011-05-28 - e71f260 - lavu 51.3.0 - pixdesc.h
    Add av_get_pix_fmt_name() in libavutil/pixdesc.h, and deprecate
    avcodec_get_pix_fmt_name() in libavcodec/avcodec.h in its favor.
  
 -2011-05-25 - 30315a8 - lavf 53.1.0 - avformat.h
 +2011-05-25 - 30315a8 - lavf 53.3.0 - avformat.h
    Add fps_probe_size to AVFormatContext.
  
 -2011-05-18 - 64150ff - lavc 53.4.0 - AVCodecContext.request_sample_fmt
 +2011-05-22 - 5ecdfd0 - lavf 53.2.0 - avformat.h
 +  Introduce avformat_alloc_output_context2() and deprecate
 +  avformat_alloc_output_context().
 +
 +2011-05-22 - 83db719 - lavfi 2.10.0 - vsrc_buffer.h
 +  Make libavfilter/vsrc_buffer.h public.
 +
 +2011-05-19 - c000a9f - lavfi 2.8.0 - avcodec.h
 +  Add av_vsrc_buffer_add_frame() to libavfilter/avcodec.h.
 +
 +2011-05-14 - 9fdf772 - lavfi 2.6.0 - avcodec.h
 +  Add avfilter_get_video_buffer_ref_from_frame() to libavfilter/avcodec.h.
 +
 +2011-05-18 - 64150ff - lavc 53.7.0 - AVCodecContext.request_sample_fmt
    Add request_sample_fmt field to AVCodecContext.
  
 -2011-05-10 - 188dea1 - lavc 53.3.0 - avcodec.h
 +2011-05-10 - 188dea1 - lavc 53.6.0 - avcodec.h
    Deprecate AVLPCType and the following fields in
    AVCodecContext: lpc_coeff_precision, prediction_order_method,
    min_partition_order, max_partition_order, lpc_type, lpc_passes.
    Corresponding FLAC encoder options should be used instead.
  
 +2011-05-07 - 9fdf772 - lavfi 2.5.0 - avcodec.h
 +  Add libavfilter/avcodec.h header and avfilter_copy_frame_props()
 +  function.
 +
 +2011-05-07 - 18ded93 - lavc 53.5.0 - AVFrame
 +  Add format field to AVFrame.
 +
 +2011-05-07 - 22333a6 - lavc 53.4.0 - AVFrame
 +  Add width and height fields to AVFrame.
 +
 +2011-05-01 - 35fe66a - lavfi 2.4.0 - avfilter.h
 +  Rename AVFilterBufferRefVideoProps.pixel_aspect to
 +  sample_aspect_ratio.
 +
 +2011-05-01 - 77e9dee - lavc 53.3.0 - AVFrame
 +  Add a sample_aspect_ratio field to AVFrame.
 +
 +2011-05-01 - 1ba5727 - lavc 53.2.0 - AVFrame
 +  Add a pkt_pos field to AVFrame.
 +
 +2011-04-29 - 35ceaa7 - lavu 51.2.0 - mem.h
 +  Add av_dynarray_add function for adding
 +  an element to a dynamic array.
 +
  2011-04-26 - bebe72f - lavu 51.1.0 - avutil.h
    Add AVPictureType enum and av_get_picture_type_char(), deprecate
    FF_*_TYPE defines and av_get_pict_type_char() defined in
      333e894 deprecate url_open_protocol
      e230705 deprecate url_poll and URLPollEntry
  
 -2011-04-10 - lavu  50.40.0 - pixfmt.h
 -  Add PIX_FMT_BGR48LE and PIX_FMT_BGR48BE pixel formats
 -
  2011-04-08 - lavf 52.106.0 - avformat.h
    Minor avformat.h cleanup:
      a9bf9d8 deprecate av_guess_image2_codec
      d9d86e0 rename url_fprintf -> avio_printf
      59f65d9 deprecate url_setbufsize
      3e68b3b deprecate url_ferror
 -    66e5b1d deprecate url_feof
      e8bb2e2 deprecate url_fget_max_packet_size
      76aa876 rename url_fsize -> avio_size
      e519753 deprecate url_fgetc
  2011-03-25 - 34b47d7 - lavc 52.115.0 - AVCodecContext.audio_service_type
    Add audio_service_type field to AVCodecContext.
  
 +2011-03-17 - e309fdc - lavu 50.40.0 - pixfmt.h
 +  Add PIX_FMT_BGR48LE and PIX_FMT_BGR48BE pixel formats
 +
  2011-03-02 - 863c471 - lavf  52.103.0 - av_pkt_dump2, av_pkt_dump_log2
    Add new functions av_pkt_dump2, av_pkt_dump_log2 that uses the
    source stream timebase for outputting timestamps. Deprecate
  2011-02-02 - dfd2a00 - lavu 50.37.0 - log.h
    Make av_dlog public.
  
 +2011-01-31 - 7b3ea55 - lavfi 1.76.0 - vsrc_buffer
 +  Add sample_aspect_ratio fields to vsrc_buffer arguments
 +
 +2011-01-31 - 910b5b8 - lavfi 1.75.0 - AVFilterLink sample_aspect_ratio
 +  Add sample_aspect_ratio field to AVFilterLink.
 +
  2011-01-15 - a242ac3 - lavfi 1.74.0 - AVFilterBufferRefAudioProps
    Rename AVFilterBufferRefAudioProps.samples_nb to nb_samples.
  
diff --combined libavcodec/snowenc.c
@@@ -1,20 -1,20 +1,20 @@@
  /*
   * Copyright (C) 2004 Michael Niedermayer <michaelni@gmx.at>
   *
 - * 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
   */
  
@@@ -22,7 -22,6 +22,7 @@@
  #include "libavutil/log.h"
  #include "libavutil/opt.h"
  #include "avcodec.h"
 +#include "internal.h"
  #include "dsputil.h"
  #include "dwt.h"
  #include "snow.h"
@@@ -218,12 -217,12 +218,12 @@@ static av_cold int encode_init(AVCodecC
  
      avctx->coded_frame= &s->current_picture;
      switch(avctx->pix_fmt){
 -//    case PIX_FMT_YUV444P:
 +    case PIX_FMT_YUV444P:
  //    case PIX_FMT_YUV422P:
      case PIX_FMT_YUV420P:
 -    case PIX_FMT_GRAY8:
 +//     case PIX_FMT_GRAY8:
  //    case PIX_FMT_YUV411P:
 -//    case PIX_FMT_YUV410P:
 +    case PIX_FMT_YUV410P:
          s->colorspace_type= 0;
          break;
  /*    case PIX_FMT_RGB32:
          av_log(avctx, AV_LOG_ERROR, "pixel format not supported\n");
          return -1;
      }
 -//    avcodec_get_chroma_sub_sample(avctx->pix_fmt, &s->chroma_h_shift, &s->chroma_v_shift);
 -    s->chroma_h_shift= 1;
 -    s->chroma_v_shift= 1;
 +    avcodec_get_chroma_sub_sample(avctx->pix_fmt, &s->chroma_h_shift, &s->chroma_v_shift);
  
      ff_set_cmp(&s->dsp, s->dsp.me_cmp, s->avctx->me_cmp);
      ff_set_cmp(&s->dsp, s->dsp.me_sub_cmp, s->avctx->me_sub_cmp);
  }
  
  //near copy & paste from dsputil, FIXME
 -static int pix_sum(uint8_t * pix, int line_size, int w)
 +static int pix_sum(uint8_t * pix, int line_size, int w, int h)
  {
      int s, i, j;
  
      s = 0;
 -    for (i = 0; i < w; i++) {
 +    for (i = 0; i < h; i++) {
          for (j = 0; j < w; j++) {
              s += pix[0];
              pix ++;
@@@ -324,8 -325,8 +324,8 @@@ static int encode_q_branch(SnowContext 
      const int stride= s->current_picture.linesize[0];
      const int uvstride= s->current_picture.linesize[1];
      uint8_t *current_data[3]= { s->input_picture.data[0] + (x + y*  stride)*block_w,
 -                                s->input_picture.data[1] + (x + y*uvstride)*block_w/2,
 -                                s->input_picture.data[2] + (x + y*uvstride)*block_w/2};
 +                                s->input_picture.data[1] + ((x*block_w)>>s->chroma_h_shift) + ((y*uvstride*block_w)>>s->chroma_v_shift),
 +                                s->input_picture.data[2] + ((x*block_w)>>s->chroma_h_shift) + ((y*uvstride*block_w)>>s->chroma_v_shift)};
      int P[10][2];
      int16_t last_mv[3][2];
      int qpel= !!(s->avctx->flags & CODEC_FLAG_QPEL); //unused
      score += (s->lambda2*(get_rac_count(&pc)-base_bits))>>FF_LAMBDA_SHIFT;
  
      block_s= block_w*block_w;
 -    sum = pix_sum(current_data[0], stride, block_w);
 +    sum = pix_sum(current_data[0], stride, block_w, block_w);
      l= (sum + block_s/2)/block_s;
      iscore = pix_norm1(current_data[0], stride, block_w) - 2*l*sum + l*l*block_s;
  
 -    block_s= block_w*block_w>>2;
 -    sum = pix_sum(current_data[1], uvstride, block_w>>1);
 +    block_s= block_w*block_w>>(s->chroma_h_shift + s->chroma_v_shift);
 +    sum = pix_sum(current_data[1], uvstride, block_w>>s->chroma_h_shift, block_w>>s->chroma_v_shift);
      cb= (sum + block_s/2)/block_s;
  //    iscore += pix_norm1(&current_mb[1][0], uvstride, block_w>>1) - 2*cb*sum + cb*cb*block_s;
 -    sum = pix_sum(current_data[2], uvstride, block_w>>1);
 +    sum = pix_sum(current_data[2], uvstride, block_w>>s->chroma_h_shift, block_w>>s->chroma_v_shift);
      cr= (sum + block_s/2)/block_s;
  //    iscore += pix_norm1(&current_mb[2][0], uvstride, block_w>>1) - 2*cr*sum + cr*cr*block_s;
  
@@@ -575,10 -576,9 +575,10 @@@ static int get_dc(SnowContext *s, int m
      int i, x2, y2;
      Plane *p= &s->plane[plane_index];
      const int block_size = MB_SIZE >> s->block_max_depth;
 -    const int block_w    = plane_index ? block_size/2 : block_size;
 -    const uint8_t *obmc  = plane_index ? ff_obmc_tab[s->block_max_depth+1] : ff_obmc_tab[s->block_max_depth];
 -    const int obmc_stride= plane_index ? block_size : 2*block_size;
 +    const int block_w    = plane_index ? block_size>>s->chroma_h_shift : block_size;
 +    const int block_h    = plane_index ? block_size>>s->chroma_v_shift : block_size;
 +    const uint8_t *obmc  = plane_index ? ff_obmc_tab[s->block_max_depth+s->chroma_h_shift] : ff_obmc_tab[s->block_max_depth];
 +    const int obmc_stride= plane_index ? (2*block_size)>>s->chroma_h_shift : 2*block_size;
      const int ref_stride= s->current_picture.linesize[plane_index];
      uint8_t *src= s-> input_picture.data[plane_index];
      IDWTELEM *dst= (IDWTELEM*)s->m.obmc_scratchpad + plane_index*block_size*block_size*4; //FIXME change to unsigned
      int ab=0;
      int aa=0;
  
 +    av_assert2(s->chroma_h_shift == s->chroma_v_shift); //obmc stuff above
 +
      b->type|= BLOCK_INTRA;
      b->color[plane_index]= 0;
      memset(dst, 0, obmc_stride*obmc_stride*sizeof(IDWTELEM));
          int mb_x2= mb_x + (i &1) - 1;
          int mb_y2= mb_y + (i>>1) - 1;
          int x= block_w*mb_x2 + block_w/2;
 -        int y= block_w*mb_y2 + block_w/2;
 +        int y= block_h*mb_y2 + block_h/2;
  
 -        add_yblock(s, 0, NULL, dst + ((i&1)+(i>>1)*obmc_stride)*block_w, NULL, obmc,
 -                    x, y, block_w, block_w, w, h, obmc_stride, ref_stride, obmc_stride, mb_x2, mb_y2, 0, 0, plane_index);
 +        add_yblock(s, 0, NULL, dst + (i&1)*block_w + (i>>1)*obmc_stride*block_h, NULL, obmc,
 +                    x, y, block_w, block_h, w, h, obmc_stride, ref_stride, obmc_stride, mb_x2, mb_y2, 0, 0, plane_index);
  
 -        for(y2= FFMAX(y, 0); y2<FFMIN(h, y+block_w); y2++){
 +        for(y2= FFMAX(y, 0); y2<FFMIN(h, y+block_h); y2++){
              for(x2= FFMAX(x, 0); x2<FFMIN(w, x+block_w); x2++){
 -                int index= x2-(block_w*mb_x - block_w/2) + (y2-(block_w*mb_y - block_w/2))*obmc_stride;
 +                int index= x2-(block_w*mb_x - block_w/2) + (y2-(block_h*mb_y - block_h/2))*obmc_stride;
                  int obmc_v= obmc[index];
                  int d;
 -                if(y<0) obmc_v += obmc[index + block_w*obmc_stride];
 +                if(y<0) obmc_v += obmc[index + block_h*obmc_stride];
                  if(x<0) obmc_v += obmc[index + block_w];
 -                if(y+block_w>h) obmc_v += obmc[index - block_w*obmc_stride];
 +                if(y+block_h>h) obmc_v += obmc[index - block_h*obmc_stride];
                  if(x+block_w>w) obmc_v += obmc[index - block_w];
                  //FIXME precalculate this or simplify it somehow else
  
@@@ -670,9 -668,8 +670,9 @@@ static inline int get_block_bits(SnowCo
  static int get_block_rd(SnowContext *s, int mb_x, int mb_y, int plane_index, uint8_t (*obmc_edged)[MB_SIZE * 2]){
      Plane *p= &s->plane[plane_index];
      const int block_size = MB_SIZE >> s->block_max_depth;
 -    const int block_w    = plane_index ? block_size/2 : block_size;
 -    const int obmc_stride= plane_index ? block_size : 2*block_size;
 +    const int block_w    = plane_index ? block_size>>s->chroma_h_shift : block_size;
 +    const int block_h    = plane_index ? block_size>>s->chroma_v_shift : block_size;
 +    const int obmc_stride= plane_index ? (2*block_size)>>s->chroma_h_shift : 2*block_size;
      const int ref_stride= s->current_picture.linesize[plane_index];
      uint8_t *dst= s->current_picture.data[plane_index];
      uint8_t *src= s->  input_picture.data[plane_index];
      int rate= 0;
      const int penalty_factor= get_penalty_factor(s->lambda, s->lambda2, s->avctx->me_cmp);
      int sx= block_w*mb_x - block_w/2;
 -    int sy= block_w*mb_y - block_w/2;
 +    int sy= block_h*mb_y - block_h/2;
      int x0= FFMAX(0,-sx);
      int y0= FFMAX(0,-sy);
      int x1= FFMIN(block_w*2, w-sx);
 -    int y1= FFMIN(block_w*2, h-sy);
 +    int y1= FFMIN(block_h*2, h-sy);
      int i,x,y;
  
 -    ff_snow_pred_block(s, cur, tmp, ref_stride, sx, sy, block_w*2, block_w*2, &s->block[mb_x + mb_y*b_stride], plane_index, w, h);
 +    av_assert2(s->chroma_h_shift == s->chroma_v_shift); //obmc and square assumtions below chckinhg only block_w
 +
 +    ff_snow_pred_block(s, cur, tmp, ref_stride, sx, sy, block_w*2, block_h*2, &s->block[mb_x + mb_y*b_stride], plane_index, w, h);
  
      for(y=y0; y<y1; y++){
          const uint8_t *obmc1= obmc_edged[y];
          else
              x0 = block_w;
          if(mb_y == 0)
 -            y1 = block_w;
 +            y1 = block_h;
          else
 -            y0 = block_w;
 +            y0 = block_h;
          for(y=y0; y<y1; y++)
              memcpy(dst + sx+x0 + (sy+y)*ref_stride, cur + x0 + y*ref_stride, x1-x0);
      }
@@@ -772,10 -767,9 +772,10 @@@ static int get_4block_rd(SnowContext *s
      int i, y2;
      Plane *p= &s->plane[plane_index];
      const int block_size = MB_SIZE >> s->block_max_depth;
 -    const int block_w    = plane_index ? block_size/2 : block_size;
 -    const uint8_t *obmc  = plane_index ? ff_obmc_tab[s->block_max_depth+1] : ff_obmc_tab[s->block_max_depth];
 -    const int obmc_stride= plane_index ? block_size : 2*block_size;
 +    const int block_w    = plane_index ? block_size>>s->chroma_h_shift : block_size;
 +    const int block_h    = plane_index ? block_size>>s->chroma_v_shift : block_size;
 +    const uint8_t *obmc  = plane_index ? ff_obmc_tab[s->block_max_depth+s->chroma_h_shift] : ff_obmc_tab[s->block_max_depth];
 +    const int obmc_stride= plane_index ? (2*block_size)>>s->chroma_h_shift : 2*block_size;
      const int ref_stride= s->current_picture.linesize[plane_index];
      uint8_t *dst= s->current_picture.data[plane_index];
      uint8_t *src= s-> input_picture.data[plane_index];
      int rate= 0;
      const int penalty_factor= get_penalty_factor(s->lambda, s->lambda2, s->avctx->me_cmp);
  
 +    av_assert2(s->chroma_h_shift == s->chroma_v_shift); //obmc and square assumtions below
 +
      for(i=0; i<9; i++){
          int mb_x2= mb_x + (i%3) - 1;
          int mb_y2= mb_y + (i/3) - 1;
          int x= block_w*mb_x2 + block_w/2;
 -        int y= block_w*mb_y2 + block_w/2;
 +        int y= block_h*mb_y2 + block_h/2;
  
          add_yblock(s, 0, NULL, zero_dst, dst, obmc,
 -                   x, y, block_w, block_w, w, h, /*dst_stride*/0, ref_stride, obmc_stride, mb_x2, mb_y2, 1, 1, plane_index);
 +                   x, y, block_w, block_h, w, h, /*dst_stride*/0, ref_stride, obmc_stride, mb_x2, mb_y2, 1, 1, plane_index);
  
          //FIXME find a cleaner/simpler way to skip the outside stuff
          for(y2= y; y2<0; y2++)
              memcpy(dst + x + y2*ref_stride, src + x + y2*ref_stride, block_w);
 -        for(y2= h; y2<y+block_w; y2++)
 +        for(y2= h; y2<y+block_h; y2++)
              memcpy(dst + x + y2*ref_stride, src + x + y2*ref_stride, block_w);
          if(x<0){
 -            for(y2= y; y2<y+block_w; y2++)
 +            for(y2= y; y2<y+block_h; y2++)
                  memcpy(dst + x + y2*ref_stride, src + x + y2*ref_stride, -x);
          }
          if(x+block_w > w){
 -            for(y2= y; y2<y+block_w; y2++)
 +            for(y2= y; y2<y+block_h; y2++)
                  memcpy(dst + w + y2*ref_stride, src + w + y2*ref_stride, x+block_w - w);
          }
  
          assert(block_w== 8 || block_w==16);
 -        distortion += s->dsp.me_cmp[block_w==8](&s->m, src + x + y*ref_stride, dst + x + y*ref_stride, ref_stride, block_w);
 +        distortion += s->dsp.me_cmp[block_w==8](&s->m, src + x + y*ref_stride, dst + x + y*ref_stride, ref_stride, block_h);
      }
  
      if(plane_index==0){
      return distortion + rate*penalty_factor;
  }
  
 -static int encode_subband_c0run(SnowContext *s, SubBand *b, IDWTELEM *src, IDWTELEM *parent, int stride, int orientation){
 +static int encode_subband_c0run(SnowContext *s, SubBand *b, const IDWTELEM *src, const IDWTELEM *parent, int stride, int orientation){
      const int w= b->width;
      const int h= b->height;
      int x, y;
      return 0;
  }
  
 -static int encode_subband(SnowContext *s, SubBand *b, IDWTELEM *src, IDWTELEM *parent, int stride, int orientation){
 +static int encode_subband(SnowContext *s, SubBand *b, const IDWTELEM *src, const IDWTELEM *parent, int stride, int orientation){
  //    encode_subband_qtree(s, b, src, parent, stride, orientation);
  //    encode_subband_z0run(s, b, src, parent, stride, orientation);
      return encode_subband_c0run(s, b, src, parent, stride, orientation);
@@@ -1013,10 -1005,18 +1013,18 @@@ static av_always_inline int check_block
  static av_always_inline int check_4block_inter(SnowContext *s, int mb_x, int mb_y, int p0, int p1, int ref, int *best_rd){
      const int b_stride= s->b_width << s->block_max_depth;
      BlockNode *block= &s->block[mb_x + mb_y * b_stride];
-     BlockNode backup[4]= {block[0], block[1], block[b_stride], block[b_stride+1]};
+     BlockNode backup[4];
      unsigned value;
      int rd, index;
  
+     /* We don't initialize backup[] during variable declaration, because
+      * that fails to compile on MSVC: "cannot convert from 'BlockNode' to
+      * 'int16_t'". */
+     backup[0] = block[0];
+     backup[1] = block[1];
+     backup[2] = block[b_stride];
+     backup[3] = block[b_stride + 1];
      assert(mb_x>=0 && mb_y>=0);
      assert(mb_x<b_stride);
      assert(((mb_x|mb_y)&1) == 0);
@@@ -1128,23 -1128,22 +1136,23 @@@ static void iterative_me(SnowContext *s
                      uint8_t *dst= s->current_picture.data[0];
                      const int stride= s->current_picture.linesize[0];
                      const int block_w= MB_SIZE >> s->block_max_depth;
 +                    const int block_h= MB_SIZE >> s->block_max_depth;
                      const int sx= block_w*mb_x - block_w/2;
 -                    const int sy= block_w*mb_y - block_w/2;
 +                    const int sy= block_h*mb_y - block_h/2;
                      const int w= s->plane[0].width;
                      const int h= s->plane[0].height;
                      int y;
  
                      for(y=sy; y<0; y++)
                          memcpy(dst + sx + y*stride, src + sx + y*stride, block_w*2);
 -                    for(y=h; y<sy+block_w*2; y++)
 +                    for(y=h; y<sy+block_h*2; y++)
                          memcpy(dst + sx + y*stride, src + sx + y*stride, block_w*2);
                      if(sx<0){
 -                        for(y=sy; y<sy+block_w*2; y++)
 +                        for(y=sy; y<sy+block_h*2; y++)
                              memcpy(dst + sx + y*stride, src + sx + y*stride, -sx);
                      }
                      if(sx+block_w*2 > w){
 -                        for(y=sy; y<sy+block_w*2; y++)
 +                        for(y=sy; y<sy+block_h*2; y++)
                              memcpy(dst + w + y*stride, src + w + y*stride, sx+block_w*2 - w);
                      }
                  }
@@@ -1624,19 -1623,21 +1632,19 @@@ static int encode_frame(AVCodecContext 
      uint8_t rc_header_bak[sizeof(s->header_state)];
      uint8_t rc_block_bak[sizeof(s->block_state)];
  
 -    if (!pkt->data &&
 -        (ret = av_new_packet(pkt, s->b_width*s->b_height*MB_SIZE*MB_SIZE*3 + FF_MIN_BUFFER_SIZE)) < 0) {
 -        av_log(avctx, AV_LOG_ERROR, "Error getting output packet.\n");
 +    if ((ret = ff_alloc_packet2(avctx, pkt, s->b_width*s->b_height*MB_SIZE*MB_SIZE*3 + FF_MIN_BUFFER_SIZE)) < 0)
          return ret;
 -    }
  
      ff_init_range_encoder(c, pkt->data, pkt->size);
      ff_build_rac_states(c, 0.05*(1LL<<32), 256-8);
  
      for(i=0; i<3; i++){
 -        int shift= !!i;
 -        for(y=0; y<(height>>shift); y++)
 +        int hshift= i ? s->chroma_h_shift : 0;
 +        int vshift= i ? s->chroma_v_shift : 0;
 +        for(y=0; y<(height>>vshift); y++)
              memcpy(&s->input_picture.data[i][y * s->input_picture.linesize[i]],
                     &pict->data[i][y * pict->linesize[i]],
 -                   width>>shift);
 +                   width>>hshift);
      }
      s->new_picture = *pict;
  
@@@ -1724,10 -1725,6 +1732,10 @@@ redo_frame
      else
          s->spatial_decomposition_count= 5;
  
 +    while(   !(width >>(s->chroma_h_shift + s->spatial_decomposition_count))
 +          || !(height>>(s->chroma_v_shift + s->spatial_decomposition_count)))
 +        s->spatial_decomposition_count--;
 +
      s->m.pict_type = pic->pict_type;
      s->qbias = pic->pict_type == AV_PICTURE_TYPE_P ? 2 : 0;
  
                          quantize(s, b, b->ibuf, b->buf, b->stride, s->qbias);
                      if(orientation==0)
                          decorrelate(s, b, b->ibuf, b->stride, pic->pict_type == AV_PICTURE_TYPE_P, 0);
 +                    if (!s->no_bitstream)
                      encode_subband(s, b, b->ibuf, b->parent ? b->parent->ibuf : NULL, b->stride, orientation);
                      assert(b->parent==NULL || b->parent->stride == b->stride*2);
                      if(orientation==0)
@@@ -1919,7 -1915,6 +1927,7 @@@ static av_cold int encode_end(AVCodecCo
  #define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
  static const AVOption options[] = {
      { "memc_only",      "Only do ME/MC (I frames -> ref, P frame -> ME+MC).",   OFFSET(memc_only), AV_OPT_TYPE_INT, { 0 }, 0, 1, VE },
 +    { "no_bitstream",   "Skip final bitstream writeout.",                    OFFSET(no_bitstream), AV_OPT_TYPE_INT, { 0 }, 0, 1, VE },
      { NULL },
  };
  
@@@ -1938,134 -1933,6 +1946,134 @@@ AVCodec ff_snow_encoder = 
      .init           = encode_init,
      .encode2        = encode_frame,
      .close          = encode_end,
 +    .pix_fmts       = (const enum PixelFormat[]){
 +        PIX_FMT_YUV420P, PIX_FMT_YUV410P, PIX_FMT_YUV444P,
 +        PIX_FMT_NONE
 +    },
      .long_name      = NULL_IF_CONFIG_SMALL("Snow"),
      .priv_class     = &snowenc_class,
  };
 +
 +
 +#ifdef TEST
 +#undef malloc
 +#undef free
 +#undef printf
 +
 +#include "libavutil/lfg.h"
 +#include "libavutil/mathematics.h"
 +
 +int main(void){
 +    int width=256;
 +    int height=256;
 +    int buffer[2][width*height];
 +    SnowContext s;
 +    int i;
 +    AVLFG prng;
 +    s.spatial_decomposition_count=6;
 +    s.spatial_decomposition_type=1;
 +
 +    s.temp_dwt_buffer  = av_mallocz(width * sizeof(DWTELEM));
 +    s.temp_idwt_buffer = av_mallocz(width * sizeof(IDWTELEM));
 +
 +    av_lfg_init(&prng, 1);
 +
 +    printf("testing 5/3 DWT\n");
 +    for(i=0; i<width*height; i++)
 +        buffer[0][i] = buffer[1][i] = av_lfg_get(&prng) % 54321 - 12345;
 +
 +    ff_spatial_dwt(buffer[0], s.temp_dwt_buffer, width, height, width, s.spatial_decomposition_type, s.spatial_decomposition_count);
 +    ff_spatial_idwt((IDWTELEM*)buffer[0], s.temp_idwt_buffer, width, height, width, s.spatial_decomposition_type, s.spatial_decomposition_count);
 +
 +    for(i=0; i<width*height; i++)
 +        if(buffer[0][i]!= buffer[1][i]) printf("fsck: %6d %12d %7d\n",i, buffer[0][i], buffer[1][i]);
 +
 +    printf("testing 9/7 DWT\n");
 +    s.spatial_decomposition_type=0;
 +    for(i=0; i<width*height; i++)
 +        buffer[0][i] = buffer[1][i] = av_lfg_get(&prng) % 54321 - 12345;
 +
 +    ff_spatial_dwt(buffer[0], s.temp_dwt_buffer, width, height, width, s.spatial_decomposition_type, s.spatial_decomposition_count);
 +    ff_spatial_idwt((IDWTELEM*)buffer[0], s.temp_idwt_buffer, width, height, width, s.spatial_decomposition_type, s.spatial_decomposition_count);
 +
 +    for(i=0; i<width*height; i++)
 +        if(FFABS(buffer[0][i] - buffer[1][i])>20) printf("fsck: %6d %12d %7d\n",i, buffer[0][i], buffer[1][i]);
 +
 +    {
 +    int level, orientation, x, y;
 +    int64_t errors[8][4];
 +    int64_t g=0;
 +
 +        memset(errors, 0, sizeof(errors));
 +        s.spatial_decomposition_count=3;
 +        s.spatial_decomposition_type=0;
 +        for(level=0; level<s.spatial_decomposition_count; level++){
 +            for(orientation=level ? 1 : 0; orientation<4; orientation++){
 +                int w= width  >> (s.spatial_decomposition_count-level);
 +                int h= height >> (s.spatial_decomposition_count-level);
 +                int stride= width  << (s.spatial_decomposition_count-level);
 +                DWTELEM *buf= buffer[0];
 +                int64_t error=0;
 +
 +                if(orientation&1) buf+=w;
 +                if(orientation>1) buf+=stride>>1;
 +
 +                memset(buffer[0], 0, sizeof(int)*width*height);
 +                buf[w/2 + h/2*stride]= 256*256;
 +                ff_spatial_idwt((IDWTELEM*)buffer[0], s.temp_idwt_buffer, width, height, width, s.spatial_decomposition_type, s.spatial_decomposition_count);
 +                for(y=0; y<height; y++){
 +                    for(x=0; x<width; x++){
 +                        int64_t d= buffer[0][x + y*width];
 +                        error += d*d;
 +                        if(FFABS(width/2-x)<9 && FFABS(height/2-y)<9 && level==2) printf("%8"PRId64" ", d);
 +                    }
 +                    if(FFABS(height/2-y)<9 && level==2) printf("\n");
 +                }
 +                error= (int)(sqrt(error)+0.5);
 +                errors[level][orientation]= error;
 +                if(g) g=av_gcd(g, error);
 +                else g= error;
 +            }
 +        }
 +        printf("static int const visual_weight[][4]={\n");
 +        for(level=0; level<s.spatial_decomposition_count; level++){
 +            printf("  {");
 +            for(orientation=0; orientation<4; orientation++){
 +                printf("%8"PRId64",", errors[level][orientation]/g);
 +            }
 +            printf("},\n");
 +        }
 +        printf("};\n");
 +        {
 +            int level=2;
 +            int w= width  >> (s.spatial_decomposition_count-level);
 +            //int h= height >> (s.spatial_decomposition_count-level);
 +            int stride= width  << (s.spatial_decomposition_count-level);
 +            DWTELEM *buf= buffer[0];
 +            int64_t error=0;
 +
 +            buf+=w;
 +            buf+=stride>>1;
 +
 +            memset(buffer[0], 0, sizeof(int)*width*height);
 +            for(y=0; y<height; y++){
 +                for(x=0; x<width; x++){
 +                    int tab[4]={0,2,3,1};
 +                    buffer[0][x+width*y]= 256*256*tab[(x&1) + 2*(y&1)];
 +                }
 +            }
 +            ff_spatial_dwt(buffer[0], s.temp_dwt_buffer, width, height, width, s.spatial_decomposition_type, s.spatial_decomposition_count);
 +            for(y=0; y<height; y++){
 +                for(x=0; x<width; x++){
 +                    int64_t d= buffer[0][x + y*width];
 +                    error += d*d;
 +                    if(FFABS(width/2-x)<9 && FFABS(height/2-y)<9) printf("%8"PRId64" ", d);
 +                }
 +                if(FFABS(height/2-y)<9) printf("\n");
 +            }
 +        }
 +
 +    }
 +    return 0;
 +}
 +#endif /* TEST */
diff --combined libavcodec/vc1dec.c
@@@ -4,20 -4,20 +4,20 @@@
   * Copyright (c) 2006-2007 Konstantin Shishkov
   * Partly based on vc9.c (c) 2005 Anonymous, Alex Beregszaszi, Michael Niedermayer
   *
 - * 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
   */
  
@@@ -39,7 -39,6 +39,7 @@@
  #include "simple_idct.h"
  #include "mathops.h"
  #include "vdpau_internal.h"
 +#include "libavutil/avassert.h"
  
  #undef NDEBUG
  #include <assert.h>
@@@ -370,7 -369,7 +370,7 @@@ static void vc1_mc_1mv(VC1Context *v, i
      }
      if (v->field_mode) { // interlaced field picture
          if (!dir) {
 -            if ((v->cur_field_type != v->ref_field_type[dir]) && v->cur_field_type) {
 +            if ((v->cur_field_type != v->ref_field_type[dir]) && v->second_field) {
                  srcY = s->current_picture.f.data[0];
                  srcU = s->current_picture.f.data[1];
                  srcV = s->current_picture.f.data[2];
          srcY += s->mspel * (1 + s->linesize);
      }
  
 -    if (v->field_mode && v->cur_field_type) {
 +    if (v->field_mode && v->second_field) {
          off    = s->current_picture_ptr->f.linesize[0];
          off_uv = s->current_picture_ptr->f.linesize[1];
      } else {
@@@ -562,7 -561,7 +562,7 @@@ static void vc1_mc_4mv_luma(VC1Context 
  
      if (!dir) {
          if (v->field_mode) {
 -            if ((v->cur_field_type != v->ref_field_type[dir]) && v->cur_field_type)
 +            if ((v->cur_field_type != v->ref_field_type[dir]) && v->second_field)
                  srcY = s->current_picture.f.data[0];
              else
                  srcY = s->last_picture.f.data[0];
          off = ((n > 1) ? s->linesize : 0) + (n & 1) * 8;
      else
          off = s->linesize * 4 * (n & 2) + (n & 1) * 8;
 -    if (v->field_mode && v->cur_field_type)
 +    if (v->field_mode && v->second_field)
          off += s->current_picture_ptr->f.linesize[0];
  
      src_x = s->mb_x * 16 + (n & 1) * 8 + (mx >> 2);
@@@ -862,7 -861,7 +862,7 @@@ static void vc1_mc_4mv_chroma(VC1Contex
              srcU += s->current_picture_ptr->f.linesize[1];
              srcV += s->current_picture_ptr->f.linesize[2];
          }
 -        off = v->cur_field_type ? s->current_picture_ptr->f.linesize[1] : 0;
 +        off = v->second_field ? s->current_picture_ptr->f.linesize[1] : 0;
      }
  
      if (v->rangeredfrm || (v->mv_mode == MV_PMODE_INTENSITY_COMP)
@@@ -1049,10 -1048,6 +1049,10 @@@ static void vc1_mc_4mv_chroma4(VC1Conte
              mquant = v->altpq;                                 \
          if ((edges&8) && s->mb_y == (s->mb_height - 1))        \
              mquant = v->altpq;                                 \
 +        if (!mquant || mquant > 31) {                          \
 +            av_log(v->s.avctx, AV_LOG_ERROR, "invalid mquant %d\n", mquant);   \
 +            mquant = 1;                                \
 +        }                                              \
      }
  
  /**
@@@ -1138,7 -1133,6 +1138,7 @@@ static av_always_inline void get_mvdata
          }
      }
      else {
 +        av_assert0(index < esc);
          if (extend_x)
              offs_tab = offset_table2;
          else
@@@ -1790,7 -1784,7 +1790,7 @@@ static inline void vc1_pred_mv_intfr(VC
                  } else if (c_valid) {
                      px = C[0];
                      py = C[1];
 -                }
 +                } else px = py = 0;
              }
          } else if (total_valid == 1) {
              px = (a_valid) ? A[0] : ((b_valid) ? B[0] : C[0]);
@@@ -1923,7 -1917,7 +1923,7 @@@ static void vc1_interp_mc(VC1Context *v
          srcY += s->mspel * (1 + s->linesize);
      }
  
 -    if (v->field_mode && v->cur_field_type) {
 +    if (v->field_mode && v->second_field) {
          off    = s->current_picture_ptr->f.linesize[0];
          off_uv = s->current_picture_ptr->f.linesize[1];
      } else {
@@@ -3704,7 -3698,7 +3704,7 @@@ static int vc1_decode_p_mb_intfr(VC1Con
      int idx_mbmode = 0, mvbp;
      int stride_y, fieldtx;
  
 -    mquant = v->pq; /* Loosy initialization */
 +    mquant = v->pq; /* Lossy initialization */
  
      if (v->skip_is_raw)
          skipped = get_bits1(gb);
@@@ -3908,11 -3902,11 +3908,11 @@@ static int vc1_decode_p_mb_intfi(VC1Con
      int val; /* temp values */
      int first_block = 1;
      int dst_idx, off;
 -    int pred_flag;
 +    int pred_flag = 0;
      int block_cbp = 0, pat, block_tt = 0;
      int idx_mbmode = 0;
  
 -    mquant = v->pq; /* Loosy initialization */
 +    mquant = v->pq; /* Lossy initialization */
  
      idx_mbmode = get_vlc2(gb, v->mbmode_vlc->table, VC1_IF_MBMODE_VLC_BITS, 2);
      if (idx_mbmode <= 1) { // intra MB
                  continue;
              v->vc1dsp.vc1_inv_trans_8x8(s->block[i]);
              off  = (i & 4) ? 0 : ((i & 1) * 8 + (i & 2) * 4 * s->linesize);
 -            off += v->cur_field_type ? ((i & 4) ? s->current_picture_ptr->f.linesize[1] : s->current_picture_ptr->f.linesize[0]) : 0;
 +            off += v->second_field ? ((i & 4) ? s->current_picture_ptr->f.linesize[1] : s->current_picture_ptr->f.linesize[0]) : 0;
              s->dsp.put_signed_pixels_clamped(s->block[i], s->dest[dst_idx] + off, (i & 4) ? s->uvlinesize : s->linesize);
              // TODO: loop filter
          }
          s->current_picture.f.mb_type[mb_pos + v->mb_off] = MB_TYPE_16x16;
          for (i = 0; i < 6; i++) v->mb_type[0][s->block_index[i]] = 0;
          if (idx_mbmode <= 5) { // 1-MV
-             dmv_x = dmv_y = 0;
+             dmv_x = dmv_y = pred_flag = 0;
              if (idx_mbmode & 1) {
                  get_mvdata_interlaced(v, &dmv_x, &dmv_y, &pred_flag);
              }
              dst_idx += i >> 2;
              val = ((cbp >> (5 - i)) & 1);
              off = (i & 4) ? 0 : (i & 1) * 8 + (i & 2) * 4 * s->linesize;
 -            if (v->cur_field_type)
 +            if (v->second_field)
                  off += (i & 4) ? s->current_picture_ptr->f.linesize[1] : s->current_picture_ptr->f.linesize[0];
              if (val) {
                  pat = vc1_decode_p_block(v, s->block[i], i, mquant, ttmb,
@@@ -4185,7 -4179,7 +4185,7 @@@ static void vc1_decode_b_mb_intfi(VC1Co
      int bmvtype = BMV_TYPE_BACKWARD;
      int idx_mbmode, interpmvp;
  
 -    mquant      = v->pq; /* Loosy initialization */
 +    mquant      = v->pq; /* Lossy initialization */
      s->mb_intra = 0;
  
      idx_mbmode = get_vlc2(gb, v->mbmode_vlc->table, VC1_IF_MBMODE_VLC_BITS, 2);
                  for (j = 0; j < 64; j++)
                      s->block[i][j] <<= 1;
              off  = (i & 4) ? 0 : ((i & 1) * 8 + (i & 2) * 4 * s->linesize);
 -            off += v->cur_field_type ? ((i & 4) ? s->current_picture_ptr->f.linesize[1] : s->current_picture_ptr->f.linesize[0]) : 0;
 +            off += v->second_field ? ((i & 4) ? s->current_picture_ptr->f.linesize[1] : s->current_picture_ptr->f.linesize[0]) : 0;
              s->dsp.put_signed_pixels_clamped(s->block[i], s->dest[dst_idx] + off, (i & 4) ? s->uvlinesize : s->linesize);
              // TODO: yet to perform loop filter
          }
              dst_idx += i >> 2;
              val = ((cbp >> (5 - i)) & 1);
              off = (i & 4) ? 0 : (i & 1) * 8 + (i & 2) * 4 * s->linesize;
 -            if (v->cur_field_type)
 +            if (v->second_field)
                  off += (i & 4) ? s->current_picture_ptr->f.linesize[1] : s->current_picture_ptr->f.linesize[0];
              if (val) {
                  vc1_decode_p_block(v, s->block[i], i, mquant, ttmb,
@@@ -4952,7 -4946,7 +4952,7 @@@ static void vc1_draw_sprites(VC1Contex
                  if (!(xoff[sprite] & 0xFFFF) && xadv[sprite] == 1 << 16) {
                          src_h[sprite][0] = iplane + (xoff[sprite] >> 16) +  yline      * iline;
                      if (ysub[sprite])
 -                        src_h[sprite][1] = iplane + (xoff[sprite] >> 16) + (yline + 1) * iline;
 +                        src_h[sprite][1] = iplane + (xoff[sprite] >> 16) + FFMIN(yline + 1, (v->sprite_height>>!!plane)-1) * iline;
                  } else {
                      if (sr_cache[sprite][0] != yline) {
                          if (sr_cache[sprite][1] == yline) {
                          }
                      }
                      if (ysub[sprite] && sr_cache[sprite][1] != yline + 1) {
 -                        v->vc1dsp.sprite_h(v->sr_rows[sprite][1], iplane + (yline + 1) * iline, xoff[sprite], xadv[sprite], width);
 +                        v->vc1dsp.sprite_h(v->sr_rows[sprite][1], iplane + FFMIN(yline + 1, (v->sprite_height>>!!plane)-1) * iline, xoff[sprite], xadv[sprite], width);
                          sr_cache[sprite][1] = yline + 1;
                      }
                      src_h[sprite][0] = v->sr_rows[sprite][0];
@@@ -5318,16 -5312,13 +5318,16 @@@ static int vc1_decode_frame(AVCodecCont
      AVFrame *pict = data;
      uint8_t *buf2 = NULL;
      const uint8_t *buf_start = buf;
 -    int mb_height, n_slices1;
 +    int mb_height, n_slices1=-1;
      struct {
          uint8_t *buf;
          GetBitContext gb;
          int mby_start;
      } *slices = NULL, *tmp;
  
 +    if(s->flags & CODEC_FLAG_LOW_DELAY)
 +        s->low_delay = 1;
 +
      /* no supplementary picture */
      if (buf_size == 0 || (buf_size == 4 && AV_RB32(buf) == VC1_CODE_ENDOFSEQ)) {
          /* special case for last picture */
      // do parse frame header
      v->pic_header_flag = 0;
      if (v->profile < PROFILE_ADVANCED) {
 -        if (ff_vc1_parse_frame_header(v, &s->gb) == -1) {
 +        if (ff_vc1_parse_frame_header(v, &s->gb) < 0) {
              goto err;
          }
      } else {
 -        if (ff_vc1_parse_frame_header_adv(v, &s->gb) == -1) {
 +        if (ff_vc1_parse_frame_header_adv(v, &s->gb) < 0) {
              goto err;
          }
      }
          goto err;
      }
  
 +    v->s.current_picture_ptr->f.interlaced_frame = (v->fcm != PROGRESSIVE);
 +    v->s.current_picture_ptr->f.top_field_first  = v->tff;
 +
      s->me.qpel_put = s->dsp.put_qpel_pixels_tab;
      s->me.qpel_avg = s->dsp.avg_qpel_pixels_tab;
  
          mb_height = s->mb_height >> v->field_mode;
          for (i = 0; i <= n_slices; i++) {
              if (i > 0 &&  slices[i - 1].mby_start >= mb_height) {
 +                if(v->field_mode <= 0) {
 +                    av_log(v->s.avctx, AV_LOG_ERROR, "invalid end_mb_y %d\n", slices[i - 1].mby_start);
 +                    continue;
 +                }
                  v->second_field = 1;
                  v->blocks_off   = s->mb_width  * s->mb_height << 1;
                  v->mb_off       = s->mb_stride * s->mb_height >> 1;
              }
              if (i) {
                  v->pic_header_flag = 0;
 -                if (v->field_mode && i == n_slices1 + 2)
 -                    ff_vc1_parse_frame_header_adv(v, &s->gb);
 -                else if (get_bits1(&s->gb)) {
 +                if (v->field_mode && i == n_slices1 + 2) {
 +                    if (ff_vc1_parse_frame_header_adv(v, &s->gb) < 0) {
 +                        av_log(v->s.avctx, AV_LOG_ERROR, "slice header damaged\n");
 +                        continue;
 +                    }
 +                } else if (get_bits1(&s->gb)) {
                      v->pic_header_flag = 1;
 -                    ff_vc1_parse_frame_header_adv(v, &s->gb);
 +                    if (ff_vc1_parse_frame_header_adv(v, &s->gb) < 0) {
 +                        av_log(v->s.avctx, AV_LOG_ERROR, "slice header damaged\n");
 +                        continue;
 +                    }
                  }
              }
              s->start_mb_y = (i == 0) ? 0 : FFMAX(0, slices[i-1].mby_start % mb_height);
                  s->end_mb_y = (i == n_slices     ) ? mb_height : FFMIN(mb_height, slices[i].mby_start % mb_height);
              else
                  s->end_mb_y = (i <= n_slices1 + 1) ? mb_height : FFMIN(mb_height, slices[i].mby_start % mb_height);
 +            if (s->end_mb_y <= s->start_mb_y) {
 +                av_log(v->s.avctx, AV_LOG_ERROR, "end mb y %d %d invalid\n", s->end_mb_y, s->start_mb_y);
 +                continue;
 +            }
              vc1_decode_blocks(v);
              if (i != n_slices)
                  s->gb = slices[i].gb;
  //av_log(s->avctx, AV_LOG_INFO, "Consumed %i/%i bits\n", get_bits_count(&s->gb), s->gb.size_in_bits);
  //  if (get_bits_count(&s->gb) > buf_size * 8)
  //      return -1;
 +        if(s->error_occurred && s->pict_type == AV_PICTURE_TYPE_B)
 +            goto err;
          ff_er_frame_end(s);
      }
  
diff --combined libavcodec/vp8.c
@@@ -4,21 -4,22 +4,22 @@@
   * Copyright (C) 2010 David Conrad
   * Copyright (C) 2010 Ronald S. Bultje
   * Copyright (C) 2010 Jason Garrett-Glaser
+  * Copyright (C) 2012 Daniel Kang
   *
 - * 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
   */
  
  
  static void free_buffers(VP8Context *s)
  {
+     int i;
+     if (s->thread_data)
+         for (i = 0; i < MAX_THREADS; i++) {
+             av_freep(&s->thread_data[i].filter_strength);
+             av_freep(&s->thread_data[i].edge_emu_buffer);
+         }
+     av_freep(&s->thread_data);
      av_freep(&s->macroblocks_base);
-     av_freep(&s->filter_strength);
      av_freep(&s->intra4x4_pred_mode_top);
      av_freep(&s->top_nnz);
-     av_freep(&s->edge_emu_buffer);
      av_freep(&s->top_border);
  
      s->macroblocks = NULL;
@@@ -108,7 -114,10 +114,10 @@@ static void vp8_decode_flush(AVCodecCon
  
  static int update_dimensions(VP8Context *s, int width, int height)
  {
 -    if (width  != s->avctx->width ||
+     AVCodecContext *avctx = s->avctx;
+     int i;
 +    if (width  != s->avctx->width || ((width+15)/16 != s->mb_width || (height+15)/16 != s->mb_height) && s->macroblocks_base ||
          height != s->avctx->height) {
          if (av_image_check_size(width, height, 0, s->avctx))
              return AVERROR_INVALIDDATA;
      s->mb_width  = (s->avctx->coded_width +15) / 16;
      s->mb_height = (s->avctx->coded_height+15) / 16;
  
-     s->macroblocks_base        = av_mallocz((s->mb_width+s->mb_height*2+1)*sizeof(*s->macroblocks));
-     s->filter_strength         = av_mallocz(s->mb_width*sizeof(*s->filter_strength));
-     s->intra4x4_pred_mode_top  = av_mallocz(s->mb_width*4);
-     s->top_nnz                 = av_mallocz(s->mb_width*sizeof(*s->top_nnz));
-     s->top_border              = av_mallocz((s->mb_width+1)*sizeof(*s->top_border));
+     s->mb_layout = (avctx->active_thread_type == FF_THREAD_SLICE) && (FFMIN(s->num_coeff_partitions, avctx->thread_count) > 1);
+     if (!s->mb_layout) { // Frame threading and one thread
+         s->macroblocks_base       = av_mallocz((s->mb_width+s->mb_height*2+1)*sizeof(*s->macroblocks));
+         s->intra4x4_pred_mode_top = av_mallocz(s->mb_width*4);
+     }
+     else // Sliced threading
+         s->macroblocks_base       = av_mallocz((s->mb_width+2)*(s->mb_height+2)*sizeof(*s->macroblocks));
+     s->top_nnz                    = av_mallocz(s->mb_width*sizeof(*s->top_nnz));
+     s->top_border                 = av_mallocz((s->mb_width+1)*sizeof(*s->top_border));
+     s->thread_data                = av_mallocz(MAX_THREADS*sizeof(VP8ThreadData));
+     for (i = 0; i < MAX_THREADS; i++) {
+         s->thread_data[i].filter_strength = av_mallocz(s->mb_width*sizeof(*s->thread_data[0].filter_strength));
+ #if HAVE_THREADS
+         pthread_mutex_init(&s->thread_data[i].lock, NULL);
+         pthread_cond_init(&s->thread_data[i].cond, NULL);
+ #endif
+     }
  
-     if (!s->macroblocks_base || !s->filter_strength || !s->intra4x4_pred_mode_top ||
-         !s->top_nnz || !s->top_border)
+     if (!s->macroblocks_base || !s->top_nnz || !s->top_border ||
+         (!s->intra4x4_pred_mode_top && !s->mb_layout))
          return AVERROR(ENOMEM);
  
      s->macroblocks        = s->macroblocks_base + 1;
@@@ -332,12 -354,6 +354,6 @@@ static int decode_frame_header(VP8Conte
          memset(&s->segmentation, 0, sizeof(s->segmentation));
      }
  
-     if (!s->macroblocks_base || /* first frame */
-         width != s->avctx->width || height != s->avctx->height || (width+15)/16 != s->mb_width || (height+15)/16 != s->mb_height) {
-         if ((ret = update_dimensions(s, width, height)) < 0)
-             return ret;
-     }
      ff_vp56_init_range_decoder(c, buf, header_size);
      buf      += header_size;
      buf_size -= header_size;
          return AVERROR_INVALIDDATA;
      }
  
 -        width != s->avctx->width || height != s->avctx->height) {
+     if (!s->macroblocks_base || /* first frame */
++        width != s->avctx->width || height != s->avctx->height || (width+15)/16 != s->mb_width || (height+15)/16 != s->mb_height) {
+         if ((ret = update_dimensions(s, width, height)) < 0)
+             return ret;
+     }
      get_quants(s);
  
      if (!s->keyframe) {
@@@ -468,19 -490,26 +490,26 @@@ const uint8_t *get_submv_prob(uint32_t 
   * @returns the number of motion vectors parsed (2, 4 or 16)
   */
  static av_always_inline
- int decode_splitmvs(VP8Context *s, VP56RangeCoder *c, VP8Macroblock *mb)
+ int decode_splitmvs(VP8Context *s, VP56RangeCoder *c, VP8Macroblock *mb, int layout)
  {
      int part_idx;
      int n, num;
-     VP8Macroblock *top_mb  = &mb[2];
+     VP8Macroblock *top_mb;
      VP8Macroblock *left_mb = &mb[-1];
      const uint8_t *mbsplits_left = vp8_mbsplits[left_mb->partitioning],
-                   *mbsplits_top = vp8_mbsplits[top_mb->partitioning],
+                   *mbsplits_top,
                    *mbsplits_cur, *firstidx;
-     VP56mv *top_mv  = top_mb->bmv;
+     VP56mv *top_mv;
      VP56mv *left_mv = left_mb->bmv;
      VP56mv *cur_mv  = mb->bmv;
  
+     if (!layout) // layout is inlined, s->mb_layout is not
+         top_mb = &mb[2];
+     else
+         top_mb = &mb[-s->mb_width-1];
+     mbsplits_top = vp8_mbsplits[top_mb->partitioning];
+     top_mv = top_mb->bmv;
      if (vp56_rac_get_prob_branchy(c, vp8_mbsplit_prob[0])) {
          if (vp56_rac_get_prob_branchy(c, vp8_mbsplit_prob[1])) {
              part_idx = VP8_SPLITMVMODE_16x8 + vp56_rac_get_prob(c, vp8_mbsplit_prob[2]);
  }
  
  static av_always_inline
- void decode_mvs(VP8Context *s, VP8Macroblock *mb, int mb_x, int mb_y)
+ void decode_mvs(VP8Context *s, VP8Macroblock *mb, int mb_x, int mb_y, int layout)
  {
-     VP8Macroblock *mb_edge[3] = { mb + 2 /* top */,
+     VP8Macroblock *mb_edge[3] = { 0 /* top */,
                                    mb - 1 /* left */,
-                                   mb + 1 /* top-left */ };
+                                   0 /* top-left */ };
      enum { CNT_ZERO, CNT_NEAREST, CNT_NEAR, CNT_SPLITMV };
      enum { VP8_EDGE_TOP, VP8_EDGE_LEFT, VP8_EDGE_TOPLEFT };
      int idx = CNT_ZERO;
      uint8_t cnt[4] = { 0 };
      VP56RangeCoder *c = &s->c;
  
+     if (!layout) { // layout is inlined (s->mb_layout is not)
+         mb_edge[0] = mb + 2;
+         mb_edge[2] = mb + 1;
+     }
+     else {
+         mb_edge[0] = mb - s->mb_width-1;
+         mb_edge[2] = mb - s->mb_width-2;
+     }
      AV_ZERO32(&near_mv[0]);
      AV_ZERO32(&near_mv[1]);
      AV_ZERO32(&near_mv[2]);
  
                  if (vp56_rac_get_prob_branchy(c, vp8_mode_contexts[cnt[CNT_SPLITMV]][3])) {
                      mb->mode = VP8_MVMODE_SPLIT;
-                     mb->mv = mb->bmv[decode_splitmvs(s, c, mb) - 1];
+                     mb->mv = mb->bmv[decode_splitmvs(s, c, mb, layout) - 1];
                  } else {
                      mb->mv.y += read_mv_component(c, s->prob->mvc[0]);
                      mb->mv.x += read_mv_component(c, s->prob->mvc[1]);
  }
  
  static av_always_inline
- void decode_intra4x4_modes(VP8Context *s, VP56RangeCoder *c,
-                            int mb_x, int keyframe)
+ void decode_intra4x4_modes(VP8Context *s, VP56RangeCoder *c, VP8Macroblock *mb,
+                            int mb_x, int keyframe, int layout)
  {
-     uint8_t *intra4x4 = s->intra4x4_pred_mode_mb;
+     uint8_t *intra4x4 = mb->intra4x4_pred_mode_mb;
+     if (layout == 1) {
+         VP8Macroblock *mb_top = mb - s->mb_width - 1;
+         memcpy(mb->intra4x4_pred_mode_top, mb_top->intra4x4_pred_mode_top, 4);
+     }
      if (keyframe) {
          int x, y;
-         uint8_t* const top = s->intra4x4_pred_mode_top + 4 * mb_x;
+         uint8_t* top;
          uint8_t* const left = s->intra4x4_pred_mode_left;
+         if (layout == 1)
+             top = mb->intra4x4_pred_mode_top;
+         else
+             top = s->intra4x4_pred_mode_top + 4 * mb_x;
          for (y = 0; y < 4; y++) {
              for (x = 0; x < 4; x++) {
                  const uint8_t *ctx;
  }
  
  static av_always_inline
- void decode_mb_mode(VP8Context *s, VP8Macroblock *mb, int mb_x, int mb_y, uint8_t *segment, uint8_t *ref)
+ void decode_mb_mode(VP8Context *s, VP8Macroblock *mb, int mb_x, int mb_y,
+                     uint8_t *segment, uint8_t *ref, int layout)
  {
      VP56RangeCoder *c = &s->c;
  
 -    if (s->segmentation.update_map)
 -        *segment = vp8_rac_get_tree(c, vp8_segmentid_tree, s->prob->segmentid);
 -    else if (s->segmentation.enabled)
 +    if (s->segmentation.update_map) {
 +        int bit  = vp56_rac_get_prob(c, s->prob->segmentid[0]);
 +        *segment = vp56_rac_get_prob(c, s->prob->segmentid[1+bit]) + 2*bit;
 +    } else if (s->segmentation.enabled)
          *segment = ref ? *ref : *segment;
-     s->segment = *segment;
+     mb->segment = *segment;
  
      mb->skip = s->mbskip_enabled ? vp56_rac_get_prob(c, s->prob->mbskip) : 0;
  
          mb->mode = vp8_rac_get_tree(c, vp8_pred16x16_tree_intra, vp8_pred16x16_prob_intra);
  
          if (mb->mode == MODE_I4x4) {
-             decode_intra4x4_modes(s, c, mb_x, 1);
+             decode_intra4x4_modes(s, c, mb, mb_x, 1, layout);
          } else {
              const uint32_t modes = vp8_pred4x4_mode[mb->mode] * 0x01010101u;
-             AV_WN32A(s->intra4x4_pred_mode_top + 4 * mb_x, modes);
-             AV_WN32A(s->intra4x4_pred_mode_left, modes);
+             if (s->mb_layout == 1)
+                 AV_WN32A(mb->intra4x4_pred_mode_top, modes);
+             else
+                 AV_WN32A(s->intra4x4_pred_mode_top + 4 * mb_x, modes);
+             AV_WN32A( s->intra4x4_pred_mode_left, modes);
          }
  
-         s->chroma_pred_mode = vp8_rac_get_tree(c, vp8_pred8x8c_tree, vp8_pred8x8c_prob_intra);
+         mb->chroma_pred_mode = vp8_rac_get_tree(c, vp8_pred8x8c_tree, vp8_pred8x8c_prob_intra);
          mb->ref_frame = VP56_FRAME_CURRENT;
      } else if (vp56_rac_get_prob_branchy(c, s->prob->intra)) {
          // inter MB, 16.2
          s->ref_count[mb->ref_frame-1]++;
  
          // motion vectors, 16.3
-         decode_mvs(s, mb, mb_x, mb_y);
+         decode_mvs(s, mb, mb_x, mb_y, layout);
      } else {
          // intra MB, 16.1
          mb->mode = vp8_rac_get_tree(c, vp8_pred16x16_tree_inter, s->prob->pred16x16);
  
          if (mb->mode == MODE_I4x4)
-             decode_intra4x4_modes(s, c, mb_x, 0);
+             decode_intra4x4_modes(s, c, mb, mb_x, 0, layout);
  
-         s->chroma_pred_mode = vp8_rac_get_tree(c, vp8_pred8x8c_tree, s->prob->pred8x8c);
+         mb->chroma_pred_mode = vp8_rac_get_tree(c, vp8_pred8x8c_tree, s->prob->pred8x8c);
          mb->ref_frame = VP56_FRAME_CURRENT;
          mb->partitioning = VP8_SPLITMVMODE_NONE;
          AV_ZERO32(&mb->bmv[0]);
@@@ -787,28 -837,28 +838,28 @@@ int decode_block_coeffs(VP56RangeCoder 
  }
  
  static av_always_inline
- void decode_mb_coeffs(VP8Context *s, VP56RangeCoder *c, VP8Macroblock *mb,
+ void decode_mb_coeffs(VP8Context *s, VP8ThreadData *td, VP56RangeCoder *c, VP8Macroblock *mb,
                        uint8_t t_nnz[9], uint8_t l_nnz[9])
  {
      int i, x, y, luma_start = 0, luma_ctx = 3;
      int nnz_pred, nnz, nnz_total = 0;
-     int segment = s->segment;
+     int segment = mb->segment;
      int block_dc = 0;
  
      if (mb->mode != MODE_I4x4 && mb->mode != VP8_MVMODE_SPLIT) {
          nnz_pred = t_nnz[8] + l_nnz[8];
  
          // decode DC values and do hadamard
-         nnz = decode_block_coeffs(c, s->block_dc, s->prob->token[1], 0, nnz_pred,
+         nnz = decode_block_coeffs(c, td->block_dc, s->prob->token[1], 0, nnz_pred,
                                    s->qmat[segment].luma_dc_qmul);
          l_nnz[8] = t_nnz[8] = !!nnz;
          if (nnz) {
              nnz_total += nnz;
              block_dc = 1;
              if (nnz == 1)
-                 s->vp8dsp.vp8_luma_dc_wht_dc(s->block, s->block_dc);
+                 s->vp8dsp.vp8_luma_dc_wht_dc(td->block, td->block_dc);
              else
-                 s->vp8dsp.vp8_luma_dc_wht(s->block, s->block_dc);
+                 s->vp8dsp.vp8_luma_dc_wht(td->block, td->block_dc);
          }
          luma_start = 1;
          luma_ctx = 0;
      for (y = 0; y < 4; y++)
          for (x = 0; x < 4; x++) {
              nnz_pred = l_nnz[y] + t_nnz[x];
-             nnz = decode_block_coeffs(c, s->block[y][x], s->prob->token[luma_ctx], luma_start,
+             nnz = decode_block_coeffs(c, td->block[y][x], s->prob->token[luma_ctx], luma_start,
                                        nnz_pred, s->qmat[segment].luma_qmul);
              // nnz+block_dc may be one more than the actual last index, but we don't care
-             s->non_zero_count_cache[y][x] = nnz + block_dc;
+             td->non_zero_count_cache[y][x] = nnz + block_dc;
              t_nnz[x] = l_nnz[y] = !!nnz;
              nnz_total += nnz;
          }
          for (y = 0; y < 2; y++)
              for (x = 0; x < 2; x++) {
                  nnz_pred = l_nnz[i+2*y] + t_nnz[i+2*x];
-                 nnz = decode_block_coeffs(c, s->block[i][(y<<1)+x], s->prob->token[2], 0,
+                 nnz = decode_block_coeffs(c, td->block[i][(y<<1)+x], s->prob->token[2], 0,
                                            nnz_pred, s->qmat[segment].chroma_qmul);
-                 s->non_zero_count_cache[i][(y<<1)+x] = nnz;
+                 td->non_zero_count_cache[i][(y<<1)+x] = nnz;
                  t_nnz[i+2*x] = l_nnz[i+2*y] = !!nnz;
                  nnz_total += nnz;
              }
@@@ -980,8 -1030,8 +1031,8 @@@ int check_intra_pred4x4_mode_emuedge(in
  }
  
  static av_always_inline
- void intra_predict(VP8Context *s, uint8_t *dst[3], VP8Macroblock *mb,
-                    int mb_x, int mb_y)
+ void intra_predict(VP8Context *s, VP8ThreadData *td, uint8_t *dst[3],
+                    VP8Macroblock *mb, int mb_x, int mb_y)
  {
      AVCodecContext *avctx = s->avctx;
      int x, y, mode, nnz;
  
      // for the first row, we need to run xchg_mb_border to init the top edge to 127
      // otherwise, skip it if we aren't going to deblock
-     if (!(avctx->flags & CODEC_FLAG_EMU_EDGE && !mb_y) && (s->deblock_filter || !mb_y))
+     if (!(avctx->flags & CODEC_FLAG_EMU_EDGE && !mb_y) && (s->deblock_filter || !mb_y) && td->thread_nr == 0)
          xchg_mb_border(s->top_border[mb_x+1], dst[0], dst[1], dst[2],
                         s->linesize, s->uvlinesize, mb_x, mb_y, s->mb_width,
                         s->filter.simple, 1);
          s->hpc.pred16x16[mode](dst[0], s->linesize);
      } else {
          uint8_t *ptr = dst[0];
-         uint8_t *intra4x4 = s->intra4x4_pred_mode_mb;
+         uint8_t *intra4x4 = mb->intra4x4_pred_mode_mb;
          uint8_t tr_top[4] = { 127, 127, 127, 127 };
  
          // all blocks on the right edge of the macroblock use bottom edge
          }
  
          if (mb->skip)
-             AV_ZERO128(s->non_zero_count_cache);
+             AV_ZERO128(td->non_zero_count_cache);
  
          for (y = 0; y < 4; y++) {
              uint8_t *topright = ptr + 4 - s->linesize;
                      AV_COPY32(ptr+4*x+s->linesize*3, copy_dst+36);
                  }
  
-                 nnz = s->non_zero_count_cache[y][x];
+                 nnz = td->non_zero_count_cache[y][x];
                  if (nnz) {
                      if (nnz == 1)
-                         s->vp8dsp.vp8_idct_dc_add(ptr+4*x, s->block[y][x], s->linesize);
+                         s->vp8dsp.vp8_idct_dc_add(ptr+4*x, td->block[y][x], s->linesize);
                      else
-                         s->vp8dsp.vp8_idct_add(ptr+4*x, s->block[y][x], s->linesize);
+                         s->vp8dsp.vp8_idct_add(ptr+4*x, td->block[y][x], s->linesize);
                  }
                  topright += 4;
              }
      }
  
      if (avctx->flags & CODEC_FLAG_EMU_EDGE) {
-         mode = check_intra_pred8x8_mode_emuedge(s->chroma_pred_mode, mb_x, mb_y);
+         mode = check_intra_pred8x8_mode_emuedge(mb->chroma_pred_mode, mb_x, mb_y);
      } else {
-         mode = check_intra_pred8x8_mode(s->chroma_pred_mode, mb_x, mb_y);
+         mode = check_intra_pred8x8_mode(mb->chroma_pred_mode, mb_x, mb_y);
      }
      s->hpc.pred8x8[mode](dst[1], s->uvlinesize);
      s->hpc.pred8x8[mode](dst[2], s->uvlinesize);
  
-     if (!(avctx->flags & CODEC_FLAG_EMU_EDGE && !mb_y) && (s->deblock_filter || !mb_y))
+     if (!(avctx->flags & CODEC_FLAG_EMU_EDGE && !mb_y) && (s->deblock_filter || !mb_y) && td->thread_nr == 0)
          xchg_mb_border(s->top_border[mb_x+1], dst[0], dst[1], dst[2],
                         s->linesize, s->uvlinesize, mb_x, mb_y, s->mb_width,
                         s->filter.simple, 0);
@@@ -1125,7 -1175,8 +1176,8 @@@ static const uint8_t subpel_idx[3][8] 
   * @param mc_func motion compensation function pointers (bilinear or sixtap MC)
   */
  static av_always_inline
- void vp8_mc_luma(VP8Context *s, uint8_t *dst, AVFrame *ref, const VP56mv *mv,
+ void vp8_mc_luma(VP8Context *s, VP8ThreadData *td, uint8_t *dst,
+                  AVFrame *ref, const VP56mv *mv,
                   int x_off, int y_off, int block_w, int block_h,
                   int width, int height, int linesize,
                   vp8_mc_func mc_func[3][3])
          src += y_off * linesize + x_off;
          if (x_off < mx_idx || x_off >= width  - block_w - subpel_idx[2][mx] ||
              y_off < my_idx || y_off >= height - block_h - subpel_idx[2][my]) {
-             s->dsp.emulated_edge_mc(s->edge_emu_buffer, src - my_idx * linesize - mx_idx, linesize,
+             s->dsp.emulated_edge_mc(td->edge_emu_buffer, src - my_idx * linesize - mx_idx, linesize,
                                      block_w + subpel_idx[1][mx], block_h + subpel_idx[1][my],
                                      x_off - mx_idx, y_off - my_idx, width, height);
-             src = s->edge_emu_buffer + mx_idx + linesize * my_idx;
+             src = td->edge_emu_buffer + mx_idx + linesize * my_idx;
          }
          mc_func[my_idx][mx_idx](dst, linesize, src, linesize, block_h, mx, my);
      } else {
   * @param mc_func motion compensation function pointers (bilinear or sixtap MC)
   */
  static av_always_inline
- void vp8_mc_chroma(VP8Context *s, uint8_t *dst1, uint8_t *dst2, AVFrame *ref,
-                    const VP56mv *mv, int x_off, int y_off,
+ void vp8_mc_chroma(VP8Context *s, VP8ThreadData *td, uint8_t *dst1, uint8_t *dst2,
+                    AVFrame *ref, const VP56mv *mv, int x_off, int y_off,
                     int block_w, int block_h, int width, int height, int linesize,
                     vp8_mc_func mc_func[3][3])
  {
          ff_thread_await_progress(ref, (3 + y_off + block_h + subpel_idx[2][my]) >> 3, 0);
          if (x_off < mx_idx || x_off >= width  - block_w - subpel_idx[2][mx] ||
              y_off < my_idx || y_off >= height - block_h - subpel_idx[2][my]) {
-             s->dsp.emulated_edge_mc(s->edge_emu_buffer, src1 - my_idx * linesize - mx_idx, linesize,
+             s->dsp.emulated_edge_mc(td->edge_emu_buffer, src1 - my_idx * linesize - mx_idx, linesize,
                                      block_w + subpel_idx[1][mx], block_h + subpel_idx[1][my],
                                      x_off - mx_idx, y_off - my_idx, width, height);
-             src1 = s->edge_emu_buffer + mx_idx + linesize * my_idx;
+             src1 = td->edge_emu_buffer + mx_idx + linesize * my_idx;
              mc_func[my_idx][mx_idx](dst1, linesize, src1, linesize, block_h, mx, my);
  
-             s->dsp.emulated_edge_mc(s->edge_emu_buffer, src2 - my_idx * linesize - mx_idx, linesize,
+             s->dsp.emulated_edge_mc(td->edge_emu_buffer, src2 - my_idx * linesize - mx_idx, linesize,
                                      block_w + subpel_idx[1][mx], block_h + subpel_idx[1][my],
                                      x_off - mx_idx, y_off - my_idx, width, height);
-             src2 = s->edge_emu_buffer + mx_idx + linesize * my_idx;
+             src2 = td->edge_emu_buffer + mx_idx + linesize * my_idx;
              mc_func[my_idx][mx_idx](dst2, linesize, src2, linesize, block_h, mx, my);
          } else {
              mc_func[my_idx][mx_idx](dst1, linesize, src1, linesize, block_h, mx, my);
  }
  
  static av_always_inline
- void vp8_mc_part(VP8Context *s, uint8_t *dst[3],
+ void vp8_mc_part(VP8Context *s, VP8ThreadData *td, uint8_t *dst[3],
                   AVFrame *ref_frame, int x_off, int y_off,
                   int bx_off, int by_off,
                   int block_w, int block_h,
      VP56mv uvmv = *mv;
  
      /* Y */
-     vp8_mc_luma(s, dst[0] + by_off * s->linesize + bx_off,
+     vp8_mc_luma(s, td, dst[0] + by_off * s->linesize + bx_off,
                  ref_frame, mv, x_off + bx_off, y_off + by_off,
                  block_w, block_h, width, height, s->linesize,
                  s->put_pixels_tab[block_w == 8]);
      bx_off  >>= 1; by_off  >>= 1;
      width   >>= 1; height  >>= 1;
      block_w >>= 1; block_h >>= 1;
-     vp8_mc_chroma(s, dst[1] + by_off * s->uvlinesize + bx_off,
+     vp8_mc_chroma(s, td, dst[1] + by_off * s->uvlinesize + bx_off,
                    dst[2] + by_off * s->uvlinesize + bx_off, ref_frame,
                    &uvmv, x_off + bx_off, y_off + by_off,
                    block_w, block_h, width, height, s->uvlinesize,
@@@ -1272,8 -1323,8 +1324,8 @@@ static av_always_inline void prefetch_m
   * Apply motion vectors to prediction buffer, chapter 18.
   */
  static av_always_inline
- void inter_predict(VP8Context *s, uint8_t *dst[3], VP8Macroblock *mb,
-                    int mb_x, int mb_y)
+ void inter_predict(VP8Context *s, VP8ThreadData *td, uint8_t *dst[3],
+                    VP8Macroblock *mb, int mb_x, int mb_y)
  {
      int x_off = mb_x << 4, y_off = mb_y << 4;
      int width = 16*s->mb_width, height = 16*s->mb_height;
  
      switch (mb->partitioning) {
      case VP8_SPLITMVMODE_NONE:
-         vp8_mc_part(s, dst, ref, x_off, y_off,
+         vp8_mc_part(s, td, dst, ref, x_off, y_off,
                      0, 0, 16, 16, width, height, &mb->mv);
          break;
      case VP8_SPLITMVMODE_4x4: {
          /* Y */
          for (y = 0; y < 4; y++) {
              for (x = 0; x < 4; x++) {
-                 vp8_mc_luma(s, dst[0] + 4*y*s->linesize + x*4,
+                 vp8_mc_luma(s, td, dst[0] + 4*y*s->linesize + x*4,
                              ref, &bmv[4*y + x],
                              4*x + x_off, 4*y + y_off, 4, 4,
                              width, height, s->linesize,
                      uvmv.x &= ~7;
                      uvmv.y &= ~7;
                  }
-                 vp8_mc_chroma(s, dst[1] + 4*y*s->uvlinesize + x*4,
+                 vp8_mc_chroma(s, td, dst[1] + 4*y*s->uvlinesize + x*4,
                                dst[2] + 4*y*s->uvlinesize + x*4, ref, &uvmv,
                                4*x + x_off, 4*y + y_off, 4, 4,
                                width, height, s->uvlinesize,
          break;
      }
      case VP8_SPLITMVMODE_16x8:
-         vp8_mc_part(s, dst, ref, x_off, y_off,
+         vp8_mc_part(s, td, dst, ref, x_off, y_off,
                      0, 0, 16, 8, width, height, &bmv[0]);
-         vp8_mc_part(s, dst, ref, x_off, y_off,
+         vp8_mc_part(s, td, dst, ref, x_off, y_off,
                      0, 8, 16, 8, width, height, &bmv[1]);
          break;
      case VP8_SPLITMVMODE_8x16:
-         vp8_mc_part(s, dst, ref, x_off, y_off,
+         vp8_mc_part(s, td, dst, ref, x_off, y_off,
                      0, 0, 8, 16, width, height, &bmv[0]);
-         vp8_mc_part(s, dst, ref, x_off, y_off,
+         vp8_mc_part(s, td, dst, ref, x_off, y_off,
                      8, 0, 8, 16, width, height, &bmv[1]);
          break;
      case VP8_SPLITMVMODE_8x8:
-         vp8_mc_part(s, dst, ref, x_off, y_off,
+         vp8_mc_part(s, td, dst, ref, x_off, y_off,
                      0, 0, 8, 8, width, height, &bmv[0]);
-         vp8_mc_part(s, dst, ref, x_off, y_off,
+         vp8_mc_part(s, td, dst, ref, x_off, y_off,
                      8, 0, 8, 8, width, height, &bmv[1]);
-         vp8_mc_part(s, dst, ref, x_off, y_off,
+         vp8_mc_part(s, td, dst, ref, x_off, y_off,
                      0, 8, 8, 8, width, height, &bmv[2]);
-         vp8_mc_part(s, dst, ref, x_off, y_off,
+         vp8_mc_part(s, td, dst, ref, x_off, y_off,
                      8, 8, 8, 8, width, height, &bmv[3]);
          break;
      }
  }
  
- static av_always_inline void idct_mb(VP8Context *s, uint8_t *dst[3], VP8Macroblock *mb)
+ static av_always_inline void idct_mb(VP8Context *s, VP8ThreadData *td,
+                                      uint8_t *dst[3], VP8Macroblock *mb)
  {
      int x, y, ch;
  
      if (mb->mode != MODE_I4x4) {
          uint8_t *y_dst = dst[0];
          for (y = 0; y < 4; y++) {
-             uint32_t nnz4 = AV_RL32(s->non_zero_count_cache[y]);
+             uint32_t nnz4 = AV_RL32(td->non_zero_count_cache[y]);
              if (nnz4) {
                  if (nnz4&~0x01010101) {
                      for (x = 0; x < 4; x++) {
                          if ((uint8_t)nnz4 == 1)
-                             s->vp8dsp.vp8_idct_dc_add(y_dst+4*x, s->block[y][x], s->linesize);
+                             s->vp8dsp.vp8_idct_dc_add(y_dst+4*x, td->block[y][x], s->linesize);
                          else if((uint8_t)nnz4 > 1)
-                             s->vp8dsp.vp8_idct_add(y_dst+4*x, s->block[y][x], s->linesize);
+                             s->vp8dsp.vp8_idct_add(y_dst+4*x, td->block[y][x], s->linesize);
                          nnz4 >>= 8;
                          if (!nnz4)
                              break;
                      }
                  } else {
-                     s->vp8dsp.vp8_idct_dc_add4y(y_dst, s->block[y], s->linesize);
+                     s->vp8dsp.vp8_idct_dc_add4y(y_dst, td->block[y], s->linesize);
                  }
              }
              y_dst += 4*s->linesize;
      }
  
      for (ch = 0; ch < 2; ch++) {
-         uint32_t nnz4 = AV_RL32(s->non_zero_count_cache[4+ch]);
+         uint32_t nnz4 = AV_RL32(td->non_zero_count_cache[4+ch]);
          if (nnz4) {
              uint8_t *ch_dst = dst[1+ch];
              if (nnz4&~0x01010101) {
                  for (y = 0; y < 2; y++) {
                      for (x = 0; x < 2; x++) {
                          if ((uint8_t)nnz4 == 1)
-                             s->vp8dsp.vp8_idct_dc_add(ch_dst+4*x, s->block[4+ch][(y<<1)+x], s->uvlinesize);
+                             s->vp8dsp.vp8_idct_dc_add(ch_dst+4*x, td->block[4+ch][(y<<1)+x], s->uvlinesize);
                          else if((uint8_t)nnz4 > 1)
-                             s->vp8dsp.vp8_idct_add(ch_dst+4*x, s->block[4+ch][(y<<1)+x], s->uvlinesize);
+                             s->vp8dsp.vp8_idct_add(ch_dst+4*x, td->block[4+ch][(y<<1)+x], s->uvlinesize);
                          nnz4 >>= 8;
                          if (!nnz4)
                              goto chroma_idct_end;
                      ch_dst += 4*s->uvlinesize;
                  }
              } else {
-                 s->vp8dsp.vp8_idct_dc_add4uv(ch_dst, s->block[4+ch], s->uvlinesize);
+                 s->vp8dsp.vp8_idct_dc_add4uv(ch_dst, td->block[4+ch], s->uvlinesize);
              }
          }
  chroma_idct_end: ;
@@@ -1409,7 -1461,7 +1462,7 @@@ static av_always_inline void filter_lev
      int interior_limit, filter_level;
  
      if (s->segmentation.enabled) {
-         filter_level = s->segmentation.filter_level[s->segment];
+         filter_level = s->segmentation.filter_level[mb->segment];
          if (!s->segmentation.absolute_vals)
              filter_level += s->filter.level;
      } else
@@@ -1535,51 -1587,277 +1588,277 @@@ static av_always_inline void filter_mb_
      }
  }
  
- static void filter_mb_row(VP8Context *s, AVFrame *curframe, int mb_y)
+ static void release_queued_segmaps(VP8Context *s, int is_close)
  {
-     VP8FilterStrength *f = s->filter_strength;
+     int leave_behind = is_close ? 0 : !s->maps_are_invalid;
+     while (s->num_maps_to_be_freed > leave_behind)
+         av_freep(&s->segmentation_maps[--s->num_maps_to_be_freed]);
+     s->maps_are_invalid = 0;
+ }
+ #define MARGIN (16 << 2)
+ static void vp8_decode_mv_mb_modes(AVCodecContext *avctx, AVFrame *curframe,
+                                    AVFrame *prev_frame)
+ {
+     VP8Context *s = avctx->priv_data;
+     int mb_x, mb_y;
+     s->mv_min.y = -MARGIN;
+     s->mv_max.y = ((s->mb_height - 1) << 6) + MARGIN;
+     for (mb_y = 0; mb_y < s->mb_height; mb_y++) {
+         VP8Macroblock *mb = s->macroblocks_base + ((s->mb_width+1)*(mb_y + 1) + 1);
+         int mb_xy = mb_y*s->mb_width;
+         AV_WN32A(s->intra4x4_pred_mode_left, DC_PRED*0x01010101);
+         s->mv_min.x = -MARGIN;
+         s->mv_max.x = ((s->mb_width - 1) << 6) + MARGIN;
+         for (mb_x = 0; mb_x < s->mb_width; mb_x++, mb_xy++, mb++) {
+             if (mb_y == 0)
+                 AV_WN32A((mb-s->mb_width-1)->intra4x4_pred_mode_top, DC_PRED*0x01010101);
+             decode_mb_mode(s, mb, mb_x, mb_y, curframe->ref_index[0] + mb_xy,
+                            prev_frame && prev_frame->ref_index[0] ? prev_frame->ref_index[0] + mb_xy : NULL, 1);
+             s->mv_min.x -= 64;
+             s->mv_max.x -= 64;
+         }
+         s->mv_min.y -= 64;
+         s->mv_max.y -= 64;
+     }
+ }
+ #if HAVE_THREADS
+ #define check_thread_pos(td, otd, mb_x_check, mb_y_check)\
+     do {\
+         int tmp = (mb_y_check << 16) | (mb_x_check & 0xFFFF);\
+         if (otd->thread_mb_pos < tmp) {\
+             pthread_mutex_lock(&otd->lock);\
+             td->wait_mb_pos = tmp;\
+             do {\
+                 if (otd->thread_mb_pos >= tmp)\
+                     break;\
+                 pthread_cond_wait(&otd->cond, &otd->lock);\
+             } while (1);\
+             td->wait_mb_pos = INT_MAX;\
+             pthread_mutex_unlock(&otd->lock);\
+         }\
+     } while(0);
+ #define update_pos(td, mb_y, mb_x)\
+     do {\
+     int pos              = (mb_y << 16) | (mb_x & 0xFFFF);\
+     int sliced_threading = (avctx->active_thread_type == FF_THREAD_SLICE) && (num_jobs > 1);\
+     int is_null          = (next_td == NULL) || (prev_td == NULL);\
+     int pos_check        = (is_null) ? 1 :\
+                             (next_td != td && pos >= next_td->wait_mb_pos) ||\
+                             (prev_td != td && pos >= prev_td->wait_mb_pos);\
+     td->thread_mb_pos = pos;\
+     if (sliced_threading && pos_check) {\
+         pthread_mutex_lock(&td->lock);\
+         pthread_cond_broadcast(&td->cond);\
+         pthread_mutex_unlock(&td->lock);\
+     }\
+     } while(0);
+ #else
+ #define check_thread_pos(td, otd, mb_x_check, mb_y_check)
+ #define update_pos(td, mb_y, mb_x)
+ #endif
+ static void vp8_decode_mb_row_no_filter(AVCodecContext *avctx, void *tdata,
+                                         int jobnr, int threadnr)
+ {
+     VP8Context *s = avctx->priv_data;
+     VP8ThreadData *prev_td, *next_td, *td = &s->thread_data[threadnr];
+     int mb_y = td->thread_mb_pos>>16;
+     int i, y, mb_x, mb_xy = mb_y*s->mb_width;
+     int num_jobs = s->num_jobs;
+     AVFrame *curframe = s->curframe, *prev_frame = s->prev_frame;
+     VP56RangeCoder *c = &s->coeff_partition[mb_y & (s->num_coeff_partitions-1)];
+     VP8Macroblock *mb;
      uint8_t *dst[3] = {
          curframe->data[0] + 16*mb_y*s->linesize,
          curframe->data[1] +  8*mb_y*s->uvlinesize,
          curframe->data[2] +  8*mb_y*s->uvlinesize
      };
-     int mb_x;
+     if (mb_y == 0) prev_td = td;
+     else           prev_td = &s->thread_data[(jobnr + num_jobs - 1)%num_jobs];
+     if (mb_y == s->mb_height-1) next_td = td;
+     else                        next_td = &s->thread_data[(jobnr + 1)%num_jobs];
+     if (s->mb_layout == 1)
+         mb = s->macroblocks_base + ((s->mb_width+1)*(mb_y + 1) + 1);
+     else {
+         mb = s->macroblocks + (s->mb_height - mb_y - 1)*2;
+         memset(mb - 1, 0, sizeof(*mb)); // zero left macroblock
+         AV_WN32A(s->intra4x4_pred_mode_left, DC_PRED*0x01010101);
+     }
+     memset(td->left_nnz, 0, sizeof(td->left_nnz));
+     // left edge of 129 for intra prediction
+     if (!(avctx->flags & CODEC_FLAG_EMU_EDGE)) {
+         for (i = 0; i < 3; i++)
+             for (y = 0; y < 16>>!!i; y++)
+                 dst[i][y*curframe->linesize[i]-1] = 129;
+         if (mb_y == 1) {
+             s->top_border[0][15] = s->top_border[0][23] = s->top_border[0][31] = 129;
+         }
+     }
+     s->mv_min.x = -MARGIN;
+     s->mv_max.x = ((s->mb_width  - 1) << 6) + MARGIN;
+     for (mb_x = 0; mb_x < s->mb_width; mb_x++, mb_xy++, mb++) {
+         // Wait for previous thread to read mb_x+2, and reach mb_y-1.
+         if (prev_td != td) {
+             if (threadnr != 0) {
+                 check_thread_pos(td, prev_td, mb_x+1, mb_y-1);
+             } else {
+                 check_thread_pos(td, prev_td, (s->mb_width+3) + (mb_x+1), mb_y-1);
+             }
+         }
+         s->dsp.prefetch(dst[0] + (mb_x&3)*4*s->linesize + 64, s->linesize, 4);
+         s->dsp.prefetch(dst[1] + (mb_x&7)*s->uvlinesize + 64, dst[2] - dst[1], 2);
+         if (!s->mb_layout)
+             decode_mb_mode(s, mb, mb_x, mb_y, curframe->ref_index[0] + mb_xy,
+                            prev_frame && prev_frame->ref_index[0] ? prev_frame->ref_index[0] + mb_xy : NULL, 0);
+         prefetch_motion(s, mb, mb_x, mb_y, mb_xy, VP56_FRAME_PREVIOUS);
+         if (!mb->skip)
+             decode_mb_coeffs(s, td, c, mb, s->top_nnz[mb_x], td->left_nnz);
+         if (mb->mode <= MODE_I4x4)
+             intra_predict(s, td, dst, mb, mb_x, mb_y);
+         else
+             inter_predict(s, td, dst, mb, mb_x, mb_y);
+         prefetch_motion(s, mb, mb_x, mb_y, mb_xy, VP56_FRAME_GOLDEN);
+         if (!mb->skip) {
+             idct_mb(s, td, dst, mb);
+         } else {
+             AV_ZERO64(td->left_nnz);
+             AV_WN64(s->top_nnz[mb_x], 0);   // array of 9, so unaligned
+             // Reset DC block predictors if they would exist if the mb had coefficients
+             if (mb->mode != MODE_I4x4 && mb->mode != VP8_MVMODE_SPLIT) {
+                 td->left_nnz[8]     = 0;
+                 s->top_nnz[mb_x][8] = 0;
+             }
+         }
+         if (s->deblock_filter)
+             filter_level_for_mb(s, mb, &td->filter_strength[mb_x]);
+         if (s->deblock_filter && num_jobs != 1 && threadnr == num_jobs-1) {
+             if (s->filter.simple)
+                 backup_mb_border(s->top_border[mb_x+1], dst[0], NULL, NULL, s->linesize, 0, 1);
+             else
+                 backup_mb_border(s->top_border[mb_x+1], dst[0], dst[1], dst[2], s->linesize, s->uvlinesize, 0);
+         }
+         prefetch_motion(s, mb, mb_x, mb_y, mb_xy, VP56_FRAME_GOLDEN2);
  
-     for (mb_x = 0; mb_x < s->mb_width; mb_x++) {
-         backup_mb_border(s->top_border[mb_x+1], dst[0], dst[1], dst[2], s->linesize, s->uvlinesize, 0);
-         filter_mb(s, dst, f++, mb_x, mb_y);
          dst[0] += 16;
          dst[1] += 8;
          dst[2] += 8;
+         s->mv_min.x -= 64;
+         s->mv_max.x -= 64;
+         if (mb_x == s->mb_width+1) {
+             update_pos(td, mb_y, s->mb_width+3);
+         } else {
+             update_pos(td, mb_y, mb_x);
+         }
      }
  }
  
- static void filter_mb_row_simple(VP8Context *s, AVFrame *curframe, int mb_y)
+ static void vp8_filter_mb_row(AVCodecContext *avctx, void *tdata,
+                               int jobnr, int threadnr)
  {
-     VP8FilterStrength *f = s->filter_strength;
-     uint8_t *dst = curframe->data[0] + 16*mb_y*s->linesize;
-     int mb_x;
+     VP8Context *s = avctx->priv_data;
+     VP8ThreadData *td = &s->thread_data[threadnr];
+     int mb_x, mb_y = td->thread_mb_pos>>16, num_jobs = s->num_jobs;
+     AVFrame *curframe = s->curframe;
+     VP8Macroblock *mb;
+     VP8ThreadData *prev_td, *next_td;
+     uint8_t *dst[3] = {
+         curframe->data[0] + 16*mb_y*s->linesize,
+         curframe->data[1] +  8*mb_y*s->uvlinesize,
+         curframe->data[2] +  8*mb_y*s->uvlinesize
+     };
  
-     for (mb_x = 0; mb_x < s->mb_width; mb_x++) {
-         backup_mb_border(s->top_border[mb_x+1], dst, NULL, NULL, s->linesize, 0, 1);
-         filter_mb_simple(s, dst, f++, mb_x, mb_y);
-         dst += 16;
+     if (s->mb_layout == 1)
+         mb = s->macroblocks_base + ((s->mb_width+1)*(mb_y + 1) + 1);
+     else
+         mb = s->macroblocks + (s->mb_height - mb_y - 1)*2;
+     if (mb_y == 0) prev_td = td;
+     else           prev_td = &s->thread_data[(jobnr + num_jobs - 1)%num_jobs];
+     if (mb_y == s->mb_height-1) next_td = td;
+     else                        next_td = &s->thread_data[(jobnr + 1)%num_jobs];
+     for (mb_x = 0; mb_x < s->mb_width; mb_x++, mb++) {
+         VP8FilterStrength *f = &td->filter_strength[mb_x];
+         if (prev_td != td) {
+             check_thread_pos(td, prev_td, (mb_x+1) + (s->mb_width+3), mb_y-1);
+         }
+         if (next_td != td)
+             if (next_td != &s->thread_data[0]) {
+                 check_thread_pos(td, next_td, mb_x+1, mb_y+1);
+             }
+         if (num_jobs == 1) {
+             if (s->filter.simple)
+                 backup_mb_border(s->top_border[mb_x+1], dst[0], NULL, NULL, s->linesize, 0, 1);
+             else
+                 backup_mb_border(s->top_border[mb_x+1], dst[0], dst[1], dst[2], s->linesize, s->uvlinesize, 0);
+         }
+         if (s->filter.simple)
+             filter_mb_simple(s, dst[0], f, mb_x, mb_y);
+         else
+             filter_mb(s, dst, f, mb_x, mb_y);
+         dst[0] += 16;
+         dst[1] += 8;
+         dst[2] += 8;
+         update_pos(td, mb_y, (s->mb_width+3) + mb_x);
      }
  }
  
- static void release_queued_segmaps(VP8Context *s, int is_close)
+ static int vp8_decode_mb_row_sliced(AVCodecContext *avctx, void *tdata,
+                                     int jobnr, int threadnr)
  {
-     int leave_behind = is_close ? 0 : !s->maps_are_invalid;
-     while (s->num_maps_to_be_freed > leave_behind)
-         av_freep(&s->segmentation_maps[--s->num_maps_to_be_freed]);
-     s->maps_are_invalid = 0;
+     VP8Context *s = avctx->priv_data;
+     VP8ThreadData *td = &s->thread_data[jobnr];
+     VP8ThreadData *next_td = NULL, *prev_td = NULL;
+     AVFrame *curframe = s->curframe;
+     int mb_y, num_jobs = s->num_jobs;
+     td->thread_nr = threadnr;
+     for (mb_y = jobnr; mb_y < s->mb_height; mb_y += num_jobs) {
+         if (mb_y >= s->mb_height) break;
+         td->thread_mb_pos = mb_y<<16;
+         vp8_decode_mb_row_no_filter(avctx, tdata, jobnr, threadnr);
+         if (s->deblock_filter)
+             vp8_filter_mb_row(avctx, tdata, jobnr, threadnr);
+         update_pos(td, mb_y, INT_MAX & 0xFFFF);
+         s->mv_min.y -= 64;
+         s->mv_max.y -= 64;
+         if (avctx->active_thread_type == FF_THREAD_FRAME)
+             ff_thread_report_progress(curframe, mb_y, 0);
+     }
+     return 0;
  }
  
  static int vp8_decode_frame(AVCodecContext *avctx, void *data, int *data_size,
                              AVPacket *avpkt)
  {
      VP8Context *s = avctx->priv_data;
-     int ret, mb_x, mb_y, i, y, referenced;
+     int ret, i, referenced, num_jobs;
      enum AVDiscard skip_thresh;
      AVFrame *av_uninit(curframe), *prev_frame;
  
      s->linesize   = curframe->linesize[0];
      s->uvlinesize = curframe->linesize[1];
  
-     if (!s->edge_emu_buffer)
-         s->edge_emu_buffer = av_malloc(21*s->linesize);
+     if (!s->thread_data[0].edge_emu_buffer)
+         for (i = 0; i < MAX_THREADS; i++)
+             s->thread_data[i].edge_emu_buffer = av_malloc(21*s->linesize);
  
      memset(s->top_nnz, 0, s->mb_width*sizeof(*s->top_nnz));
      /* Zero macroblock structures for top/top-left prediction from outside the frame. */
-     memset(s->macroblocks + s->mb_height*2 - 1, 0, (s->mb_width+1)*sizeof(*s->macroblocks));
+     if (!s->mb_layout)
+         memset(s->macroblocks + s->mb_height*2 - 1, 0, (s->mb_width+1)*sizeof(*s->macroblocks));
+     if (!s->mb_layout && s->keyframe)
+         memset(s->intra4x4_pred_mode_top, DC_PRED, s->mb_width*4);
  
      // top edge of 127 for intra prediction
      if (!(avctx->flags & CODEC_FLAG_EMU_EDGE)) {
          memset(s->top_border[1]-1, 127, s->mb_width*sizeof(*s->top_border)+1);
      }
      memset(s->ref_count, 0, sizeof(s->ref_count));
-     if (s->keyframe)
-         memset(s->intra4x4_pred_mode_top, DC_PRED, s->mb_width*4);
- #define MARGIN (16 << 2)
-     s->mv_min.y = -MARGIN;
-     s->mv_max.y = ((s->mb_height - 1) << 6) + MARGIN;
-     for (mb_y = 0; mb_y < s->mb_height; mb_y++) {
-         VP56RangeCoder *c = &s->coeff_partition[mb_y & (s->num_coeff_partitions-1)];
-         VP8Macroblock *mb = s->macroblocks + (s->mb_height - mb_y - 1)*2;
-         int mb_xy = mb_y*s->mb_width;
-         uint8_t *dst[3] = {
-             curframe->data[0] + 16*mb_y*s->linesize,
-             curframe->data[1] +  8*mb_y*s->uvlinesize,
-             curframe->data[2] +  8*mb_y*s->uvlinesize
-         };
-         memset(mb - 1, 0, sizeof(*mb));   // zero left macroblock
-         memset(s->left_nnz, 0, sizeof(s->left_nnz));
-         AV_WN32A(s->intra4x4_pred_mode_left, DC_PRED*0x01010101);
-         // left edge of 129 for intra prediction
-         if (!(avctx->flags & CODEC_FLAG_EMU_EDGE)) {
-             for (i = 0; i < 3; i++)
-                 for (y = 0; y < 16>>!!i; y++)
-                     dst[i][y*curframe->linesize[i]-1] = 129;
-             if (mb_y == 1) // top left edge is also 129
-                 s->top_border[0][15] = s->top_border[0][23] = s->top_border[0][31] = 129;
-         }
-         s->mv_min.x = -MARGIN;
-         s->mv_max.x = ((s->mb_width  - 1) << 6) + MARGIN;
-         if (prev_frame && s->segmentation.enabled && !s->segmentation.update_map)
-             ff_thread_await_progress(prev_frame, mb_y, 0);
-         for (mb_x = 0; mb_x < s->mb_width; mb_x++, mb_xy++, mb++) {
-             /* Prefetch the current frame, 4 MBs ahead */
-             s->dsp.prefetch(dst[0] + (mb_x&3)*4*s->linesize + 64, s->linesize, 4);
-             s->dsp.prefetch(dst[1] + (mb_x&7)*s->uvlinesize + 64, dst[2] - dst[1], 2);
-             decode_mb_mode(s, mb, mb_x, mb_y, curframe->ref_index[0] + mb_xy,
-                            prev_frame && prev_frame->ref_index[0] ? prev_frame->ref_index[0] + mb_xy : NULL);
-             prefetch_motion(s, mb, mb_x, mb_y, mb_xy, VP56_FRAME_PREVIOUS);
-             if (!mb->skip)
-                 decode_mb_coeffs(s, c, mb, s->top_nnz[mb_x], s->left_nnz);
  
-             if (mb->mode <= MODE_I4x4)
-                 intra_predict(s, dst, mb, mb_x, mb_y);
-             else
-                 inter_predict(s, dst, mb, mb_x, mb_y);
  
-             prefetch_motion(s, mb, mb_x, mb_y, mb_xy, VP56_FRAME_GOLDEN);
+     // Make sure the previous frame has read its segmentation map,
+     // if we re-use the same map.
+     if (prev_frame && s->segmentation.enabled && !s->segmentation.update_map)
+         ff_thread_await_progress(prev_frame, 1, 0);
  
-             if (!mb->skip) {
-                 idct_mb(s, dst, mb);
-             } else {
-                 AV_ZERO64(s->left_nnz);
-                 AV_WN64(s->top_nnz[mb_x], 0);   // array of 9, so unaligned
+     if (s->mb_layout == 1)
+         vp8_decode_mv_mb_modes(avctx, curframe, prev_frame);
  
-                 // Reset DC block predictors if they would exist if the mb had coefficients
-                 if (mb->mode != MODE_I4x4 && mb->mode != VP8_MVMODE_SPLIT) {
-                     s->left_nnz[8]      = 0;
-                     s->top_nnz[mb_x][8] = 0;
-                 }
-             }
-             if (s->deblock_filter)
-                 filter_level_for_mb(s, mb, &s->filter_strength[mb_x]);
-             prefetch_motion(s, mb, mb_x, mb_y, mb_xy, VP56_FRAME_GOLDEN2);
-             dst[0] += 16;
-             dst[1] += 8;
-             dst[2] += 8;
-             s->mv_min.x -= 64;
-             s->mv_max.x -= 64;
-         }
-         if (s->deblock_filter) {
-             if (s->filter.simple)
-                 filter_mb_row_simple(s, curframe, mb_y);
-             else
-                 filter_mb_row(s, curframe, mb_y);
-         }
-         s->mv_min.y -= 64;
-         s->mv_max.y -= 64;
-         ff_thread_report_progress(curframe, mb_y, 0);
-     }
+     if (avctx->active_thread_type == FF_THREAD_FRAME)
+         num_jobs = 1;
+     else
+         num_jobs = FFMIN(s->num_coeff_partitions, avctx->thread_count);
+     s->num_jobs   = num_jobs;
+     s->curframe   = curframe;
+     s->prev_frame = prev_frame;
+     s->mv_min.y   = -MARGIN;
+     s->mv_max.y   = ((s->mb_height - 1) << 6) + MARGIN;
+     for (i = 0; i < MAX_THREADS; i++) {
+         s->thread_data[i].thread_mb_pos = 0;
+         s->thread_data[i].wait_mb_pos = INT_MAX;
+     }
+     avctx->execute2(avctx, vp8_decode_mb_row_sliced, s->thread_data, NULL, num_jobs);
  
      ff_thread_report_progress(curframe, INT_MAX, 0);
      memcpy(&s->framep[0], &s->next_framep[0], sizeof(s->framep[0]) * 4);
@@@ -1862,7 -2077,7 +2078,7 @@@ AVCodec ff_vp8_decoder = 
      .init                  = vp8_decode_init,
      .close                 = vp8_decode_free,
      .decode                = vp8_decode_frame,
-     .capabilities          = CODEC_CAP_DR1 | CODEC_CAP_FRAME_THREADS,
+     .capabilities          = CODEC_CAP_DR1 | CODEC_CAP_FRAME_THREADS | CODEC_CAP_SLICE_THREADS,
      .flush                 = vp8_decode_flush,
      .long_name             = NULL_IF_CONFIG_SMALL("On2 VP8"),
      .init_thread_copy      = ONLY_IF_THREADS_ENABLED(vp8_decode_init_thread_copy),
diff --combined libavcodec/vp8.h
@@@ -4,21 -4,22 +4,22 @@@
   * Copyright (C) 2010 David Conrad
   * Copyright (C) 2010 Ronald S. Bultje
   * Copyright (C) 2010 Jason Garrett-Glaser
+  * Copyright (C) 2012 Daniel Kang
   *
 - * 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 "vp56data.h"
  #include "vp8dsp.h"
  #include "h264pred.h"
+ #if HAVE_PTHREADS
+ #include <pthread.h>
+ #elif HAVE_W32THREADS
+ #include "w32pthreads.h"
+ #endif
  
  #define VP8_MAX_QUANT 127
  
@@@ -79,15 -85,51 +85,51 @@@ typedef struct 
      uint8_t mode;
      uint8_t ref_frame;
      uint8_t partitioning;
+     uint8_t chroma_pred_mode;
+     uint8_t segment;
+     uint8_t intra4x4_pred_mode_mb[16];
+     uint8_t intra4x4_pred_mode_top[4];
      VP56mv mv;
      VP56mv bmv[16];
  } VP8Macroblock;
  
  typedef struct {
+ #if HAVE_THREADS
+     pthread_mutex_t lock;
+     pthread_cond_t  cond;
+ #endif
+     int thread_nr;
+     int thread_mb_pos; // (mb_y << 16) | (mb_x & 0xFFFF)
+     int wait_mb_pos; // What the current thread is waiting on.
+     uint8_t *edge_emu_buffer;
+     /**
+      * For coeff decode, we need to know whether the above block had non-zero
+      * coefficients. This means for each macroblock, we need data for 4 luma
+      * blocks, 2 u blocks, 2 v blocks, and the luma dc block, for a total of 9
+      * per macroblock. We keep the last row in top_nnz.
+      */
+     DECLARE_ALIGNED(8, uint8_t, left_nnz)[9];
+     /**
+      * This is the index plus one of the last non-zero coeff
+      * for each of the blocks in the current macroblock.
+      * So, 0 -> no coeffs
+      *     1 -> dc-only (special transform)
+      *     2+-> full transform
+      */
+     DECLARE_ALIGNED(16, uint8_t, non_zero_count_cache)[6][4];
+     DECLARE_ALIGNED(16, DCTELEM, block)[6][4][16];
+     DECLARE_ALIGNED(16, DCTELEM, block_dc)[16];
+     VP8FilterStrength *filter_strength;
+ } VP8ThreadData;
+ #define MAX_THREADS 8
+ typedef struct {
+     VP8ThreadData *thread_data;
      AVCodecContext *avctx;
      AVFrame *framep[4];
      AVFrame *next_framep[4];
-     uint8_t *edge_emu_buffer;
+     AVFrame *curframe;
+     AVFrame *prev_frame;
  
      uint16_t mb_width;   /* number of horizontal MB */
      uint16_t mb_height;  /* number of vertical MB */
      uint8_t keyframe;
      uint8_t deblock_filter;
      uint8_t mbskip_enabled;
-     uint8_t segment;             ///< segment of the current macroblock
-     uint8_t chroma_pred_mode;    ///< 8x8c pred mode of the current macroblock
      uint8_t profile;
      VP56mv mv_min;
      VP56mv mv_max;
      } filter;
  
      VP8Macroblock *macroblocks;
-     VP8FilterStrength *filter_strength;
  
      uint8_t *intra4x4_pred_mode_top;
      uint8_t intra4x4_pred_mode_left[4];
          int8_t ref[4];
      } lf_delta;
  
-     /**
-      * Cache of the top row needed for intra prediction
-      * 16 for luma, 8 for each chroma plane
-      */
      uint8_t (*top_border)[16+8+8];
-     /**
-      * For coeff decode, we need to know whether the above block had non-zero
-      * coefficients. This means for each macroblock, we need data for 4 luma
-      * blocks, 2 u blocks, 2 v blocks, and the luma dc block, for a total of 9
-      * per macroblock. We keep the last row in top_nnz.
-      */
      uint8_t (*top_nnz)[9];
-     DECLARE_ALIGNED(8, uint8_t, left_nnz)[9];
  
-     /**
-      * This is the index plus one of the last non-zero coeff
-      * for each of the blocks in the current macroblock.
-      * So, 0 -> no coeffs
-      *     1 -> dc-only (special transform)
-      *     2+-> full transform
-      */
-     DECLARE_ALIGNED(16, uint8_t, non_zero_count_cache)[6][4];
      VP56RangeCoder c;   ///< header context, includes mb modes and motion vectors
-     DECLARE_ALIGNED(16, DCTELEM, block)[6][4][16];
-     DECLARE_ALIGNED(16, DCTELEM, block_dc)[16];
-     uint8_t intra4x4_pred_mode_mb[16];
  
      /**
       * These are all of the updatable probabilities for binary decisions.
      uint8_t *segmentation_maps[5];
      int num_maps_to_be_freed;
      int maps_are_invalid;
+     int num_jobs;
+     /**
+      * This describes the macroblock memory layout.
+      * 0 -> Only width+height*2+1 macroblocks allocated (frame/single thread).
+      * 1 -> Macroblocks for entire frame alloced (sliced thread).
+      */
+     int mb_layout;
  } VP8Context;
  
  #endif /* AVCODEC_VP8_H */
diff --combined libavutil/mem.h
@@@ -1,20 -1,20 +1,20 @@@
  /*
   * copyright (c) 2006 Michael Niedermayer <michaelni@gmx.at>
   *
 - * 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
   */
  
@@@ -27,7 -27,6 +27,7 @@@
  #define AVUTIL_MEM_H
  
  #include "attributes.h"
 +#include "error.h"
  #include "avutil.h"
  
  /**
@@@ -36,7 -35,7 +36,7 @@@
   */
  
  
 -#if defined(__ICC) && _ICC < 1200 || defined(__SUNPRO_C)
 +#if defined(__INTEL_COMPILER) && __INTEL_COMPILER < 1110 || defined(__SUNPRO_C)
      #define DECLARE_ALIGNED(n,t,v)      t __attribute__ ((aligned (n))) v
      #define DECLARE_ASM_CONST(n,t,v)    const t __attribute__ ((aligned (n))) v
  #elif defined(__TI_COMPILER_VERSION__)
@@@ -64,9 -63,9 +64,9 @@@
  #endif
  
  #if AV_GCC_VERSION_AT_LEAST(4,3)
-     #define av_alloc_size(n) __attribute__((alloc_size(n)))
+     #define av_alloc_size(...) __attribute__((alloc_size(__VA_ARGS__)))
  #else
-     #define av_alloc_size(n)
+     #define av_alloc_size(...)
  #endif
  
  /**
  void *av_malloc(size_t size) av_malloc_attrib av_alloc_size(1);
  
  /**
+  * Helper function to allocate a block of size * nmemb bytes with
+  * using av_malloc()
+  * @param nmemb Number of elements
+  * @param size Size of the single element
+  * @return Pointer to the allocated block, NULL if the block cannot
+  * be allocated.
+  * @see av_malloc()
+  */
+ av_alloc_size(1,2) static inline void *av_malloc_array(size_t nmemb, size_t size)
+ {
+     if (size <= 0 || nmemb >= INT_MAX / size)
+         return NULL;
+     return av_malloc(nmemb * size);
+ }
+ /**
   * Allocate or reallocate a block of memory.
   * If ptr is NULL and size > 0, allocate a new block. If
   * size is zero, free the memory block pointed to by ptr.
  void *av_realloc(void *ptr, size_t size) av_alloc_size(2);
  
  /**
 + * Allocate or reallocate a block of memory.
 + * This function does the same thing as av_realloc, except:
 + * - It takes two arguments and checks the result of the multiplication for
 + *   integer overflow.
 + * - It frees the input block in case of failure, thus avoiding the memory
 + *   leak with the classic "buf = realloc(buf); if (!buf) return -1;".
 + */
 +void *av_realloc_f(void *ptr, size_t nelem, size_t elsize);
 +
 +/**
   * Free a memory block which has been allocated with av_malloc(z)() or
   * av_realloc().
   * @param ptr Pointer to the memory block which should be freed.
@@@ -124,18 -129,23 +140,35 @@@ void av_free(void *ptr)
  void *av_mallocz(size_t size) av_malloc_attrib av_alloc_size(1);
  
  /**
 + * Allocate a block of nmemb * size bytes with alignment suitable for all
 + * memory accesses (including vectors if available on the CPU) and
 + * zero all the bytes of the block.
 + * The allocation will fail if nmemb * size is greater than or equal
 + * to INT_MAX.
 + * @param nmemb
 + * @param size
 + * @return Pointer to the allocated block, NULL if it cannot be allocated.
 + */
 +void *av_calloc(size_t nmemb, size_t size) av_malloc_attrib;
 +
 +/**
+  * Helper function to allocate a block of size * nmemb bytes with
+  * using av_mallocz()
+  * @param nmemb Number of elements
+  * @param size Size of the single element
+  * @return Pointer to the allocated block, NULL if the block cannot
+  * be allocated.
+  * @see av_mallocz()
+  * @see av_malloc_array()
+  */
+ av_alloc_size(1,2) static inline void *av_mallocz_array(size_t nmemb, size_t size)
+ {
+     if (size <= 0 || nmemb >= INT_MAX / size)
+         return NULL;
+     return av_mallocz(nmemb * size);
+ }
+ /**
   * Duplicate the string s.
   * @param s string to be duplicated
   * @return Pointer to a newly allocated string containing a
@@@ -153,35 -163,6 +186,35 @@@ char *av_strdup(const char *s) av_mallo
  void av_freep(void *ptr);
  
  /**
 + * Add an element to a dynamic array.
 + *
 + * @param tab_ptr Pointer to the array.
 + * @param nb_ptr  Pointer to the number of elements in the array.
 + * @param elem    Element to be added.
 + */
 +void av_dynarray_add(void *tab_ptr, int *nb_ptr, void *elem);
 +
 +/**
 + * Multiply two size_t values checking for overflow.
 + * @return  0 if success, AVERROR(EINVAL) if overflow.
 + */
 +static inline int av_size_mult(size_t a, size_t b, size_t *r)
 +{
 +    size_t t = a * b;
 +    /* Hack inspired from glibc: only try the division if nelem and elsize
 +     * are both greater than sqrt(SIZE_MAX). */
 +    if ((a | b) >= ((size_t)1 << (sizeof(size_t) * 4)) && a && t / a != b)
 +        return AVERROR(EINVAL);
 +    *r = t;
 +    return 0;
 +}
 +
 +/**
 + * Set the maximum size that may me allocated in one block.
 + */
 +void av_max_alloc(size_t max);
 +
 +/**
   * @}
   */
  
diff --combined libavutil/version.h
@@@ -1,20 -1,18 +1,20 @@@
  /*
 - * This file is part of Libav.
 + * copyright (c) 2003 Fabrice Bellard
   *
 - * Libav is free software; you can redistribute it and/or
 + * This file is part of FFmpeg.
 + *
 + * 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
   */
  
@@@ -39,8 -37,8 +39,8 @@@
   */
  
  #define LIBAVUTIL_VERSION_MAJOR 51
- #define LIBAVUTIL_VERSION_MINOR 64
 -#define LIBAVUTIL_VERSION_MINOR 37
 -#define LIBAVUTIL_VERSION_MICRO  0
++#define LIBAVUTIL_VERSION_MINOR 65
 +#define LIBAVUTIL_VERSION_MICRO 100
  
  #define LIBAVUTIL_VERSION_INT   AV_VERSION_INT(LIBAVUTIL_VERSION_MAJOR, \
                                                 LIBAVUTIL_VERSION_MINOR, \
@@@ -63,9 -61,6 +63,9 @@@
   * @{
   */
  
 +#ifndef FF_API_OLD_EVAL_NAMES
 +#define FF_API_OLD_EVAL_NAMES           (LIBAVUTIL_VERSION_MAJOR < 52)
 +#endif
  #ifndef FF_API_GET_BITS_PER_SAMPLE_FMT
  #define FF_API_GET_BITS_PER_SAMPLE_FMT (LIBAVUTIL_VERSION_MAJOR < 52)
  #endif
@@@ -84,4 -79,3 +84,4 @@@
   */
  
  #endif /* AVUTIL_VERSION_H */
 +