Merge remote-tracking branch 'qatar/master'
authorMichael Niedermayer <michaelni@gmx.at>
Wed, 27 Jun 2012 22:42:47 +0000 (00:42 +0200)
committerMichael Niedermayer <michaelni@gmx.at>
Wed, 27 Jun 2012 23:08:52 +0000 (01:08 +0200)
* qatar/master:
  mss1: validate number of changeable palette entries
  mss1: report palette changed when some additional colours were decoded
  x86: fft: replace call to memcpy by a loop
  udp: Support IGMPv3 source specific multicast and source blocking
  dxva2: include dxva.h if found
  libm: Provide fallback definitions for isnan() and isinf()
  tcp: Pass NULL as hostname to getaddrinfo if the string is empty
  tcp: Set AI_PASSIVE when the socket will be used for listening

Conflicts:
configure
libavcodec/mss1.c
libavformat/udp.c

Merged-by: Michael Niedermayer <michaelni@gmx.at>
1  2 
configure
doc/protocols.texi
libavcodec/dxva2_internal.h
libavcodec/mss1.c
libavcodec/x86/fft_mmx.asm
libavformat/tcp.c
libavformat/udp.c
libavutil/libm.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-libfreetype     enable libfreetype [no]
    --enable-libgsm          enable GSM support via libgsm [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]
  
@@@ -218,26 -203,22 +218,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)
@@@ -269,37 -250,16 +269,37 @@@ 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
 +  --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.
 +  --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
@@@ -334,7 -294,7 +334,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
@@@ -632,10 -592,6 +632,10 @@@ add_cflags()
      append CFLAGS $($filter_cflags "$@")
  }
  
 +add_cxxflags(){
 +    append CXXFLAGS $($filter_cflags "$@")
 +}
 +
  add_asflags(){
      append ASFLAGS $($filter_asflags "$@")
  }
@@@ -660,13 -616,6 +660,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
@@@ -702,14 -651,12 +702,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
  }
  
@@@ -729,17 -676,9 +729,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
  }
@@@ -765,7 -704,7 +765,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
@@@ -776,10 -715,10 +776,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
  }
  
@@@ -796,26 -735,7 +796,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(){
@@@ -847,21 -767,13 +847,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
  }
@@@ -954,14 -862,6 +954,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"
@@@ -1013,10 -913,10 +1013,10 @@@ COMPONENT_LIST=
  "
  
  PROGRAM_LIST="
 -    avconv
 -    avplay
 -    avprobe
 -    avserver
 +    ffplay
 +    ffprobe
 +    ffserver
 +    ffmpeg
  "
  
  CONFIG_LIST="
      avresample
      avisynth
      bzlib
 +    crystalhd
      dct
      doc
      dwt
      dxva2
      fastdiv
      fft
 +    fontconfig
      frei0r
      gnutls
      gpl
      gray
      hardcoded_tables
 +    libaacplus
 +    libass
 +    libbluray
      libcdio
 +    libcelt
      libdc1394
      libfaac
      libfreetype
      libgsm
      libilbc
 +    libmodplug
      libmp3lame
 +    libnut
      libopencore_amrnb
      libopencore_amrwb
      libopencv
      librtmp
      libschroedinger
      libspeex
 +    libstagefright_h264
      libtheora
 +    libutvideo
 +    libv4l2
      libvo_aacenc
      libvo_amrwbenc
      libvorbis
      mpegaudiodsp
      network
      nonfree
 +    openal
      openssl
      pic
 +    postproc
      rdft
      rtpdec
      runtime_cpudetect
      small
      sram
      static
 +    swresample
      swscale
      swscale_alpha
      thumb
  THREADS_LIST='
      pthreads
      w32threads
 +    os2threads
  '
  
  ARCH_LIST='
@@@ -1155,10 -1040,6 +1155,10 @@@ ARCH_EXT_LIST=
      ssse3
      vfpv3
      vis
 +    mipsfpu
 +    mips32r2
 +    mipsdspr1
 +    mipsdspr2
  '
  
  HAVE_LIST_PUB='
@@@ -1176,11 -1057,9 +1176,11 @@@ HAVE_LIST=
      altivec_h
      arpa_inet_h
      asm_mod_y
 +    asm_types_h
      attribute_may_alias
      attribute_packed
      cbrtf
 +    clock_gettime
      closesocket
      cmov
      dcbzl
      dlfcn_h
      dlopen
      dos_paths
+     dxva_h
      ebp_available
      ebx_available
      exp2
      GetSystemTimeAsFileTime
      getrusage
      gettimeofday
 +    glob
      gnu_as
      ibm_asm
      inet_aton
      inline_asm
      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
      poll_h
      posix_memalign
 +    pthread_cancel
      round
      roundf
      sched_getaffinity
      soundcard_h
      strerror_r
      strptime
 -    strtok_r
      struct_addrinfo
+     struct_group_source_req
+     struct_ip_mreq_source
      struct_ipv6_mreq
      struct_rusage_ru_maxrss
      struct_sockaddr_in6
      sys_soundcard_h
      sys_time_h
      sys_videoio_h
 +    termios_h
      threads
      trunc
      truncf
@@@ -1312,13 -1190,11 +1317,13 @@@ CMDLINE_SELECT=
      $CONFIG_LIST
      $THREADS_LIST
      asm
 +    coverage
      cross_compile
      debug
      extra_warnings
      logging
      optimizations
 +    stripping
      symver
      yasm
  "
@@@ -1338,12 -1214,10 +1343,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
@@@ -1388,10 -1254,6 +1393,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"
@@@ -1434,7 -1296,6 +1439,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"
@@@ -1443,7 -1304,6 +1448,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"
@@@ -1456,7 -1316,6 +1461,7 @@@ flac_decoder_select="golomb
  flac_encoder_select="golomb lpc"
  flashsv_decoder_select="zlib"
  flashsv_encoder_select="zlib"
 +flashsv2_encoder_select="zlib"
  flashsv2_decoder_select="zlib"
  flv_decoder_select="h263_decoder"
  flv_encoder_select="h263_encoder"
@@@ -1467,12 -1326,10 +1472,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"
@@@ -1499,20 -1356,15 +1504,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"
@@@ -1537,18 -1389,15 +1542,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"
@@@ -1572,7 -1421,6 +1577,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"
@@@ -1583,7 -1431,6 +1588,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"
  libgsm_decoder_deps="libgsm"
  libgsm_encoder_deps="libgsm"
@@@ -1601,31 -1446,24 +1606,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"
@@@ -1635,8 -1473,6 +1640,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"
@@@ -1663,30 -1499,22 +1668,30 @@@ w64_demuxer_deps="wav_demuxer
  alsa_indev_deps="alsa_asoundlib_h snd_pcm_htimestamp"
  alsa_outdev_deps="alsa_asoundlib_h"
  bktr_indev_deps_any="dev_bktr_ioctl_bt848_h machine_ioctl_bt848_h dev_video_bktr_ioctl_bt848_h dev_ic_bt8xx_h"
 +dshow_indev_deps="IBaseFilter"
 +dshow_indev_extralibs="-lpsapi -lole32 -lstrmiids -luuid"
  dv1394_indev_deps="dv1394 dv_demuxer"
  fbdev_indev_deps="linux_fb_h"
 -jack_indev_deps="jack_jack_h"
 +jack_indev_deps="jack_jack_h sem_timedwait"
 +lavfi_indev_deps="avfilter"
  libcdio_indev_deps="libcdio"
  libdc1394_indev_deps="libdc1394"
 +libv4l2_indev_deps="libv4l2"
 +openal_indev_deps="openal"
  oss_indev_deps_any="soundcard_h sys_soundcard_h"
  oss_outdev_deps_any="soundcard_h sys_soundcard_h"
  pulse_indev_deps="libpulse"
 +sdl_outdev_deps="sdl"
  sndio_indev_deps="sndio_h"
  sndio_outdev_deps="sndio_h"
 +v4l_indev_deps="linux_videodev_h"
  v4l2_indev_deps_any="linux_videodev2_h sys_videoio_h"
  vfwcap_indev_deps="capCreateCaptureWindow vfwcap_defines"
  vfwcap_indev_extralibs="-lavicap32"
  x11_grab_device_indev_deps="x11grab XShmCreateImage"
  
  # protocols
 +bluray_protocol_deps="libbluray"
  gopher_protocol_deps="network"
  httpproxy_protocol_deps="network"
  httpproxy_protocol_select="tcp_protocol"
@@@ -1714,52 -1542,34 +1719,52 @@@ 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"
 +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"
  
@@@ -1793,11 -1603,11 +1798,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
  
@@@ -1827,27 -1625,23 +1832,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=":"
@@@ -1860,12 -1654,6 +1865,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
  
@@@ -1873,10 -1661,8 +1878,10 @@@ enable avcode
  enable avdevice
  enable avfilter
  enable avformat
 -enable avresample
  enable avutil
 +enable postproc
 +enable stripping
 +enable swresample
  enable swscale
  
  enable asm
@@@ -1891,7 -1677,7 +1896,7 @@@ enable swscale_alph
  
  # build settings
  SHFLAGS='-shared -Wl,-soname,$$(@F)'
 -AVSERVERLDFLAGS=-Wl,-E
 +FFSERVERLDFLAGS=-Wl,-E
  LIBPREF="lib"
  LIBSUF=".a"
  FULLNAME='$(NAME)$(BUILDSUF)'
@@@ -1907,7 -1693,6 +1912,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'
@@@ -1934,7 -1719,7 +1939,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(){
@@@ -1974,12 -1759,11 +1979,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
@@@ -2002,27 -1786,6 +2007,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"
@@@ -2088,7 -1843,7 +2093,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
@@@ -2098,29 -1853,17 +2103,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
  
@@@ -2163,7 -1906,6 +2168,7 @@@ trap 'rm -f -- $TMPFILES' EXI
  
  tmpfile TMPASM .asm
  tmpfile TMPC   .c
 +tmpfile TMPCPP .cpp
  tmpfile TMPE   $EXESUF
  tmpfile TMPH   .h
  tmpfile TMPO   .o
@@@ -2398,11 -2140,9 +2403,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)
 -        arch="ppc"
 -    ;;
 -    ppc64|powerpc64)
 +    "Power Macintosh"|ppc|powerpc|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
@@@ -2596,28 -2340,6 +2601,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
@@@ -2658,7 -2380,6 +2663,7 @@@ if test "$?" != 0; the
  fi
  
  add_cppflags -D_ISOC99_SOURCE
 +add_cxxflags -D__STDC_CONSTANT_MACROS
  check_cflags -std=c99
  check_cc -D_FILE_OFFSET_BITS=64 <<EOF && add_cppflags -D_FILE_OFFSET_BITS=64
  #include <stdlib.h>
              spic=$shared
          fi
      ;;
 +    ppc)
 +        check_cc <<EOF && subarch="ppc64"
 +        int test[(int)sizeof(char*) - 7];
 +EOF
 +    ;;
  esac
  
  enable $subarch
@@@ -2701,7 -2417,7 +2706,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
@@@ -2873,7 -2585,7 +2878,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
  
@@@ -2894,20 -2606,14 +2899,20 @@@ 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
  
  die_license_disabled version3 libopencore_amrnb
  die_license_disabled version3 libopencore_amrwb
@@@ -2971,7 -2677,7 +2976,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
@@@ -2994,15 -2700,6 +2999,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
  
  if enabled network; then
      check_type "sys/types.h sys/socket.h" socklen_t
      check_type netdb.h "struct addrinfo"
+     check_type netinet/in.h "struct group_source_req" -D_BSD_SOURCE
+     check_type netinet/in.h "struct ip_mreq_source" -D_BSD_SOURCE
      check_type netinet/in.h "struct ipv6_mreq" -D_DARWIN_C_SOURCE
      check_type netinet/in.h "struct sockaddr_in6"
      check_type "sys/types.h sys/socket.h" "struct sockaddr_storage"
              network_extralibs="-lws2_32"; }
          check_type ws2tcpip.h socklen_t
          check_type ws2tcpip.h "struct addrinfo"
+         check_type ws2tcpip.h "struct group_source_req"
+         check_type ws2tcpip.h "struct ip_mreq_source"
          check_type ws2tcpip.h "struct ipv6_mreq"
          check_type ws2tcpip.h "struct sockaddr_in6"
          check_type ws2tcpip.h "struct sockaddr_storage"
  # 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
@@@ -3162,14 -2862,12 +3171,14 @@@ 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 psapi.h" GetProcessMemoryInfo -lpsapi
  check_func_headers windows.h GetProcessAffinityMask
  check_func_headers windows.h GetProcessTimes
@@@ -3177,11 -2875,10 +3186,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 dxva2api.h
+ check_header dxva.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
@@@ -3189,32 -2886,22 +3199,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
          :
@@@ -3239,17 -2926,14 +3249,19 @@@ 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
  check_mathfunc exp2
  check_mathfunc exp2f
+ check_mathfunc isinf
+ check_mathfunc isnan
  check_mathfunc llrint
  check_mathfunc llrintf
  check_mathfunc log2
@@@ -3263,54 -2947,35 +3275,54 @@@ 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 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 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 ||
@@@ -3325,28 -2990,15 +3337,28 @@@ if enabled libdc1394; the
      die "ERROR: No version of libdc1394 found "
  fi
  
 +SDL_CONFIG="${cross_prefix}sdl-config"
  if check_pkg_config sdl SDL_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
 +makeinfo --version > /dev/null 2>&1 && enable makeinfo  || disable makeinfo
  
  check_header linux/fb.h
 +check_header linux/videodev.h
  check_header linux/videodev2.h
  check_struct linux/videodev2.h "struct v4l2_frmivalenum" discrete
  
@@@ -3357,8 -3009,6 +3369,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
@@@ -3394,11 -3037,9 +3406,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
@@@ -3409,8 -3050,6 +3421,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
@@@ -3422,17 -3061,17 +3434,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
@@@ -3510,6 -3145,7 +3522,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
@@@ -3539,41 -3175,9 +3551,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"
@@@ -3581,9 -3185,6 +3593,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
@@@ -3612,10 -3213,6 +3624,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}"
@@@ -3626,12 -3223,10 +3638,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}"
@@@ -3643,17 -3238,12 +3655,17 @@@ 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 "libgsm enabled            ${libgsm-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}"
@@@ -3662,10 -3252,7 +3674,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}"
@@@ -3673,12 -3260,9 +3685,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
@@@ -3705,15 -3289,11 +3717,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
@@@ -3722,13 -3302,9 +3734,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
@@@ -3736,22 -3312,18 +3748,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
@@@ -3762,7 -3334,6 +3774,7 @@@ EXESUF=$EXESU
  EXTRA_VERSION=$extra_version
  DEPFLAGS=$DEPFLAGS
  CCDEP=$CCDEP
 +CXXDEP=$CXXDEP
  ASDEP=$ASDEP
  CC_DEPFLAGS=$CC_DEPFLAGS
  AS_DEPFLAGS=$AS_DEPFLAGS
@@@ -3777,7 -3348,7 +3789,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}
@@@ -3788,18 -3359,14 +3800,18 @@@ 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(){
      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
@@@ -3810,30 -3377,24 +3822,30 @@@ get_version LIBAVDEVICE libavdevice/avd
  get_version LIBAVFILTER libavfilter/version.h
  get_version LIBAVFORMAT libavformat/version.h
  get_version LIBAVRESAMPLE libavresample/version.h
 -get_version LIBAVUTIL   libavutil/avutil.h
 +get_version LIBAVUTIL   libavutil/version.h
 +get_version LIBPOSTPROC libpostproc/postprocess.h
 +get_version LIBSWRESAMPLE libswresample/swresample.h
  get_version LIBSWSCALE  libswscale/swscale.h
  
  cat > $TMPH <<EOF
  /* Automatically generated by configure - do not modify! */
 -#ifndef LIBAV_CONFIG_H
 -#define LIBAV_CONFIG_H
 -#define LIBAV_CONFIGURATION "$(c_escape $LIBAV_CONFIGURATION)"
 -#define LIBAV_LICENSE "$(c_escape $license)"
 +#ifndef FFMPEG_CONFIG_H
 +#define FFMPEG_CONFIG_H
 +#define FFMPEG_CONFIGURATION "$(c_escape $FFMPEG_CONFIGURATION)"
 +#define FFMPEG_LICENSE "$(c_escape $license)"
 +#define FFMPEG_DATADIR "$(eval c_escape $datadir)"
  #define AVCONV_DATADIR "$(eval c_escape $datadir)"
  #define CC_TYPE "$cc_type"
  #define CC_VERSION $cc_version
 -#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
  
@@@ -3858,14 -3419,12 +3870,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
@@@ -3879,12 -3438,6 +3891,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
@@@ -3936,23 -3489,10 +3948,23 @@@ 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/protocols.texi
@@@ -1,10 -1,10 +1,10 @@@
  @chapter Protocols
  @c man begin PROTOCOLS
  
 -Protocols are configured elements in Libav which allow to access
 +Protocols are configured elements in FFmpeg which allow to access
  resources which require the use of a particular protocol.
  
 -When you configure your Libav build, all the supported protocols are
 +When you configure your FFmpeg build, all the supported protocols are
  enabled by default. You can list all available ones using the
  configure option "--list-protocols".
  
@@@ -19,36 -19,6 +19,36 @@@ supported protocols
  
  A description of the currently available protocols follows.
  
 +@section bluray
 +
 +Read BluRay playlist.
 +
 +The accepted options are:
 +@table @option
 +
 +@item angle
 +BluRay angle
 +
 +@item chapter
 +Start chapter (1...N)
 +
 +@item playlist
 +Playlist to read (BDMV/PLAYLIST/?????.mpls)
 +
 +@end table
 +
 +Examples:
 +
 +Read longest playlist from BluRay mounted to /mnt/bluray:
 +@example
 +bluray:/mnt/bluray
 +@end example
 +
 +Read angle 2 of playlist 4 from BluRay mounted to /mnt/bluray, start from chapter 2:
 +@example
 +-playlist 4 -angle 2 -chapter 2 bluray:/mnt/bluray
 +@end example
 +
  @section concat
  
  Physical concatenation protocol.
@@@ -66,10 -36,10 +66,10 @@@ resource to be concatenated, each one p
  protocol.
  
  For example to read a sequence of files @file{split1.mpeg},
 -@file{split2.mpeg}, @file{split3.mpeg} with @command{avplay} use the
 +@file{split2.mpeg}, @file{split3.mpeg} with @command{ffplay} use the
  command:
  @example
 -avplay concat:split1.mpeg\|split2.mpeg\|split3.mpeg
 +ffplay concat:split1.mpeg\|split2.mpeg\|split3.mpeg
  @end example
  
  Note that you may need to escape the character "|" which is special for
@@@ -81,10 -51,10 +81,10 @@@ File access protocol
  
  Allow to read from or read to a file.
  
 -For example to read from a file @file{input.mpeg} with @command{avconv}
 +For example to read from a file @file{input.mpeg} with @command{ffmpeg}
  use the command:
  @example
 -avconv -i file:input.mpeg output.mpeg
 +ffmpeg -i file:input.mpeg output.mpeg
  @end example
  
  The ff* tools default to the file protocol, that is a resource
@@@ -143,10 -113,10 +143,10 @@@ be used to test muxers without writing 
  Some examples follow.
  @example
  # Write the MD5 hash of the encoded AVI file to the file output.avi.md5.
 -avconv -i input.flv -f avi -y md5:output.avi.md5
 +ffmpeg -i input.flv -f avi -y md5:output.avi.md5
  
  # Write the MD5 hash of the encoded AVI file to stdout.
 -avconv -i input.flv -f avi -y md5:
 +ffmpeg -i input.flv -f avi -y md5:
  @end example
  
  Note that some formats (typically MOV) require the output protocol to
@@@ -168,18 -138,18 +168,18 @@@ pipe (e.g. 0 for stdin, 1 for stdout, 
  is not specified, by default the stdout file descriptor will be used
  for writing, stdin for reading.
  
 -For example to read from stdin with @command{avconv}:
 +For example to read from stdin with @command{ffmpeg}:
  @example
 -cat test.wav | avconv -i pipe:0
 +cat test.wav | ffmpeg -i pipe:0
  # ...this is the same as...
 -cat test.wav | avconv -i pipe:
 +cat test.wav | ffmpeg -i pipe:
  @end example
  
 -For writing to stdout with @command{avconv}:
 +For writing to stdout with @command{ffmpeg}:
  @example
 -avconv -i test.wav -f avi pipe:1 | cat > test.avi
 +ffmpeg -i test.wav -f avi pipe:1 | cat > test.avi
  # ...this is the same as...
 -avconv -i test.wav -f avi pipe: | cat > test.avi
 +ffmpeg -i test.wav -f avi pipe: | cat > test.avi
  @end example
  
  Note that some formats (typically MOV), require the output protocol to
@@@ -271,10 -241,10 +271,10 @@@ URL of the target stream
  
  @end table
  
 -For example to read with @command{avplay} a multimedia resource named
 +For example to read with @command{ffplay} a multimedia resource named
  "sample" from the application "vod" from an RTMP server "myserver":
  @example
 -avplay rtmp://myserver/vod/sample
 +ffplay rtmp://myserver/vod/sample
  @end example
  
  @section rtmpt
@@@ -315,14 -285,14 +315,14 @@@ meaning as specified for the RTMP nativ
  See the librtmp manual page (man 3 librtmp) for more information.
  
  For example, to stream a file in real-time to an RTMP server using
 -@command{avconv}:
 +@command{ffmpeg}:
  @example
 -avconv -re -i myfile -f flv rtmp://myserver/live/mystream
 +ffmpeg -re -i myfile -f flv rtmp://myserver/live/mystream
  @end example
  
 -To play the same stream using @command{avplay}:
 +To play the same stream using @command{ffplay}:
  @example
 -avplay "rtmp://myserver/live/mystream live=1"
 +ffplay "rtmp://myserver/live/mystream live=1"
  @end example
  
  @section rtp
@@@ -345,7 -315,7 +345,7 @@@ The required syntax for a RTSP url is
  rtsp://@var{hostname}[:@var{port}]/@var{path}
  @end example
  
 -The following options (set on the @command{avconv}/@command{avplay} command
 +The following options (set on the @command{ffmpeg}/@command{ffplay} command
  line, or set in code via @code{AVOption}s or in @code{avformat_open_input}),
  are supported:
  
@@@ -384,7 -354,7 +384,7 @@@ When receiving data over UDP, the demux
  can be disabled by setting the maximum demuxing delay to zero (via
  the @code{max_delay} field of AVFormatContext).
  
 -When watching multi-bitrate Real-RTSP streams with @command{avplay}, the
 +When watching multi-bitrate Real-RTSP streams with @command{ffplay}, the
  streams to display can be chosen with @code{-vst} @var{n} and
  @code{-ast} @var{n} for video and audio respectively, and can be switched
  on the fly by pressing @code{v} and @code{a}.
@@@ -394,19 -364,19 +394,19 @@@ Example command lines
  To watch a stream over UDP, with a max reordering delay of 0.5 seconds:
  
  @example
 -avplay -max_delay 500000 -rtsp_transport udp rtsp://server/video.mp4
 +ffplay -max_delay 500000 -rtsp_transport udp rtsp://server/video.mp4
  @end example
  
  To watch a stream tunneled over HTTP:
  
  @example
 -avplay -rtsp_transport http rtsp://server/video.mp4
 +ffplay -rtsp_transport http rtsp://server/video.mp4
  @end example
  
  To send a stream in realtime to a RTSP server, for others to watch:
  
  @example
 -avconv -re -i @var{input} -f rtsp -muxdelay 0.1 rtsp://server/live.sdp
 +ffmpeg -re -i @var{input} -f rtsp -muxdelay 0.1 rtsp://server/live.sdp
  @end example
  
  @section sap
@@@ -458,19 -428,19 +458,19 @@@ Example command lines follow
  To broadcast a stream on the local subnet, for watching in VLC:
  
  @example
 -avconv -re -i @var{input} -f sap sap://224.0.0.255?same_port=1
 +ffmpeg -re -i @var{input} -f sap sap://224.0.0.255?same_port=1
  @end example
  
 -Similarly, for watching in avplay:
 +Similarly, for watching in @command{ffplay}:
  
  @example
 -avconv -re -i @var{input} -f sap sap://224.0.0.255
 +ffmpeg -re -i @var{input} -f sap sap://224.0.0.255
  @end example
  
 -And for watching in avplay, over IPv6:
 +And for watching in @command{ffplay}, over IPv6:
  
  @example
 -avconv -re -i @var{input} -f sap sap://[ff0e::1:2:3:4]
 +ffmpeg -re -i @var{input} -f sap sap://[ff0e::1:2:3:4]
  @end example
  
  @subsection Demuxer
@@@ -492,13 -462,13 +492,13 @@@ Example command lines follow
  To play back the first stream announced on the normal SAP multicast address:
  
  @example
 -avplay sap://
 +ffplay sap://
  @end example
  
  To play back the first stream announced on one the default IPv6 SAP multicast address:
  
  @example
 -avplay sap://[ff0e::2:7ffe]
 +ffplay sap://[ff0e::2:7ffe]
  @end example
  
  @section tcp
@@@ -516,8 -486,8 +516,8 @@@ tcp://@var{hostname}:@var{port}[?@var{o
  Listen for an incoming connection
  
  @example
 -avconv -i @var{input} -f @var{format} tcp://@var{hostname}:@var{port}?listen
 -avplay tcp://@var{hostname}:@var{port}
 +ffmpeg -i @var{input} -f @var{format} tcp://@var{hostname}:@var{port}?listen
 +ffplay tcp://@var{hostname}:@var{port}
  @end example
  
  @end table
@@@ -566,23 -536,31 +566,31 @@@ and makes writes return with AVERROR(EC
  unreachable" is received.
  For receiving, this gives the benefit of only receiving packets from
  the specified peer address/port.
+ @item sources=@var{address}[,@var{address}]
+ Only receive packets sent to the multicast group from one of the
+ specified sender IP addresses.
+ @item block=@var{address}[,@var{address}]
+ Ignore packets sent to the multicast group from the specified
+ sender IP addresses.
  @end table
  
 -Some usage examples of the udp protocol with @command{avconv} follow.
 +Some usage examples of the udp protocol with @command{ffmpeg} follow.
  
  To stream over UDP to a remote endpoint:
  @example
 -avconv -i @var{input} -f @var{format} udp://@var{hostname}:@var{port}
 +ffmpeg -i @var{input} -f @var{format} udp://@var{hostname}:@var{port}
  @end example
  
  To stream in mpegts format over UDP using 188 sized UDP packets, using a large input buffer:
  @example
 -avconv -i @var{input} -f mpegts udp://@var{hostname}:@var{port}?pkt_size=188&buffer_size=65535
 +ffmpeg -i @var{input} -f mpegts udp://@var{hostname}:@var{port}?pkt_size=188&buffer_size=65535
  @end example
  
  To receive over UDP from a remote endpoint:
  @example
 -avconv -i udp://[@var{multicast-address}]:@var{port}
 +ffmpeg -i udp://[@var{multicast-address}]:@var{port}
  @end example
  
  @c man end PROTOCOLS
@@@ -3,20 -3,20 +3,20 @@@
   *
   * copyright (c) 2010 Laurent Aimar
   *
 - * This file is part of Libav.
 + * This file is part of FFmpeg.
   *
 - * Libav is free software; you can redistribute it and/or
 + * FFmpeg is free software; you can redistribute it and/or
   * modify it under the terms of the GNU Lesser General Public
   * License as published by the Free Software Foundation; either
   * version 2.1 of the License, or (at your option) any later version.
   *
 - * Libav is distributed in the hope that it will be useful,
 + * FFmpeg is distributed in the hope that it will be useful,
   * but WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   * Lesser General Public License for more details.
   *
   * You should have received a copy of the GNU Lesser General Public
 - * License along with Libav; if not, write to the Free Software
 + * License along with FFmpeg; if not, write to the Free Software
   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
   */
  
  
  #define _WIN32_WINNT 0x0600
  #define COBJMACROS
+ #include "config.h"
  #include "dxva2.h"
+ #if HAVE_DXVA_H
+ #include <dxva.h>
+ #endif
  #include "avcodec.h"
  #include "mpegvideo.h"
  
diff --combined libavcodec/mss1.c
@@@ -2,20 -2,20 +2,20 @@@
   * Microsoft Screen 1 (aka Windows Media Video V7 Screen) decoder
   * Copyright (c) 2012 Konstantin Shishkov
   *
 - * 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
   */
  
@@@ -554,10 -554,10 +554,10 @@@ static int decode_pal(MSS1Context *ctx
          r = arith_get_bits(acoder, 8);
          g = arith_get_bits(acoder, 8);
          b = arith_get_bits(acoder, 8);
 -        *pal++ = (r << 16) | (g << 8) | b;
 +        *pal++ = (0xFF << 24) | (r << 16) | (g << 8) | b;
      }
  
-     return 1;
+     return !!ncol;
  }
  
  static int decode_pivot(MSS1Context *ctx, ArithCoder *acoder, int base)
@@@ -783,8 -783,10 +783,10 @@@ static av_cold int mss1_decode_init(AVC
      av_log(avctx, AV_LOG_DEBUG, "Encoder version %d.%d\n",
             AV_RB32(avctx->extradata + 4), AV_RB32(avctx->extradata + 8));
      c->free_colours     = AV_RB32(avctx->extradata + 48);
-     if (c->free_colours < 0 || c->free_colours > 256) {
-         av_log(avctx, AV_LOG_ERROR, "Invalid free colours %d\n", c->free_colours);
+     if ((unsigned)c->free_colours > 256) {
+         av_log(avctx, AV_LOG_ERROR,
+                "Incorrect number of changeable palette entries: %d\n",
+                c->free_colours);
          return AVERROR_INVALIDDATA;
      }
      av_log(avctx, AV_LOG_DEBUG, "%d free colour(s)\n", c->free_colours);
             av_int2float(AV_RB32(avctx->extradata + 44)));
  
      for (i = 0; i < 256; i++)
 -        c->pal[i] = AV_RB24(avctx->extradata + 52 + i * 3);
 +        c->pal[i] = 0xFF << 24 | AV_RB24(avctx->extradata + 52 + i * 3);
  
      avctx->pix_fmt = PIX_FMT_PAL8;
  
@@@ -6,20 -6,20 +6,20 @@@
  ;* This algorithm (though not any of the implementation details) is
  ;* based on libdjbfft by D. J. Bernstein.
  ;*
 -;* 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
  ;******************************************************************************
  
@@@ -28,7 -28,7 +28,7 @@@
  ; in blocks as conventient to the vector size.
  ; i.e. {4x real, 4x imaginary, 4x real, ...} (or 2x respectively)
  
 -%include "x86inc.asm"
 +%include "libavutil/x86/x86inc.asm"
  
  %if ARCH_X86_64
  %define pointer resq
@@@ -36,8 -36,6 +36,8 @@@
  %define pointer resd
  %endif
  
 +SECTION_RODATA
 +
  struc FFTContext
      .nbits:    resd 1
      .reverse:  resd 1
@@@ -53,6 -51,8 +53,6 @@@
      .imdcthalf:pointer 1
  endstruc
  
 -SECTION_RODATA
 -
  %define M_SQRT1_2 0.70710678118654752440
  %define M_COS_PI_1_8 0.923879532511287
  %define M_COS_PI_3_8 0.38268343236509
@@@ -393,7 -393,6 +393,7 @@@ fft32_interleave_avx
      sub r2d, mmsize/4
      jg .deint_loop
      ret
 +
  %endif
  
  INIT_XMM sse
@@@ -616,8 -615,6 +616,6 @@@ cglobal fft_calc, 2,5,
  .end:
      REP_RET
  
- cextern_naked memcpy
  cglobal fft_permute, 2,7,1
      mov     r4,  [r0 + FFTContext.revtab]
      mov     r5,  [r0 + FFTContext.tmpbuf]
      cmp     r0, r2
      jl      .loop
      shl     r2, 3
- %if ARCH_X86_64
-     mov     r0, r1
-     mov     r1, r5
- %endif
- %if WIN64
-     sub     rsp, 8
-     call    memcpy
-     add     rsp, 8
-     RET
- %elif ARCH_X86_64
- %ifdef PIC
-     jmp     memcpy wrt ..plt
- %else
-     jmp     memcpy
- %endif
- %else
-     push    r2
-     push    r5
-     push    r1
-     call    memcpy
-     add     esp, 12
-     RET
- %endif
+     add     r1, r2
+     add     r5, r2
+     neg     r2
+ ; nbits >= 2 (FFT4) and sizeof(FFTComplex)=8 => at least 32B
+ .loopcopy:
+     movaps  xmm0, [r5 + r2]
+     movaps  xmm1, [r5 + r2 + 16]
+     movaps  [r1 + r2], xmm0
+     movaps  [r1 + r2 + 16], xmm1
+     add     r2, 32
+     jl      .loopcopy
+     REP_RET
  
  cglobal imdct_calc, 3,5,3
      mov     r3d, [r0 + FFTContext.mdctsize]
diff --combined libavformat/tcp.c
@@@ -2,20 -2,20 +2,20 @@@
   * TCP protocol
   * Copyright (c) 2002 Fabrice Bellard
   *
 - * This file is part of Libav.
 + * This file is part of FFmpeg.
   *
 - * Libav is free software; you can redistribute it and/or
 + * FFmpeg is free software; you can redistribute it and/or
   * modify it under the terms of the GNU Lesser General Public
   * License as published by the Free Software Foundation; either
   * version 2.1 of the License, or (at your option) any later version.
   *
 - * Libav is distributed in the hope that it will be useful,
 + * FFmpeg is distributed in the hope that it will be useful,
   * but WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   * Lesser General Public License for more details.
   *
   * You should have received a copy of the GNU Lesser General Public
 - * License along with Libav; if not, write to the Free Software
 + * License along with FFmpeg; if not, write to the Free Software
   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
   */
  #include "avformat.h"
@@@ -43,7 -43,7 +43,7 @@@ static int tcp_open(URLContext *h, cons
      char buf[256];
      int ret;
      socklen_t optlen;
 -    int timeout = 100;
 +    int timeout = 50;
      char hostname[1024],proto[1024],path[1024];
      char portstr[10];
  
      hints.ai_family = AF_UNSPEC;
      hints.ai_socktype = SOCK_STREAM;
      snprintf(portstr, sizeof(portstr), "%d", port);
-     ret = getaddrinfo(hostname, portstr, &hints, &ai);
+     if (listen_socket)
+         hints.ai_flags |= AI_PASSIVE;
+     if (!hostname[0])
+         ret = getaddrinfo(NULL, portstr, &hints, &ai);
+     else
+         ret = getaddrinfo(hostname, portstr, &hints, &ai);
      if (ret) {
          av_log(h, AV_LOG_ERROR,
                 "Failed to resolve hostname %s: %s\n",
diff --combined libavformat/udp.c
@@@ -2,20 -2,20 +2,20 @@@
   * UDP prototype streaming system
   * Copyright (c) 2000, 2001, 2002 Fabrice Bellard
   *
 - * This file is part of Libav.
 + * This file is part of FFmpeg.
   *
 - * Libav is free software; you can redistribute it and/or
 + * FFmpeg is free software; you can redistribute it and/or
   * modify it under the terms of the GNU Lesser General Public
   * License as published by the Free Software Foundation; either
   * version 2.1 of the License, or (at your option) any later version.
   *
 - * Libav is distributed in the hope that it will be useful,
 + * FFmpeg is distributed in the hope that it will be useful,
   * but WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   * Lesser General Public License for more details.
   *
   * You should have received a copy of the GNU Lesser General Public
 - * License along with Libav; if not, write to the Free Software
 + * License along with FFmpeg; if not, write to the Free Software
   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
   */
  
  #include "avformat.h"
  #include "avio_internal.h"
  #include "libavutil/parseutils.h"
 +#include "libavutil/fifo.h"
 +#include "libavutil/intreadwrite.h"
  #include "libavutil/avstring.h"
  #include "internal.h"
  #include "network.h"
  #include "os_support.h"
  #include "url.h"
  
 +#if HAVE_PTHREAD_CANCEL
 +#include <pthread.h>
 +#endif
 +
  #ifndef IPV6_ADD_MEMBERSHIP
  #define IPV6_ADD_MEMBERSHIP IPV6_JOIN_GROUP
  #define IPV6_DROP_MEMBERSHIP IPV6_LEAVE_GROUP
  #endif
  
 +#define UDP_TX_BUF_SIZE 32768
 +#define UDP_MAX_PKT_SIZE 65536
 +
  typedef struct {
      int udp_fd;
      int ttl;
      int is_multicast;
      int local_port;
      int reuse_socket;
 +    int overrun_nonfatal;
      struct sockaddr_storage dest_addr;
      int dest_addr_len;
      int is_connected;
 -} UDPContext;
  
 -#define UDP_TX_BUF_SIZE 32768
 -#define UDP_MAX_PKT_SIZE 65536
 +    /* Circular Buffer variables for use in UDP receive code */
 +    int circular_buffer_size;
 +    AVFifoBuffer *fifo;
 +    int circular_buffer_error;
 +#if HAVE_PTHREAD_CANCEL
 +    pthread_t circular_buffer_thread;
 +    pthread_mutex_t mutex;
 +    pthread_cond_t cond;
 +    int thread_started;
 +#endif
 +    uint8_t tmp[UDP_MAX_PKT_SIZE+4];
 +    int remaining_in_dg;
 +} UDPContext;
  
  static void log_net_error(void *ctx, int level, const char* prefix)
  {
@@@ -188,6 -168,79 +188,79 @@@ static struct addrinfo* udp_resolve_hos
      return res;
  }
  
+ static int udp_set_multicast_sources(int sockfd, struct sockaddr *addr,
+                                      int addr_len, char **sources,
+                                      int nb_sources, int include)
+ {
+ #if HAVE_STRUCT_GROUP_SOURCE_REQ && defined(MCAST_BLOCK_SOURCE) && !defined(_WIN32)
+     /* These ones are available in the microsoft SDK, but don't seem to work
+      * as on linux, so just prefer the v4-only approach there for now. */
+     int i;
+     for (i = 0; i < nb_sources; i++) {
+         struct group_source_req mreqs;
+         int level = addr->sa_family == AF_INET ? IPPROTO_IP : IPPROTO_IPV6;
+         struct addrinfo *sourceaddr = udp_resolve_host(sources[i], 0,
+                                                        SOCK_DGRAM, AF_UNSPEC,
+                                                        AI_NUMERICHOST);
+         if (!sourceaddr)
+             return AVERROR(ENOENT);
+         mreqs.gsr_interface = 0;
+         memcpy(&mreqs.gsr_group, addr, addr_len);
+         memcpy(&mreqs.gsr_source, sourceaddr->ai_addr, sourceaddr->ai_addrlen);
+         freeaddrinfo(sourceaddr);
+         if (setsockopt(sockfd, level,
+                        include ? MCAST_JOIN_SOURCE_GROUP : MCAST_BLOCK_SOURCE,
+                        (const void *)&mreqs, sizeof(mreqs)) < 0) {
+             if (include)
+                 log_net_error(NULL, AV_LOG_ERROR, "setsockopt(MCAST_JOIN_SOURCE_GROUP)");
+             else
+                 log_net_error(NULL, AV_LOG_ERROR, "setsockopt(MCAST_BLOCK_SOURCE)");
+             return ff_neterrno();
+         }
+     }
+ #elif HAVE_STRUCT_IP_MREQ_SOURCE && defined(IP_BLOCK_SOURCE)
+     int i;
+     if (addr->sa_family != AF_INET) {
+         av_log(NULL, AV_LOG_ERROR,
+                "Setting multicast sources only supported for IPv4\n");
+         return AVERROR(EINVAL);
+     }
+     for (i = 0; i < nb_sources; i++) {
+         struct ip_mreq_source mreqs;
+         struct addrinfo *sourceaddr = udp_resolve_host(sources[i], 0,
+                                                        SOCK_DGRAM, AF_UNSPEC,
+                                                        AI_NUMERICHOST);
+         if (!sourceaddr)
+             return AVERROR(ENOENT);
+         if (sourceaddr->ai_addr->sa_family != AF_INET) {
+             freeaddrinfo(sourceaddr);
+             av_log(NULL, AV_LOG_ERROR, "%s is of incorrect protocol family\n",
+                    sources[i]);
+             return AVERROR(EINVAL);
+         }
+         mreqs.imr_multiaddr.s_addr = ((struct sockaddr_in *)addr)->sin_addr.s_addr;
+         mreqs.imr_interface.s_addr = INADDR_ANY;
+         mreqs.imr_sourceaddr.s_addr = ((struct sockaddr_in *)sourceaddr->ai_addr)->sin_addr.s_addr;
+         freeaddrinfo(sourceaddr);
+         if (setsockopt(sockfd, IPPROTO_IP,
+                        include ? IP_ADD_SOURCE_MEMBERSHIP : IP_BLOCK_SOURCE,
+                        (const void *)&mreqs, sizeof(mreqs)) < 0) {
+             if (include)
+                 log_net_error(NULL, AV_LOG_ERROR, "setsockopt(IP_ADD_SOURCE_MEMBERSHIP)");
+             else
+                 log_net_error(NULL, AV_LOG_ERROR, "setsockopt(IP_BLOCK_SOURCE)");
+             return ff_neterrno();
+         }
+     }
+ #else
+     return AVERROR(ENOSYS);
+ #endif
+     return 0;
+ }
  static int udp_set_url(struct sockaddr_storage *addr,
                         const char *hostname, int port)
  {
@@@ -264,7 -317,6 +337,7 @@@ static int udp_port(struct sockaddr_sto
   *         'localport=n' : set the local port
   *         'pkt_size=n'  : set max packet size
   *         'reuse=1'     : enable reusing the socket
 + *         'overrun_nonfatal=1': survive in case of circular buffer overrun
   *
   * @param h media file context
   * @param uri of the remote server
@@@ -326,61 -378,6 +399,61 @@@ static int udp_get_file_handle(URLConte
      return s->udp_fd;
  }
  
 +#if HAVE_PTHREAD_CANCEL
 +static void *circular_buffer_task( void *_URLContext)
 +{
 +    URLContext *h = _URLContext;
 +    UDPContext *s = h->priv_data;
 +    int old_cancelstate;
 +
 +    pthread_setcancelstate(PTHREAD_CANCEL_DISABLE, &old_cancelstate);
 +    ff_socket_nonblock(s->udp_fd, 0);
 +    pthread_mutex_lock(&s->mutex);
 +    while(1) {
 +        int len;
 +
 +        pthread_mutex_unlock(&s->mutex);
 +        /* Blocking operations are always cancellation points;
 +           see "General Information" / "Thread Cancelation Overview"
 +           in Single Unix. */
 +        pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, &old_cancelstate);
 +        len = recv(s->udp_fd, s->tmp+4, sizeof(s->tmp)-4, 0);
 +        pthread_setcancelstate(PTHREAD_CANCEL_DISABLE, &old_cancelstate);
 +        pthread_mutex_lock(&s->mutex);
 +        if (len < 0) {
 +            if (ff_neterrno() != AVERROR(EAGAIN) && ff_neterrno() != AVERROR(EINTR)) {
 +                s->circular_buffer_error = ff_neterrno();
 +                goto end;
 +            }
 +            continue;
 +        }
 +        AV_WL32(s->tmp, len);
 +
 +        if(av_fifo_space(s->fifo) < len + 4) {
 +            /* No Space left */
 +            if (s->overrun_nonfatal) {
 +                av_log(h, AV_LOG_WARNING, "Circular buffer overrun. "
 +                        "Surviving due to overrun_nonfatal option\n");
 +                continue;
 +            } else {
 +                av_log(h, AV_LOG_ERROR, "Circular buffer overrun. "
 +                        "To avoid, increase fifo_size URL option. "
 +                        "To survive in such case, use overrun_nonfatal option\n");
 +                s->circular_buffer_error = AVERROR(EIO);
 +                goto end;
 +            }
 +        }
 +        av_fifo_generic_write(s->fifo, s->tmp, len+4, NULL);
 +        pthread_cond_signal(&s->cond);
 +    }
 +
 +end:
 +    pthread_cond_signal(&s->cond);
 +    pthread_mutex_unlock(&s->mutex);
 +    return NULL;
 +}
 +#endif
 +
  /* put it in UDP context */
  /* return non zero if error */
  static int udp_open(URLContext *h, const char *uri, int flags)
      struct sockaddr_storage my_addr;
      int len;
      int reuse_specified = 0;
+     int i, include = 0, num_sources = 0;
+     char *sources[32];
  
      h->is_streamed = 1;
      h->max_packet_size = 1472;
      s->ttl = 16;
      s->buffer_size = is_output ? UDP_TX_BUF_SIZE : UDP_MAX_PKT_SIZE;
  
 +    s->circular_buffer_size = 7*188*4096;
 +
      p = strchr(uri, '?');
      if (p) {
          if (av_find_info_tag(buf, sizeof(buf), "reuse", p)) {
                  s->reuse_socket = 1;
              reuse_specified = 1;
          }
 +        if (av_find_info_tag(buf, sizeof(buf), "overrun_nonfatal", p)) {
 +            char *endptr = NULL;
 +            s->overrun_nonfatal = strtol(buf, &endptr, 10);
 +            /* assume if no digits were found it is a request to enable it */
 +            if (buf == endptr)
 +                s->overrun_nonfatal = 1;
 +        }
          if (av_find_info_tag(buf, sizeof(buf), "ttl", p)) {
              s->ttl = strtol(buf, NULL, 10);
          }
          if (av_find_info_tag(buf, sizeof(buf), "connect", p)) {
              s->is_connected = strtol(buf, NULL, 10);
          }
 +        if (av_find_info_tag(buf, sizeof(buf), "fifo_size", p)) {
 +            s->circular_buffer_size = strtol(buf, NULL, 10)*188;
 +        }
          if (av_find_info_tag(buf, sizeof(buf), "localaddr", p)) {
              av_strlcpy(localaddr, buf, sizeof(localaddr));
          }
+         if (av_find_info_tag(buf, sizeof(buf), "sources", p))
+             include = 1;
+         if (include || av_find_info_tag(buf, sizeof(buf), "block", p)) {
+             char *source_start;
+             source_start = buf;
+             while (1) {
+                 char *next = strchr(source_start, ',');
+                 if (next)
+                     *next = '\0';
+                 sources[num_sources] = av_strdup(source_start);
+                 if (!sources[num_sources])
+                     goto fail;
+                 source_start = next + 1;
+                 num_sources++;
+                 if (num_sources >= FF_ARRAY_ELEMS(sources) || !next)
+                     break;
+             }
+         }
      }
  
      /* fill the dest addr */
          }
          if (h->flags & AVIO_FLAG_READ) {
              /* input */
-             if (udp_join_multicast_group(udp_fd, (struct sockaddr *)&s->dest_addr) < 0)
+             if (num_sources == 0 || !include) {
+                 if (udp_join_multicast_group(udp_fd, (struct sockaddr *)&s->dest_addr) < 0)
+                     goto fail;
+                 if (num_sources) {
+                     if (udp_set_multicast_sources(udp_fd, (struct sockaddr *)&s->dest_addr, s->dest_addr_len, sources, num_sources, 0) < 0)
+                         goto fail;
+                 }
+             } else if (include && num_sources) {
+                 if (udp_set_multicast_sources(udp_fd, (struct sockaddr *)&s->dest_addr, s->dest_addr_len, sources, num_sources, 1) < 0)
+                     goto fail;
+             } else {
+                 av_log(NULL, AV_LOG_ERROR, "invalid udp settings: inclusive multicast but no sources given\n");
                  goto fail;
+             }
          }
      }
  
          }
      }
  
+     for (i = 0; i < num_sources; i++)
+         av_free(sources[i]);
      s->udp_fd = udp_fd;
 +
 +#if HAVE_PTHREAD_CANCEL
 +    if (!is_output && s->circular_buffer_size) {
 +        int ret;
 +
 +        /* start the task going */
 +        s->fifo = av_fifo_alloc(s->circular_buffer_size);
 +        ret = pthread_mutex_init(&s->mutex, NULL);
 +        if (ret != 0) {
 +            av_log(h, AV_LOG_ERROR, "pthread_mutex_init failed : %s\n", strerror(ret));
 +            goto fail;
 +        }
 +        ret = pthread_cond_init(&s->cond, NULL);
 +        if (ret != 0) {
 +            av_log(h, AV_LOG_ERROR, "pthread_cond_init failed : %s\n", strerror(ret));
 +            goto cond_fail;
 +        }
 +        ret = pthread_create(&s->circular_buffer_thread, NULL, circular_buffer_task, h);
 +        if (ret != 0) {
 +            av_log(h, AV_LOG_ERROR, "pthread_create failed : %s\n", strerror(ret));
 +            goto thread_fail;
 +        }
 +        s->thread_started = 1;
 +    }
 +#endif
 +
      return 0;
 +#if HAVE_PTHREAD_CANCEL
 + thread_fail:
 +    pthread_cond_destroy(&s->cond);
 + cond_fail:
 +    pthread_mutex_destroy(&s->mutex);
 +#endif
   fail:
      if (udp_fd >= 0)
          closesocket(udp_fd);
 +    av_fifo_free(s->fifo);
+     for (i = 0; i < num_sources; i++)
+         av_free(sources[i]);
      return AVERROR(EIO);
  }
  
@@@ -574,48 -565,6 +686,48 @@@ static int udp_read(URLContext *h, uint
  {
      UDPContext *s = h->priv_data;
      int ret;
 +    int avail, nonblock = h->flags & AVIO_FLAG_NONBLOCK;
 +
 +#if HAVE_PTHREAD_CANCEL
 +    if (s->fifo) {
 +        pthread_mutex_lock(&s->mutex);
 +        do {
 +            avail = av_fifo_size(s->fifo);
 +            if (avail) { // >=size) {
 +                uint8_t tmp[4];
 +
 +                av_fifo_generic_read(s->fifo, tmp, 4, NULL);
 +                avail= AV_RL32(tmp);
 +                if(avail > size){
 +                    av_log(h, AV_LOG_WARNING, "Part of datagram lost due to insufficient buffer size\n");
 +                    avail= size;
 +                }
 +
 +                av_fifo_generic_read(s->fifo, buf, avail, NULL);
 +                av_fifo_drain(s->fifo, AV_RL32(tmp) - avail);
 +                pthread_mutex_unlock(&s->mutex);
 +                return avail;
 +            } else if(s->circular_buffer_error){
 +                int err = s->circular_buffer_error;
 +                pthread_mutex_unlock(&s->mutex);
 +                return err;
 +            } else if(nonblock) {
 +                pthread_mutex_unlock(&s->mutex);
 +                return AVERROR(EAGAIN);
 +            }
 +            else {
 +                /* FIXME: using the monotonic clock would be better,
 +                   but it does not exist on all supported platforms. */
 +                int64_t t = av_gettime() + 100000;
 +                struct timespec tv = { .tv_sec  =  t / 1000000,
 +                                       .tv_nsec = (t % 1000000) * 1000 };
 +                if (pthread_cond_timedwait(&s->cond, &s->mutex, &tv) < 0)
 +                    return AVERROR(errno == ETIMEDOUT ? EAGAIN : errno);
 +                nonblock = 1;
 +            }
 +        } while( 1);
 +    }
 +#endif
  
      if (!(h->flags & AVIO_FLAG_NONBLOCK)) {
          ret = ff_network_wait_fd(s->udp_fd, 0);
              return ret;
      }
      ret = recv(s->udp_fd, buf, size, 0);
 +
      return ret < 0 ? ff_neterrno() : ret;
  }
  
@@@ -651,23 -599,10 +763,23 @@@ static int udp_write(URLContext *h, con
  static int udp_close(URLContext *h)
  {
      UDPContext *s = h->priv_data;
 +    int ret;
  
      if (s->is_multicast && (h->flags & AVIO_FLAG_READ))
          udp_leave_multicast_group(s->udp_fd, (struct sockaddr *)&s->dest_addr);
      closesocket(s->udp_fd);
 +#if HAVE_PTHREAD_CANCEL
 +    if (s->thread_started) {
 +        pthread_cancel(s->circular_buffer_thread);
 +        ret = pthread_join(s->circular_buffer_thread, NULL);
 +        if (ret != 0)
 +            av_log(h, AV_LOG_ERROR, "pthread_join(): %s\n", strerror(ret));
 +    }
 +
 +    pthread_mutex_destroy(&s->mutex);
 +    pthread_cond_destroy(&s->cond);
 +#endif
 +    av_fifo_free(s->fifo);
      return 0;
  }
  
diff --combined libavutil/libm.h
@@@ -1,18 -1,18 +1,18 @@@
  /*
 - * 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 <math.h>
  #include "config.h"
  #include "attributes.h"
+ #include "intfloat.h"
  
 +#if HAVE_MIPSFPU && HAVE_INLINE_ASM
 +#include "libavutil/mips/libm_mips.h"
 +#endif /* HAVE_MIPSFPU && HAVE_INLINE_ASM*/
 +
  #if !HAVE_CBRTF
  static av_always_inline float cbrtf(float x)
  {
  #define exp2f(x) ((float)exp2(x))
  #endif /* HAVE_EXP2F */
  
+ #if !HAVE_ISINF
+ static av_always_inline av_const int isinf(float x)
+ {
+     uint32_t v = av_float2int(x);
+     if ((v & 0x7f800000) != 0x7f800000)
+         return 0;
+     return !(v & 0x007fffff);
+ }
+ #endif /* HAVE_ISINF */
+ #if !HAVE_ISNAN
+ static av_always_inline av_const int isnan(float x)
+ {
+     uint32_t v = av_float2int(x);
+     if ((v & 0x7f800000) != 0x7f800000)
+         return 0;
+     return v & 0x007fffff;
+ }
+ #endif /* HAVE_ISNAN */
  #if !HAVE_LLRINT
  #undef llrint
  #define llrint(x) ((long long)rint(x))