Merge remote-tracking branch 'qatar/master'
authorMichael Niedermayer <michaelni@gmx.at>
Fri, 21 Sep 2012 12:25:21 +0000 (14:25 +0200)
committerMichael Niedermayer <michaelni@gmx.at>
Fri, 21 Sep 2012 12:44:32 +0000 (14:44 +0200)
* qatar/master:
  libx264: add forgotten ;
  matroskadec: fix a sanity check.
  matroskadec: only return corrupt packets that actually contain data
  lavf: zero data/size of the packet passed to read_packet().
  ARM: use 2-operand syntax for ADD Rd, PC in Apple PIC code
  ARM: align PIC offset pools to 4 bytes
  ARM: swap source operands in some add instructions
  configure: update tms470 detection for latest version
  lavf probe: prevent codec probe with no data at all seen
  motion_est: fix use of inline on extern functions

Conflicts:
libavcodec/motion_est_template.c
libavformat/matroskadec.c

Merged-by: Michael Niedermayer <michaelni@gmx.at>
1  2 
configure
libavcodec/arm/dsputil_arm.S
libavcodec/arm/vp8_armv6.S
libavcodec/libx264.c
libavcodec/motion_est.c
libavcodec/motion_est_template.c
libavformat/matroskadec.c
libavformat/utils.c
libavutil/arm/asm.S

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]
@@@ -99,29 -99,20 +99,29 @@@ Configuration options
    --enable-gray            enable full grayscale support (slower color)
    --disable-swscale-alpha  disable alpha channel support in swscale
  
 -Component options:
 +Documentation 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-htmlpages      do not build HTML documentation pages
 +  --disable-manpages       do not build man documentation pages
 +  --disable-podpages       do not build POD documentation pages
 +  --disable-txtpages       do not build text documentation pages
 +
 +Component options:
 +  --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-avfilter       disable video filter support [no]
 -  --disable-avresample     disable libavresample build [no]
 +  --disable-postproc       disable libpostproc build
 +  --disable-avfilter       disable libavfilter build
 +  --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-libcaca         enable textual display using libcaca
 +  --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-libfaac         enable AAC encoding via libfaac [no]
    --enable-libfdk-aac      enable AAC encoding via libfdk-aac [no]
 +  --enable-libflite        enable flite (voice synthesis) support via libflite [no]
    --enable-libfreetype     enable libfreetype [no]
    --enable-libgsm          enable GSM de/encoding via libgsm [no]
 +  --enable-libiec61883     enable iec61883 via libiec61883 [no]
    --enable-libilbc         enable iLBC de/encoding via libilbc [no]
 +  --enable-libmodplug      enable ModPlug via libmodplug [no]
    --enable-libmp3lame      enable MP3 encoding via libmp3lame [no]
 +  --enable-libnut          enable NUT (de)muxing via libnut,
 +                           native (de)muxer exists [no]
    --enable-libopencore-amrnb enable AMR-NB de/encoding via libopencore-amrnb [no]
    --enable-libopencore-amrwb enable AMR-WB decoding via libopencore-amrwb [no]
    --enable-libopencv       enable video filtering via libopencv [no]
    --enable-libopenjpeg     enable JPEG 2000 de/encoding via OpenJPEG [no]
 +  --enable-libopus         enable Opus decoding via libopus [no]
    --enable-libpulse        enable Pulseaudio input via libpulse [no]
    --enable-librtmp         enable RTMP[E] support via librtmp [no]
    --enable-libschroedinger enable Dirac de/encoding via libschroedinger [no]
    --enable-libspeex        enable Speex de/encoding via libspeex [no]
 +  --enable-libstagefright-h264  enable H.264 decoding via libstagefright [no]
    --enable-libtheora       enable Theora encoding via libtheora [no]
 +  --enable-libtwolame      enable MP2 encoding via libtwolame [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 [no]
 +  --enable-libvorbis       enable Vorbis en/decoding via libvorbis,
 +                           native implementation exists [no]
    --enable-libvpx          enable VP8 de/encoding 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]
  
@@@ -233,14 -206,12 +233,14 @@@ Advanced options (experts only)
    --target-exec=CMD        command to run executables on target
    --target-path=DIR        path to view of build directory on target
    --toolchain=NAME         set tool defaults according to NAME
 -  --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]
 +  --cxx=CXX                use C compiler CXX [$cxx_default]
    --dep-cc=DEPCC           use dependency generator DEPCC [$cc_default]
 -  --ld=LD                  use linker LD
 +  --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-ld=HOSTLD         use host linker HOSTLD
    --host-libs=HLIBS        use libs HLIBS when linking for host
    --host-os=OS             compiler host OS [$target_os]
    --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=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)
@@@ -293,29 -262,14 +293,29 @@@ Optimization options (experts only)
    --disable-vis            disable VIS optimizations
    --disable-inline-asm     disable use of inline assembler
    --disable-yasm           disable use of yasm assembler
 -
 -Developer options (useful when working on Libav itself):
 +  --disable-mips32r2       disable MIPS32R2 optimizations
 +  --disable-mipsdspr1      disable MIPS DSP ASE R1 optimizations
 +  --disable-mipsdspr2      disable MIPS DSP ASE R2 optimizations
 +  --disable-mipsfpu        disable floating point MIPS optimizations
 +  --disable-fast-unaligned consider unaligned accesses slow
 +  --postproc-version=V     build libpostproc version V.
 +                           Where V can be '$ALT_PP_VER_MAJOR.$ALT_PP_VER_MINOR.$ALT_PP_VER_MICRO' or 'current'. [$postproc_version_default]
 +
 +Developer options (useful when working on FFmpeg itself):
 +  --enable-coverage        build with test coverage instrumentation
    --disable-debug          disable debugging symbols
    --enable-debug=LEVEL     set the debug level [$debuglevel]
    --disable-optimizations  disable compiler optimizations
    --enable-extra-warnings  enable more compiler warnings
 +  --disable-stripping      disable stripping of executables and shared libraries
 +  --assert-level=level     0(default), 1 or 2, amount of assertion testing,
 +                           2 causes a slowdown at runtime.
 +  --enable-memory-poisoning fill heap uninitialized allocated space with arbitrary data
 +  --valgrind=VALGRIND      run "make fate" tests through valgrind to detect memory
 +                           leaks and errors, using the specified valgrind binary.
 +                           Cannot be combined with --target-exec
    --samples=PATH           location of test samples for FATE, if not set use
 -                           \$LIBAV_SAMPLES at make invocation time.
 +                           \$FATE_SAMPLES at make invocation time.
    --enable-xmm-clobber-test check XMM registers for clobbering (Win64-only;
                             should be used only for debugging purposes)
    --enable-random          randomly enable/disable components
@@@ -360,7 -314,7 +360,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
@@@ -664,10 -618,6 +664,10 @@@ add_cflags()
      append CFLAGS $($cflags_filter "$@")
  }
  
 +add_cxxflags(){
 +    append CXXFLAGS $($cflags_filter "$@")
 +}
 +
  add_asflags(){
      append ASFLAGS $($asflags_filter "$@")
  }
@@@ -708,13 -658,6 +708,13 @@@ check_cc()
      check_cmd $cc $CPPFLAGS $CFLAGS "$@" $CC_C $(cc_o $TMPO) $TMPC
  }
  
 +check_cxx(){
 +    log check_cxx "$@"
 +    cat > $TMPCPP
 +    log_file $TMPCPP
 +    check_cmd $cxx $CPPFLAGS $CFLAGS $CXXFLAGS "$@" $CXX_C -o $TMPO $TMPCPP
 +}
 +
  check_cpp(){
      log check_cpp "$@"
      cat > $TMPC
@@@ -749,7 -692,7 +749,7 @@@ check_yasm()
      echo "$1" > $TMPS
      log_file $TMPS
      shift 1
 -    check_cmd $yasmexe $YASMFLAGS "$@" -o $TMPO $TMPS
 +    check_cmd $yasmexe $YASMFLAGS -Werror "$@" -o $TMPO $TMPS
  }
  
  ld_o(){
  
  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 $($cflags_filter $flags) || return
 +    check_$type $($cflags_filter $flags) || return
      flags=$($ldflags_filter $flags)
      libs=$($ldflags_filter $libs)
      check_cmd $ld $LDFLAGS $flags $(ld_o $TMPE) $TMPO $libs $extralibs
@@@ -800,17 -741,9 +800,17 @@@ int x
  EOF
  }
  
 +check_cxxflags(){
 +    log check_cxxflags "$@"
 +    set -- $($cflags_filter "$@")
 +    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
  }
@@@ -836,7 -769,7 +836,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
@@@ -847,10 -780,10 +847,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
  }
  
@@@ -867,26 -800,7 +867,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(){
@@@ -918,21 -832,13 +918,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 foo(void){
 +int func(void){
      $code
  }
 +int (*func_ptr)(void) = func;
  int main(void){
      signal(SIGILL, sighandler);
      signal(SIGFPE, sighandler);
  #ifdef SIGBUS
      signal(SIGBUS, sighandler);
  #endif
 -    foo();
 +    return func_ptr();
  }
  EOF
  }
@@@ -1010,14 -915,6 +1010,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"
@@@ -1073,24 -970,15 +1073,24 @@@ COMPONENT_LIST=
      protocols
  "
  
 +DOCUMENT_LIST="
 +    doc
 +    htmlpages
 +    manpages
 +    podpages
 +    txtpages
 +"
 +
  PROGRAM_LIST="
 -    avconv
 -    avplay
 -    avprobe
 -    avserver
 +    ffplay
 +    ffprobe
 +    ffserver
 +    ffmpeg
  "
  
  CONFIG_LIST="
      $COMPONENT_LIST
 +    $DOCUMENT_LIST
      $PROGRAM_LIST
      avcodec
      avdevice
      avresample
      avisynth
      bzlib
 +    crystalhd
      dct
 -    doc
      dwt
      dxva2
 +    fast_unaligned
      fft
 +    fontconfig
      frei0r
      gnutls
      gpl
      gray
      hardcoded_tables
 +    incompatible_fork_abi
 +    libaacplus
 +    libass
 +    libbluray
 +    libcaca
      libcdio
 +    libcelt
      libdc1394
      libfaac
      libfdk_aac
 +    libflite
      libfreetype
      libgsm
 +    libiec61883
      libilbc
 +    libmodplug
      libmp3lame
 +    libnut
      libopencore_amrnb
      libopencore_amrwb
      libopencv
      libopenjpeg
 +    libopus
      libpulse
      librtmp
      libschroedinger
      libspeex
 +    libstagefright_h264
      libtheora
 +    libtwolame
 +    libutvideo
 +    libv4l2
      libvo_aacenc
      libvo_amrwbenc
      libvorbis
      lsp
      mdct
      memalign_hack
 +    memory_poisoning
      network
      nonfree
 +    openal
      openssl
      pic
 +    postproc
      rdft
      runtime_cpudetect
      safe_bitstream_reader
      small
      sram
      static
 +    swresample
      swscale
      swscale_alpha
      thumb
  THREADS_LIST='
      pthreads
      w32threads
 +    os2threads
  '
  
  ARCH_LIST='
@@@ -1237,16 -1103,11 +1237,16 @@@ ARCH_EXT_LIST=
      ppc4xx
      vfpv3
      vis
 +    mipsfpu
 +    mips32r2
 +    mipsdspr1
 +    mipsdspr2
  "
  
  HAVE_LIST_PUB='
      bigendian
      fast_unaligned
 +    incompatible_fork_abi
  '
  
  HAVE_LIST="
      arpa_inet_h
      asm_mod_q
      asm_mod_y
 +    asm_types_h
      attribute_may_alias
      attribute_packed
      cbrtf
 +    clock_gettime
      closesocket
      cmov
      cpuid
      GetSystemTimeAsFileTime
      getrusage
      gettimeofday
 +    glob
      gnu_as
      ibm_asm
      inet_aton
      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
      msvcrt
      nanosleep
 +    PeekNamedPipe
 +    perl
 +    pod2man
      poll_h
      posix_memalign
 +    pthread_cancel
      rdtsc
      rint
      round
      socklen_t
      soundcard_h
      strerror_r
 -    strptime
 -    strtok_r
      struct_addrinfo
      struct_group_source_req
      struct_ip_mreq_source
      struct_ipv6_mreq
      struct_pollfd
      struct_rusage_ru_maxrss
 +    struct_sctp_event_subscribe
      struct_sockaddr_in6
      struct_sockaddr_sa_len
      struct_sockaddr_storage
      sys_soundcard_h
      sys_time_h
      sys_videoio_h
 +    termios_h
 +    texi2html
      threads
      trunc
      truncf
@@@ -1428,14 -1278,12 +1428,14 @@@ CMDLINE_SELECT=
      $CONFIG_LIST
      $THREADS_LIST
      asm
 +    coverage
      cross_compile
      debug
      extra_warnings
      inline_asm
      logging
      optimizations
 +    stripping
      symver
      yasm
  "
@@@ -1455,12 -1303,10 +1455,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
      toolchain
 +    valgrind
 +    yasmexe
  "
  
  CMDLINE_APPEND="
      extra_cflags
 +    extra_cxxflags
  "
  
  # code dependency declarations
@@@ -1507,10 -1346,6 +1507,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"
@@@ -1573,7 -1408,6 +1573,7 @@@ ac3_fixed_encoder_select="mdct ac3dsp
  alac_encoder_select="lpc"
  amrnb_decoder_select="lsp"
  amrwb_decoder_select="lsp"
 +amv_encoder_select="aandcttables"
  atrac1_decoder_select="mdct sinewin"
  atrac3_decoder_select="mdct"
  binkaudio_dct_decoder_select="mdct rdft dct sinewin"
@@@ -1582,7 -1416,6 +1582,7 @@@ cavs_decoder_select="golomb mpegvideo
  cook_decoder_select="mdct sinewin"
  cscd_decoder_suggest="zlib"
  dca_decoder_select="mdct"
 +dirac_decoder_select="dwt golomb"
  dnxhd_encoder_select="aandcttables mpegvideoenc"
  dxa_decoder_select="zlib"
  eac3_decoder_select="ac3_decoder"
@@@ -1590,7 -1423,6 +1590,7 @@@ eac3_encoder_select="ac3_encoder
  eamad_decoder_select="aandcttables error_resilience mpegvideo"
  eatgq_decoder_select="aandcttables"
  eatqi_decoder_select="aandcttables error_resilience mpegvideo"
 +exr_decoder_select="zlib"
  ffv1_decoder_select="golomb rangecoder"
  ffv1_encoder_select="rangecoder"
  ffvhuff_encoder_select="huffman"
@@@ -1598,7 -1430,6 +1598,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"
@@@ -1610,13 -1441,10 +1610,13 @@@ h263_encoder_select="aandcttables error
  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="error_resilience golomb h264chroma h264dsp h264pred h264qpel mpegvideo"
  h264_dxva2_hwaccel_deps="dxva2api_h"
  h264_dxva2_hwaccel_select="dxva2 h264_decoder"
  h264_vaapi_hwaccel_select="vaapi h264_decoder"
 +h264_vda_decoder_select="vda h264_parser h264_decoder"
 +h264_vda_hwaccel_deps="VideoDecodeAcceleration_VDADecoder_h pthreads"
  h264_vda_hwaccel_select="vda h264_decoder"
  h264_vdpau_decoder_select="vdpau h264_decoder"
  huffyuv_encoder_select="huffman"
@@@ -1645,22 -1473,17 +1645,22 @@@ 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_decoder_select="error_resilience mpegvideo"
  mpeg1video_encoder_select="aandcttables error_resilience mpegvideoenc"
 +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_decoder_select="error_resilience mpegvideo"
  mpeg2video_encoder_select="aandcttables error_resilience mpegvideoenc"
 +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"
@@@ -1686,9 -1509,6 +1686,9 @@@ shorten_decoder_select="golomb
  sipr_decoder_select="lsp"
  snow_decoder_select="dwt rangecoder"
  snow_encoder_select="aandcttables dwt error_resilience mpegvideoenc rangecoder"
 +sonic_decoder_select="golomb"
 +sonic_encoder_select="golomb"
 +sonic_ls_encoder_select="golomb"
  svq1_decoder_select="error_resilience mpegvideo"
  svq1_encoder_select="aandcttables error_resilience mpegvideoenc"
  svq3_decoder_select="error_resilience golomb h264chroma h264dsp h264pred h264qpel mpegvideo"
@@@ -1696,11 -1516,10 +1696,11 @@@ svq3_decoder_suggest="zlib
  theora_decoder_select="vp3_decoder"
  tiff_decoder_suggest="zlib"
  tiff_encoder_suggest="zlib"
 -truehd_decoder_select="mlp_decoder"
 +truehd_decoder_select="mlp_parser"
  tscc_decoder_select="zlib"
  twinvq_decoder_select="mdct lsp sinewin"
  utvideo_encoder_select="huffman"
 +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"
@@@ -1726,7 -1545,6 +1726,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"
@@@ -1737,7 -1555,6 +1737,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"
@@@ -1749,8 -1566,6 +1749,8 @@@ mpegvideo_parser_select="error_resilien
  vc1_parser_select="error_resilience mpegvideo"
  
  # external libraries
 +libaacplus_encoder_deps="libaacplus"
 +libcelt_decoder_deps="libcelt"
  libfaac_encoder_deps="libfaac"
  libfdk_aac_encoder_deps="libfdk_aac"
  libgsm_decoder_deps="libgsm"
@@@ -1759,33 -1574,25 +1759,33 @@@ 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"
 +libopus_decoder_deps="libopus"
  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"
 +libtwolame_encoder_deps="libtwolame"
  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"
@@@ -1795,8 -1602,6 +1795,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"
@@@ -1825,32 -1630,22 +1825,32 @@@ 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"
 +caca_outdev_deps="libcaca"
 +dshow_indev_deps="IBaseFilter"
 +dshow_indev_extralibs="-lpsapi -lole32 -lstrmiids -luuid"
  dv1394_indev_deps="dv1394 dv_demuxer"
  fbdev_indev_deps="linux_fb_h"
 -jack_indev_deps="jack_jack_h"
 +iec61883_indev_deps="libiec61883"
 +jack_indev_deps="jack_jack_h sem_timedwait"
 +lavfi_indev_deps="avfilter"
  libcdio_indev_deps="libcdio"
  libdc1394_indev_deps="libdc1394"
 +libv4l2_indev_deps="libv4l2"
 +openal_indev_deps="openal"
  oss_indev_deps_any="soundcard_h sys_soundcard_h"
  oss_outdev_deps_any="soundcard_h sys_soundcard_h"
  pulse_indev_deps="libpulse"
 +sdl_outdev_deps="sdl"
  sndio_indev_deps="sndio_h"
  sndio_outdev_deps="sndio_h"
 +v4l_indev_deps="linux_videodev_h"
  v4l2_indev_deps_any="linux_videodev2_h sys_videoio_h"
  vfwcap_indev_deps="capCreateCaptureWindow vfwcap_defines"
  vfwcap_indev_extralibs="-lavicap32"
 -x11grab_indev_deps="x11grab XShmCreateImage"
 +x11grab_indev_deps="x11grab"
  
  # protocols
 +bluray_protocol_deps="libbluray"
  ffrtmpcrypt_protocol_deps="!librtmp_protocol"
  ffrtmpcrypt_protocol_deps_any="gcrypt nettle openssl"
  ffrtmpcrypt_protocol_select="tcp_protocol"
@@@ -1885,78 -1680,41 +1885,78 @@@ 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"
 +decimate_filter_deps="gpl avcodec"
  delogo_filter_deps="gpl"
 +deshake_filter_deps="avcodec"
  drawtext_filter_deps="libfreetype"
 -frei0r_filter_deps="frei0r dlopen strtok_r"
 +flite_filter_deps="libflite"
 +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 inline_asm"
 +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"
 +smartblur_filter_deps="gpl swscale"
 +showspectrum_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'
 -
 -doc_deps="texi2html"
 +ffmpeg_deps="avcodec avfilter avformat swscale swresample"
 +ffmpeg_select="ffbuffersink_filter format_filter aformat_filter
 +               setpts_filter null_filter anull_filter ffabuffersink_filter"
 +ffplay_deps="avcodec avformat swscale swresample sdl"
 +ffplay_select="ffbuffersink_filter rdft crop_filter"
 +ffprobe_deps="avcodec avformat"
 +ffserver_deps="avformat ffm_muxer fork rtp_protocol rtsp_demuxer"
 +ffserver_extralibs='$ldl'
 +
 +# documentation
 +podpages_deps="perl"
 +manpages_deps="perl pod2man"
 +htmlpages_deps="texi2html"
 +txtpages_deps="makeinfo"
 +doc_deps_any="manpages htmlpages podpages txtpages"
  
  # tests
 -
 +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"
  seek_lavf_mxf_d10_test_deps="mxf_d10_test"
 +zlib_test_deps="zlib"
 +zmbv_test_deps="zlib"
  
  test_deps(){
      suf1=$1
@@@ -1983,11 -1741,11 +1983,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                                                                 \
@@@ -2003,26 -1761,22 +2003,26 @@@ 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++"
  host_cc_default="gcc"
 +install="install"
  ln_s="ln -sf"
  nm_default="nm -g"
  objformat="elf"
  pkg_config_default=pkg-config
  ranlib="ranlib"
 -yasmexe="yasm"
 +strip_default="strip"
 +yasmexe_default="yasm"
  
  nogas=":"
  
@@@ -2034,24 -1788,15 +2034,24 @@@ 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
 +enable $DOCUMENT_LIST
  
  enable avcodec
  enable avdevice
  enable avfilter
  enable avformat
 -enable avresample
  enable avutil
 +enable postproc
 +enable stripping
 +enable swresample
  enable swscale
  
  enable asm
@@@ -2065,7 -1810,7 +2065,7 @@@ enable swscale_alph
  
  # build settings
  SHFLAGS='-shared -Wl,-soname,$$(@F)'
 -AVSERVERLDFLAGS=-Wl,-E
 +FFSERVERLDFLAGS=-Wl,-E
  LIBPREF="lib"
  LIBSUF=".a"
  FULLNAME='$(NAME)$(BUILDSUF)'
@@@ -2088,8 -1833,6 +2088,8 @@@ AS_O='-o $@
  CC_C='-c'
  CC_E='-E -o $@'
  CC_O='-o $@'
 +CXX_C='-c'
 +CXX_O='-o $@'
  LD_O='-o $@'
  LD_LIB='-l%'
  LD_PATH='-L'
@@@ -2124,7 -1867,7 +2124,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(){
@@@ -2164,12 -1907,11 +2164,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
@@@ -2278,7 -2020,7 +2278,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
@@@ -2288,25 -2030,13 +2288,25 @@@ 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"
  
@@@ -2322,7 -2052,7 +2322,7 @@@ case "$toolchain" i
      ;;
  esac
  
 -set_default cc pkg_config sysinclude
 +set_default cc cxx pkg_config strip sysinclude yasmexe
  enabled cross_compile || host_cc_default=$cc
  set_default host_cc
  
@@@ -2365,7 -2095,6 +2365,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,7 -2127,7 +2398,7 @@@ msvc_flags()
              -Wall)                echo -W4 -wd4244 -wd4127 -wd4018 -wd4389 \
                                         -wd4146 -wd4057 -wd4204 -wd4706 -wd4305 \
                                         -wd4152 -wd4324 -we4013 -wd4100 -wd4214 \
 -                                       -wd4996 ;;
 +                                       -wd4996 -wd4554 ;;
              -std=c99)             ;;
              -fno-math-errno)      ;;
              -fno-common)          ;;
@@@ -2546,7 -2275,7 +2546,7 @@@ probe_cc()
          _depflags='-MMD'
          _cflags_speed='-O3'
          _cflags_size='-Os'
-     elif $_cc -version 2>/dev/null | grep -q TMS470; then
+     elif $_cc -version 2>/dev/null | grep -Eq 'TMS470|TI ARM'; then
          _type=tms470
          _ident=$($_cc -version | head -n1 | tr -s ' ')
          _flags='--gcc --abi=eabi -me'
          if [ $pfx = hostcc ]; then
              append _cflags -Dsnprintf=_snprintf
          fi
 +        disable stripping
      fi
  
      eval ${pfx}_type=\$_type
@@@ -2700,7 -2428,6 +2700,7 @@@ els
  fi
  
  add_cflags $extra_cflags
 +add_cxxflags $extra_cxxflags
  add_asflags $extra_cflags
  
  if test -n "$sysroot"; then
  
  # Deal with common $arch aliases
  case "$arch" in
 -    arm*)
 +    arm*|iPad*)
          arch="arm"
      ;;
      mips|mipsel|IP*)
          arch="parisc"
          subarch="parisc64"
      ;;
 -    "Power Macintosh"|ppc|powerpc)
 +    "Power Macintosh"|ppc|powerpc|ppc64|powerpc64)
          arch="ppc"
      ;;
 -    ppc64|powerpc64)
 -        arch="ppc"
 -        subarch="ppc64"
 -    ;;
      s390|s390x)
          arch="s390"
      ;;
          arch="sparc"
          subarch="sparc64"
      ;;
 -    i[3-6]86|i86pc|BePC|x86pc|x86_64|amd64)
 +    i[3-6]86|i86pc|BePC|x86pc|x86_64|x86_32|amd64)
          arch="x86"
      ;;
  esac
@@@ -2898,28 -2629,6 +2898,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
@@@ -2960,7 -2669,6 +2960,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>
@@@ -2983,11 -2691,6 +2983,11 @@@ case "$arch" i
              spic=$shared
          fi
      ;;
 +    ppc)
 +        check_cc <<EOF && subarch="ppc64"
 +        int test[(int)sizeof(char*) - 7];
 +EOF
 +    ;;
  esac
  
  enable $subarch
@@@ -3001,7 -2704,7 +3001,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"
          disable symver
          oss_indev_extralibs="-lossaudio"
          oss_outdev_extralibs="-lossaudio"
 +        enabled gcc || check_ldflags -Wl,-zmuldefs
          ;;
      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.
          ;;
      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 ||
          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)'
 +        dlltool="${cross_prefix}dlltool"
 +        if check_cmd lib.exe -list; then
 +            SLIB_EXTRA_CMD='-lib.exe /machine:$(LIBTARGET) /def:$$(@:$(SLIBSUF)=.def) /out:$(SUBDIR)$(SLIBNAME:$(SLIBSUF)=.lib)'
 +            if enabled x86_64; then
 +                LIBTARGET=x64
 +            fi
 +        elif check_cmd $dlltool --version; then
 +            SLIB_EXTRA_CMD=-'$(DLLTOOL) -m $(LIBTARGET) -d $$(@:$(SLIBSUF)=.def) -l $(SUBDIR)$(SLIBNAME:$(SLIBSUF)=.lib) -D $(SLIBNAME_WITH_MAJOR)'
 +        fi
          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"
          ranlib=:
          enable dos_paths
          check_cflags -fno-common
          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
@@@ -3210,7 -2901,7 +3210,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
  
@@@ -3232,21 -2923,15 +3232,21 @@@ die_license_disabled() 
      enabled $1 || { enabled $2 && die "$2 is $1 and --enable-$1 is not specified."; }
  }
  
 +die_license_disabled_gpl() {
 +    enabled $1 || { enabled $2 && die "$2 is incompatible with the gpl and --enable-$1 is not specified."; }
 +}
 +
  die_license_disabled gpl libcdio
 +die_license_disabled gpl libutvideo
  die_license_disabled gpl libx264
  die_license_disabled gpl libxavs
  die_license_disabled gpl libxvid
  die_license_disabled gpl x11grab
  
 +die_license_disabled nonfree libaacplus
  die_license_disabled nonfree libfaac
 -die_license_disabled nonfree libfdk_aac
 -die_license_disabled nonfree openssl
 +enabled gpl && die_license_disabled_gpl nonfree libfdk_aac
 +enabled gpl && die_license_disabled_gpl nonfree openssl
  
  die_license_disabled version3 libopencore_amrnb
  die_license_disabled version3 libopencore_amrwb
@@@ -3310,7 -2995,7 +3310,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
@@@ -3334,14 -3019,6 +3334,14 @@@ elif enabled mips; the
  
      check_inline_asm loongson '"dmult.g $1, $2, $3"'
      enabled mmi && check_inline_asm mmi '"lq $2, 0($2)"'
 +    enabled mips32r2  && add_cflags "-mips32r2" && add_asflags "-mips32r2" &&
 +     check_inline_asm mips32r2  '"rotr $t0, $t1, 1"'
 +    enabled mipsdspr1 && add_cflags "-mdsp" && add_asflags "-mdsp" &&
 +     check_inline_asm mipsdspr1 '"addu.qb $t0, $t1, $t2"'
 +    enabled mipsdspr2 && add_cflags "-mdspr2" && add_asflags "-mdspr2" &&
 +     check_inline_asm mipsdspr2 '"absq_s.qb $t0, $t1"'
 +    enabled mipsfpu   && add_cflags "-mhard-float" && add_asflags "-mhard-float" &&
 +     check_inline_asm mipsfpu   '"madd.d $f0, $f2, $f4, $f6"'
  
  elif enabled ppc; then
  
@@@ -3381,12 -3058,12 +3381,12 @@@ elif enabled sparc; the
  
  elif enabled x86; then
  
 -    check_code ld immintrin.h "return __xgetbv(0)" && enable xgetbv
 -    check_code ld intrin.h "int info[4]; __cpuid(info, 0)" && enable cpuid
 -    check_code ld intrin.h "__rdtsc()" && enable rdtsc
 -    check_code ld intrin.h "unsigned int x = __readeflags()" && enable rweflags
 +    check_code ld immintrin.h "return __xgetbv(0)" "cc" && enable xgetbv
 +    check_code ld intrin.h "int info[4]; __cpuid(info, 0)" "cc" && enable cpuid
 +    check_code ld intrin.h "__rdtsc()" "cc" && enable rdtsc
 +    check_code ld intrin.h "unsigned int x = __readeflags()" "cc" && enable rweflags
  
 -    check_code ld mmintrin.h "_mm_empty()" && enable mm_empty
 +    check_code ld mmintrin.h "_mm_empty()" "cc" && enable mm_empty
  
      enable local_aligned_8 local_aligned_16
  
  # Solaris has nanosleep in -lrt, OpenSolaris no longer needs that
  check_func nanosleep || { check_func nanosleep -lrt && add_extralibs -lrt; }
  
 +check_func  clock_gettime || { check_func clock_gettime -lrt && add_extralibs -lrt; }
  check_func  fcntl
  check_func  fork
  check_func  gethrtime
@@@ -3513,14 -3189,13 +3513,14 @@@ check_func  ${malloc_prefix}posix_memal
  check_func_headers malloc.h _aligned_malloc     && enable aligned_malloc
  check_func  setrlimit
  check_func  strerror_r
 -check_func  strptime
 -check_func  strtok_r
  check_func  sched_getaffinity
  check_func  sysconf
  check_func  sysctl
  check_func  usleep
 +check_func_headers conio.h kbhit
 +check_func_headers windows.h PeekNamedPipe
  check_func_headers io.h setmode
 +check_func_headers lzo/lzo1x.h lzo1x_999_compress
  check_lib2 "windows.h shellapi.h" CommandLineToArgvW -lshell32
  check_lib2 "windows.h psapi.h" GetProcessMemoryInfo -lpsapi
  check_func_headers windows.h GetProcessAffinityMask
@@@ -3529,14 -3204,12 +3529,14 @@@ 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 direct.h
  check_header dlfcn.h
  check_header dxva.h
 -check_header dxva2api.h
 +check_header dxva2api.h -D_WIN32_WINNT=0x0600
  check_header io.h
 +check_header libcrystalhd/libcrystalhd_if.h
  check_header malloc.h
  check_header poll.h
  check_header sys/mman.h
@@@ -3544,32 -3217,22 +3544,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
          :
@@@ -3594,12 -3257,7 +3594,12 @@@ for thread in $THREADS_LIST; d
      fi
  done
  
 +if enabled pthreads; then
 +  check_func pthread_cancel
 +fi
 +
  check_lib math.h sin -lm && LIBM="-lm"
 +disabled crystalhd || check_lib libcrystalhd/libcrystalhd_if.h DtsCrystalHDVersion -lcrystalhd || disable crystalhd
  enabled vaapi && require vaapi va/va.h vaInitialize -lva
  
  check_mathfunc cbrtf
@@@ -3621,63 -3279,36 +3621,63 @@@ check_mathfunc trunc
  
  # these are off by default, so fail if requested and not available
  enabled avisynth   && require2 vfw32 "windows.h vfw.h" AVIFileInit -lavifil32
 +enabled fontconfig && require_pkg_config fontconfig "fontconfig/fontconfig.h" FcInit
  enabled frei0r     && { check_header frei0r.h || die "ERROR: frei0r.h header not found"; }
  enabled gnutls     && require_pkg_config gnutls gnutls/gnutls.h gnutls_global_init
 +enabled libiec61883 && require libiec61883 libiec61883/iec61883.h iec61883_cmp_connect -lraw1394 -lavc1394 -lrom1394 -liec61883
 +enabled libaacplus && require  "libaacplus >= 2.0.0" aacplus.h aacplusEncOpen -laacplus
 +enabled libass     && require_pkg_config libass ass/ass.h ass_library_init
 +enabled libbluray  && require libbluray libbluray/bluray.h bd_open -lbluray
 +enabled libcelt    && require libcelt celt/celt.h celt_decode -lcelt0 &&
 +                      { check_lib celt/celt.h celt_decoder_create_custom -lcelt0 ||
 +                        die "ERROR: libcelt must be installed and version must be >= 0.11.0."; }
 +enabled libcaca    && require_pkg_config caca caca.h caca_create_canvas
  enabled libfaac    && require2 libfaac "stdint.h faac.h" faacEncGetVersion -lfaac
  enabled libfdk_aac && require  libfdk_aac fdk-aac/aacenc_lib.h aacEncOpen -lfdk-aac
 +flite_libs="-lflite_cmu_time_awb -lflite_cmu_us_awb -lflite_cmu_us_kal -lflite_cmu_us_kal16 -lflite_cmu_us_rms -lflite_cmu_us_slt -lflite_usenglish -lflite_cmulex -lflite"
 +enabled libflite   && require2 libflite "flite/flite.h" flite_init $flite_libs
  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 libopus    && require_pkg_config opus opus_multistream.h opus_multistream_decoder_create
  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 libtwolame && require  libtwolame twolame.h twolame_init -ltwolame &&
 +                      { check_lib twolame.h twolame_encode_buffer_float32_interleaved -ltwolame ||
 +                        die "ERROR: libtwolame must be installed and version must be >= 0.3.10"; }
 +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"; } }
 +                                die "ERROR: libvpx decoder must be installed and 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."; }
 +                        die "ERROR: libx264 must be installed and 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 must be installed and 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 ||
@@@ -3697,30 -3328,15 +3697,30 @@@ if enabled libdc1394; the
      die "ERROR: No version of libdc1394 found "
  fi
  
 +SDL_CONFIG="${cross_prefix}sdl-config"
  if check_pkg_config sdl SDL_events.h SDL_PollEvent; then
      check_cpp_condition SDL.h "(SDL_MAJOR_VERSION<<16 | SDL_MINOR_VERSION<<8 | SDL_PATCHLEVEL) >= 0x010201" $sdl_cflags &&
      enable sdl &&
      check_struct SDL.h SDL_VideoInfo current_w $sdl_cflags && enable sdl_video_size
 +else
 +  if "${SDL_CONFIG}" --version > /dev/null 2>&1; then
 +    sdl_cflags=$("${SDL_CONFIG}" --cflags)
 +    sdl_libs=$("${SDL_CONFIG}" --libs)
 +    check_func_headers SDL_version.h SDL_Linked_Version $sdl_cflags $sdl_libs &&
 +    check_cpp_condition SDL.h "(SDL_MAJOR_VERSION<<16 | SDL_MINOR_VERSION<<8 | SDL_PATCHLEVEL) >= 0x010201" $sdl_cflags &&
 +    enable sdl &&
 +    check_struct SDL.h SDL_VideoInfo current_w $sdl_cflags && enable sdl_video_size
 +  fi
  fi
 +enabled sdl && add_cflags $sdl_cflags && add_extralibs $sdl_libs
  
 -texi2html -version > /dev/null 2>&1 && enable texi2html || disable texi2html
 +texi2html --help 2> /dev/null | grep -q 'init-file' && enable texi2html || disable texi2html
 +makeinfo --version > /dev/null 2>&1 && enable makeinfo  || disable makeinfo
 +perl --version > /dev/null 2>&1 && enable perl || disable perl
 +pod2man --help > /dev/null 2>&1 && enable pod2man || disable pod2man
  
  check_header linux/fb.h
 +check_header linux/videodev.h
  check_header linux/videodev2.h
  check_struct linux/videodev2.h "struct v4l2_frmivalenum" discrete
  
@@@ -3731,8 -3347,6 +3731,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
@@@ -3768,11 -3375,9 +3768,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
  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
@@@ -3794,17 -3397,17 +3794,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
@@@ -3883,6 -3482,7 +3883,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
@@@ -3914,42 -3514,9 +3914,42 @@@ check_deps $CONFIG_LIST       
             $ALL_COMPONENTS    \
             $ALL_TESTS         \
  
 +
 +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"
@@@ -3957,9 -3524,6 +3957,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
@@@ -3989,10 -3553,6 +3989,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}"
@@@ -4003,12 -3563,10 +4003,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}"
@@@ -4020,34 -3578,22 +4020,34 @@@ 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 "libcaca enabled           ${libcaca-no}"
  echo "libcdio support           ${libcdio-no}"
 +echo "libcelt enabled           ${libcelt-no}"
  echo "libdc1394 support         ${libdc1394-no}"
  echo "libfaac enabled           ${libfaac-no}"
  echo "libfdk-aac enabled        ${libfdk_aac-no}"
  echo "libgsm enabled            ${libgsm-no}"
 +echo "libiec61883 support       ${libiec61883-no}"
  echo "libilbc enabled           ${libilbc-no}"
 +echo "libmodplug enabled        ${libmodplug-no}"
  echo "libmp3lame enabled        ${libmp3lame-no}"
 +echo "libnut enabled            ${libnut-no}"
  echo "libopencore-amrnb support ${libopencore_amrnb-no}"
  echo "libopencore-amrwb support ${libopencore_amrwb-no}"
  echo "libopencv support         ${libopencv-no}"
  echo "libopenjpeg enabled       ${libopenjpeg-no}"
 +echo "libopus enabled           ${libopus-no}"
  echo "libpulse enabled          ${libpulse-no}"
  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 "libtwolame enabled        ${libtwolame-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}"
@@@ -4055,14 -3601,9 +4055,14 @@@ 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}"
 +echo "texi2html enabled         ${texi2html-no}"
 +echo "perl enabled              ${perl-no}"
 +echo "pod2man enabled           ${pod2man-no}"
 +echo "makeinfo enabled          ${makeinfo-no}"
  test -n "$random_seed" &&
      echo "random seed               ${random_seed}"
  echo
@@@ -4091,15 -3632,11 +4091,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
@@@ -4108,13 -3645,9 +4108,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
@@@ -4127,29 -3660,23 +4127,29 @@@ AR=$a
  ARFLAGS=$arflags
  AR_O=$ar_o
  RANLIB=$ranlib
 +CP=cp -p
  LN_S=$ln_s
 +STRIP=$strip
  CPPFLAGS=$CPPFLAGS
  CFLAGS=$CFLAGS
 +CXXFLAGS=$CXXFLAGS
  ASFLAGS=$ASFLAGS
  AS_C=$AS_C
  AS_O=$AS_O
  CC_C=$CC_C
  CC_O=$CC_O
 +CXX_C=$CXX_C
 +CXX_O=$CXX_O
  LD_O=$LD_O
  LD_LIB=$LD_LIB
  LD_PATH=$LD_PATH
  DLLTOOL=$dlltool
  LDFLAGS=$LDFLAGS
 -LDFLAGS-avserver=$AVSERVERLDFLAGS
 +LDFLAGS-ffserver=$FFSERVERLDFLAGS
  SHFLAGS=$SHFLAGS
  YASMFLAGS=$YASMFLAGS
  BUILDSUF=$build_suffix
 +PROGSSUF=$progs_suffix
  FULLNAME=$FULLNAME
  LIBPREF=$LIBPREF
  LIBSUF=$LIBSUF
@@@ -4159,7 -3686,6 +4159,7 @@@ SLIBSUF=$SLIBSU
  EXESUF=$EXESUF
  EXTRA_VERSION=$extra_version
  CCDEP=$CCDEP
 +CXXDEP=$CXXDEP
  CCDEP_FLAGS=$CCDEP_FLAGS
  ASDEP=$ASDEP
  ASDEP_FLAGS=$ASDEP_FLAGS
@@@ -4181,12 -3707,12 +4181,12 @@@ HOSTCC_O=$HOSTCC_
  HOSTLD_O=$HOSTLD_O
  TARGET_EXEC=$target_exec
  TARGET_PATH=$target_path
 -LIBS-avplay=$sdl_libs
 -CFLAGS-avplay=$sdl_cflags
 +LIBS-ffplay=$sdl_libs
 +CFLAGS-ffplay=$sdl_cflags
  ZLIB=$($ldflags_filter -lz)
  LIB_INSTALL_EXTRA_CMD=$LIB_INSTALL_EXTRA_CMD
  EXTRALIBS=$extralibs
 -INSTALL=install
 +INSTALL=$install
  LIBTARGET=${LIBTARGET}
  SLIBNAME=${SLIBNAME}
  SLIBNAME_WITH_VERSION=${SLIBNAME_WITH_VERSION}
@@@ -4197,8 -3723,7 +4197,8 @@@ SLIB_INSTALL_NAME=${SLIB_INSTALL_NAME
  SLIB_INSTALL_LINKS=${SLIB_INSTALL_LINKS}
  SLIB_INSTALL_EXTRA_LIB=${SLIB_INSTALL_EXTRA_LIB}
  SLIB_INSTALL_EXTRA_SHLIB=${SLIB_INSTALL_EXTRA_SHLIB}
 -SAMPLES:=${samples:-\$(LIBAV_SAMPLES)}
 +SAMPLES:=${samples:-\$(FATE_SAMPLES)}
 +NOREDZONE_FLAGS=$noredzone_flags
  EOF
  
  get_version(){
      eval echo "${lcname}_VERSION_MAJOR=\$${name}_VERSION_MAJOR" >> config.mak
  }
  
 +get_version_old(){
 +    name=$1
 +    file=$source_path/$2
 +# This condition will be removed when we stop supporting old libpostproc versions
 +if ! test "$name" = LIBPOSTPROC || test "$postproc_version" = current; then
 +    eval $(grep "#define ${name}_VERSION_M" "$file" | awk '{ print $2"="$3 }')
 +    eval ${name}_VERSION=\$${name}_VERSION_MAJOR.\$${name}_VERSION_MINOR.\$${name}_VERSION_MICRO
 +fi
 +    lcname=$(tolower $name)
 +    eval echo "${lcname}_VERSION=\$${name}_VERSION" >> config.mak
 +    eval echo "${lcname}_VERSION_MAJOR=\$${name}_VERSION_MAJOR" >> config.mak
 +}
 +
 +get_version_old LIBPOSTPROC libpostproc/postprocess.h
 +get_version_old LIBSWRESAMPLE libswresample/swresample.h
 +
  get_version libavcodec
  get_version libavdevice
  get_version libavfilter
@@@ -4237,23 -3746,18 +4237,23 @@@ get_version libswscal
  
  cat > $TMPH <<EOF
  /* Automatically generated by configure - do not modify! */
 -#ifndef LIBAV_CONFIG_H
 -#define LIBAV_CONFIG_H
 -#define LIBAV_CONFIGURATION "$(c_escape $LIBAV_CONFIGURATION)"
 -#define LIBAV_LICENSE "$(c_escape $license)"
 +#ifndef FFMPEG_CONFIG_H
 +#define FFMPEG_CONFIG_H
 +#define FFMPEG_CONFIGURATION "$(c_escape $FFMPEG_CONFIGURATION)"
 +#define FFMPEG_LICENSE "$(c_escape $license)"
 +#define FFMPEG_DATADIR "$(eval c_escape $datadir)"
  #define AVCONV_DATADIR "$(eval c_escape $datadir)"
  #define CC_IDENT "$(c_escape ${cc_ident:-Unknown compiler})"
 -#define restrict $_restrict
 +#define av_restrict $_restrict
  #define EXTERN_PREFIX "${extern_prefix}"
  #define EXTERN_ASM ${extern_prefix}
  #define SLIBSUF "$SLIBSUF"
 +#define HAVE_MMX2 HAVE_MMXEXT
  EOF
  
 +test -n "$assert_level" &&
 +    echo "#define ASSERT_LEVEL $assert_level" >>$TMPH
 +
  test -n "$malloc_prefix" &&
      echo "#define MALLOC_PREFIX $malloc_prefix" >>$TMPH
  
@@@ -4269,14 -3773,12 +4269,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
@@@ -4290,12 -3792,6 +4290,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
@@@ -4331,66 -3827,26 +4331,66 @@@ Libs: -L\${libdir} -l${shortname} $(ena
  Libs.private: $(enabled shared && echo $libs)
  Cflags: -I\${includedir}
  EOF
 -    cat <<EOF > $name/$name-uninstalled.pc
 +
 +mkdir -p doc/examples/pc-uninstalled
 +includedir=${source_path}
 +[ "$includedir" = . ] && includedir="\${pcfiledir}/../../.."
 +    cat <<EOF > doc/examples/pc-uninstalled/$name.pc
  prefix=
  exec_prefix=
 -libdir=\${pcfiledir}
 -includedir=${source_path}
 +libdir=\${pcfiledir}/../../../$name
 +includedir=${includedir}
  
  Name: $name
  Description: $comment
  Version: $version
  Requires: $requires
  Conflicts:
 -Libs: \${libdir}/${LIBPREF}${shortname}${LIBSUF} $libs
 +Libs: -L\${libdir} -l${shortname} $(enabled shared || echo $libs)
  Cflags: -I\${includedir}
  EOF
  }
  
 -pkgconfig_generate libavutil "Libav utility library" "$LIBAVUTIL_VERSION" "$LIBM"
 -pkgconfig_generate libavcodec "Libav codec library" "$LIBAVCODEC_VERSION" "$extralibs" "libavutil = $LIBAVUTIL_VERSION"
 -pkgconfig_generate libavformat "Libav container format library" "$LIBAVFORMAT_VERSION" "$extralibs" "libavcodec = $LIBAVCODEC_VERSION"
 -pkgconfig_generate libavdevice "Libav device handling library" "$LIBAVDEVICE_VERSION" "$extralibs" "libavformat = $LIBAVFORMAT_VERSION"
 -pkgconfig_generate libavfilter "Libav video filtering library" "$LIBAVFILTER_VERSION" "$extralibs"
 +libavfilter_pc_deps=""
 +enabled libavfilter_deps_avcodec    && prepend libavfilter_pc_deps "libavcodec = $LIBAVCODEC_VERSION,"
 +enabled libavfilter_deps_avformat   && prepend libavfilter_pc_deps "libavformat = $LIBAVFORMAT_VERSION,"
 +enabled libavfilter_deps_swscale    && prepend libavfilter_pc_deps "libswscale = $LIBSWSCALE_VERSION,"
 +enabled libavfilter_deps_swresample && prepend libavfilter_pc_deps "libswresample = $LIBSWRESAMPLE_VERSION,"
 +enabled libavfilter_deps_postproc   && prepend libavfilter_pc_deps "libpostproc = $LIBPOSTPROC_VERSION,"
 +libavfilter_pc_deps=${libavfilter_pc_deps%, }
 +
 +libavdevice_pc_deps="libavformat = $LIBAVFORMAT_VERSION"
 +enabled lavfi_indev && prepend libavdevice_pc_deps "libavfilter = $LIBAVFILTER_VERSION,"
 +
 +pkgconfig_generate libavutil "FFmpeg utility library" "$LIBAVUTIL_VERSION" "$LIBM"
 +pkgconfig_generate libavcodec "FFmpeg codec library" "$LIBAVCODEC_VERSION" "$extralibs" "libavutil = $LIBAVUTIL_VERSION"
 +pkgconfig_generate libavformat "FFmpeg container format library" "$LIBAVFORMAT_VERSION" "$extralibs" "libavcodec = $LIBAVCODEC_VERSION"
 +pkgconfig_generate libavdevice "FFmpeg device handling library" "$LIBAVDEVICE_VERSION" "$extralibs" "$libavdevice_pc_deps"
 +pkgconfig_generate libavfilter "FFmpeg video filtering library" "$LIBAVFILTER_VERSION" "$extralibs" "$libavfilter_pc_deps"
 +pkgconfig_generate libpostproc "FFmpeg postprocessing library" "$LIBPOSTPROC_VERSION" "" "libavutil = $LIBAVUTIL_VERSION"
  pkgconfig_generate libavresample "Libav audio resampling library" "$LIBAVRESAMPLE_VERSION" "$extralibs"
 -pkgconfig_generate libswscale "Libav image rescaling library" "$LIBSWSCALE_VERSION" "$LIBM" "libavutil = $LIBAVUTIL_VERSION"
 +pkgconfig_generate libswscale "FFmpeg image rescaling library" "$LIBSWSCALE_VERSION" "$LIBM" "libavutil = $LIBAVUTIL_VERSION"
 +pkgconfig_generate libswresample "FFmpeg audio rescaling library" "$LIBSWRESAMPLE_VERSION" "$LIBM" "libavutil = $LIBAVUTIL_VERSION"
 +
 +fix_ffmpeg_remote(){
 +    git_remote_from=$1
 +    git_remote_to=$2
 +    fixme_remote=$(git --git-dir=$source_path/.git --work-tree=$source_path remote -v | grep $git_remote_from | cut -f 1 | sort | uniq)
 +    if [ "$fixme_remote" != "" ]; then
 +        echolog "
 +Outdated domain in git config, the official domain for ffmpeg git is since
 +November 2011, source.ffmpeg.org, both the old and the new point to the same
 +repository and server. To update it enter the following commands:
 +"
 +        for remote in $fixme_remote; do
 +            echolog "git remote set-url $remote $git_remote_to"
 +        done
 +    fi
 +}
 +
 +if test -f "$source_path/.git/config"; then
 +    remote_from=git.videolan.org
 +    remote_to=source.ffmpeg.org
 +    fix_ffmpeg_remote git@$remote_from:ffmpeg   git@$remote_to:ffmpeg
 +    fix_ffmpeg_remote git://$remote_from/ffmpeg git://$remote_to/ffmpeg
 +fi
@@@ -2,20 -2,20 +2,20 @@@
  @ ARMv4 optimized DSP utils
  @ Copyright (c) 2004 AGAWA Koji <i (AT) atty (DOT) jp>
  @
 -@ 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
  @
  
@@@ -632,7 -632,7 +632,7 @@@ function ff_add_pixels_clamped_arm, exp
          ldrsh           r7,  [r0, #2]
          and             r6,  r4,  #0xFF
          and             r8,  r4,  #0xFF00
-         add             r6,  r5,  r6
+         add             r6,  r6,  r5
          add             r8,  r7,  r8,  lsr #8
          mvn             r5,  r5
          mvn             r7,  r7
          ldrsh           r7,  [r0, #10]
          and             r6,  r4,  #0xFF
          and             r8,  r4,  #0xFF00
-         add             r6,  r5,  r6
+         add             r6,  r6,  r5
          add             r8,  r7,  r8,  lsr #8
          mvn             r5,  r5
          mvn             r7,  r7
@@@ -1,20 -1,20 +1,20 @@@
  /*
   * Copyright (C) 2010 Mans Rullgard
   *
 - * 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
   */
  
@@@ -88,7 -88,7 +88,7 @@@ function ff_decode_block_coeffs_armv6, 
  
          add             r4,  r3,  r3,  lsl #5
          sxth            r12, r11
-         add             r4,  r2,  r4
+         add             r4,  r4,  r2
          adds            r6,  r6,  r9
          add             r4,  r4,  #11
          lsl             r8,  r8,  r9
@@@ -138,7 -138,7 +138,7 @@@ A       orrcs           r8,  r8,  r10, 
  2:
          add             r4,  r3,  r3,  lsl #5
          cmp             r3,  #16
-         add             r4,  r2,  r4
+         add             r4,  r4,  r2
          pkhtb           r11, r11, r11, asr #16
          bne             0b
          b               6b
          ldr             r1,  [sp, #4]
  4:
          add             r4,  r3,  r3,  lsl #5
-         add             r4,  r2,  r4
+         add             r4,  r4,  r2
          add             r4,  r4,  #22
          rac_get_128     r5,  r6,  r7,  r8,  r9,  r10
          it              ge
diff --combined libavcodec/libx264.c
@@@ -2,20 -2,20 +2,20 @@@
   * H.264 encoding using the x264 library
   * Copyright (C) 2005  Mans Rullgard <mans@mansr.com>
   *
 - * 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
   */
  
@@@ -43,10 -43,7 +43,10 @@@ typedef struct X264Context 
      char *preset;
      char *tune;
      char *profile;
 +    char *level;
      int fastfirstpass;
 +    char *wpredp;
 +    char *x264opts;
      float crf;
      float crf_max;
      int cqp;
@@@ -72,7 -69,7 +72,7 @@@
      int direct_pred;
      int slice_max_size;
      char *stats;
-     int nal_hrd
+     int nal_hrd;
  } X264Context;
  
  static void X264_log(void *p, int level, const char *fmt, va_list args)
@@@ -104,21 -101,16 +104,21 @@@ static int encode_nals(AVCodecContext *
      for (i = 0; i < nnal; i++)
          size += nals[i].i_payload;
  
 -    if ((ret = ff_alloc_packet(pkt, size)) < 0)
 +    if ((ret = ff_alloc_packet2(ctx, pkt, size)) < 0)
          return ret;
  
      p = pkt->data;
  
      /* Write the SEI as part of the first frame. */
      if (x4->sei_size > 0 && nnal > 0) {
 +        if (x4->sei_size > size) {
 +            av_log(ctx, AV_LOG_ERROR, "Error: nal buffer is too small\n");
 +            return -1;
 +        }
          memcpy(p, x4->sei, x4->sei_size);
          p += x4->sei_size;
          x4->sei_size = 0;
 +        av_freep(&x4->sei);
      }
  
      for (i = 0; i < nnal; i++){
      return 1;
  }
  
 +static int avfmt2_num_planes(int avfmt)
 +{
 +    switch (avfmt) {
 +    case PIX_FMT_YUV420P:
 +    case PIX_FMT_YUVJ420P:
 +    case PIX_FMT_YUV420P9:
 +    case PIX_FMT_YUV420P10:
 +    case PIX_FMT_YUV444P:
 +        return 3;
 +
 +    case PIX_FMT_BGR24:
 +    case PIX_FMT_RGB24:
 +        return 1;
 +
 +    default:
 +        return 3;
 +    }
 +}
 +
  static int X264_frame(AVCodecContext *ctx, AVPacket *pkt, const AVFrame *frame,
                        int *got_packet)
  {
      x4->pic.img.i_csp   = x4->params.i_csp;
      if (x264_bit_depth > 8)
          x4->pic.img.i_csp |= X264_CSP_HIGH_DEPTH;
 -    x4->pic.img.i_plane = 3;
 +    x4->pic.img.i_plane = avfmt2_num_planes(ctx->pix_fmt);
  
      if (frame) {
 -        for (i = 0; i < 3; i++) {
 +        for (i = 0; i < x4->pic.img.i_plane; i++) {
              x4->pic.img.plane[i]    = frame->data[i];
              x4->pic.img.i_stride[i] = frame->linesize[i];
          }
@@@ -233,20 -206,6 +233,20 @@@ static av_cold int X264_close(AVCodecCo
      return 0;
  }
  
 +#define OPT_STR(opt, param)                                                   \
 +    do {                                                                      \
 +        int ret;                                                              \
 +        if (param && (ret = x264_param_parse(&x4->params, opt, param)) < 0) { \
 +            if(ret == X264_PARAM_BAD_NAME)                                    \
 +                av_log(avctx, AV_LOG_ERROR,                                   \
 +                        "bad option '%s': '%s'\n", opt, param);               \
 +            else                                                              \
 +                av_log(avctx, AV_LOG_ERROR,                                   \
 +                        "bad value for '%s': '%s'\n", opt, param);            \
 +            return -1;                                                        \
 +        }                                                                     \
 +    } while (0)
 +
  static int convert_pix_fmt(enum PixelFormat pix_fmt)
  {
      switch (pix_fmt) {
      case PIX_FMT_YUV444P:
      case PIX_FMT_YUV444P9:
      case PIX_FMT_YUV444P10: return X264_CSP_I444;
 +#ifdef X264_CSP_BGR
 +    case PIX_FMT_BGR24:
 +        return X264_CSP_BGR;
 +
 +    case PIX_FMT_RGB24:
 +        return X264_CSP_RGB;
 +#endif
      };
      return 0;
  }
  static av_cold int X264_init(AVCodecContext *avctx)
  {
      X264Context *x4 = avctx->priv_data;
 +    int sw,sh;
  
      x264_param_default(&x4->params);
  
      x4->params.b_deblocking_filter         = avctx->flags & CODEC_FLAG_LOOP_FILTER;
  
 +    x4->params.rc.f_ip_factor             = 1 / fabs(avctx->i_quant_factor);
 +    x4->params.rc.f_pb_factor             = avctx->b_quant_factor;
 +    x4->params.analyse.i_chroma_qp_offset = avctx->chromaoffset;
      if (x4->preset || x4->tune)
          if (x264_param_default_preset(&x4->params, x4->preset, x4->tune) < 0) {
 +            int i;
              av_log(avctx, AV_LOG_ERROR, "Error setting preset/tune %s/%s.\n", x4->preset, x4->tune);
 +            av_log(avctx, AV_LOG_INFO, "Possible presets:");
 +            for (i = 0; x264_preset_names[i]; i++)
 +                av_log(avctx, AV_LOG_INFO, " %s", x264_preset_names[i]);
 +            av_log(avctx, AV_LOG_INFO, "\n");
 +            av_log(avctx, AV_LOG_INFO, "Possible tunes:");
 +            for (i = 0; x264_tune_names[i]; i++)
 +                av_log(avctx, AV_LOG_INFO, " %s", x264_tune_names[i]);
 +            av_log(avctx, AV_LOG_INFO, "\n");
              return AVERROR(EINVAL);
          }
  
      x4->params.i_log_level          = X264_LOG_DEBUG;
      x4->params.i_csp                = convert_pix_fmt(avctx->pix_fmt);
  
 +    OPT_STR("weightp", x4->wpredp);
 +
      if (avctx->bit_rate) {
          x4->params.rc.i_bitrate   = avctx->bit_rate / 1000;
          x4->params.rc.i_rc_method = X264_RC_ABR;
              (float)avctx->rc_initial_buffer_occupancy / avctx->rc_buffer_size;
      }
  
 -    x4->params.rc.f_ip_factor             = 1 / fabs(avctx->i_quant_factor);
 -    x4->params.rc.f_pb_factor             = avctx->b_quant_factor;
 -    x4->params.analyse.i_chroma_qp_offset = avctx->chromaoffset;
 +    OPT_STR("level", x4->level);
 +
 +    if(x4->x264opts){
 +        const char *p= x4->x264opts;
 +        while(p){
 +            char param[256]={0}, val[256]={0};
 +            if(sscanf(p, "%255[^:=]=%255[^:]", param, val) == 1){
 +                OPT_STR(param, "1");
 +            }else
 +                OPT_STR(param, val);
 +            p= strchr(p, ':');
 +            p+=!!p;
 +        }
 +    }
  
      if (avctx->me_method == ME_EPZS)
          x4->params.analyse.i_me_method = X264_ME_DIA;
  
      if (x4->slice_max_size >= 0)
          x4->params.i_slice_max_size =  x4->slice_max_size;
 +    else {
 +        /*
 +         * Allow x264 to be instructed through AVCodecContext about the maximum
 +         * size of the RTP payload. For example, this enables the production of
 +         * payload suitable for the H.264 RTP packetization-mode 0 i.e. single
 +         * NAL unit per RTP packet.
 +         */
 +        if (avctx->rtp_payload_size)
 +            x4->params.i_slice_max_size = avctx->rtp_payload_size;
 +    }
  
      if (x4->fastfirstpass)
          x264_param_apply_fastfirstpass(&x4->params);
  
 +    /* Allow specifying the x264 profile through AVCodecContext. */
 +    if (!x4->profile)
 +        switch (avctx->profile) {
 +        case FF_PROFILE_H264_BASELINE:
 +            x4->profile = av_strdup("baseline");
 +            break;
 +        case FF_PROFILE_H264_HIGH:
 +            x4->profile = av_strdup("high");
 +            break;
 +        case FF_PROFILE_H264_HIGH_10:
 +            x4->profile = av_strdup("high10");
 +            break;
 +        case FF_PROFILE_H264_HIGH_422:
 +            x4->profile = av_strdup("high422");
 +            break;
 +        case FF_PROFILE_H264_HIGH_444:
 +            x4->profile = av_strdup("high444");
 +            break;
 +        case FF_PROFILE_H264_MAIN:
 +            x4->profile = av_strdup("main");
 +            break;
 +        default:
 +            break;
 +        }
 +
      if (x4->nal_hrd >= 0)
          x4->params.i_nal_hrd = x4->nal_hrd;
  
      if (x4->profile)
          if (x264_param_apply_profile(&x4->params, x4->profile) < 0) {
 +            int i;
              av_log(avctx, AV_LOG_ERROR, "Error setting profile %s.\n", x4->profile);
 +            av_log(avctx, AV_LOG_INFO, "Possible profiles:");
 +            for (i = 0; x264_profile_names[i]; i++)
 +                av_log(avctx, AV_LOG_INFO, " %s", x264_profile_names[i]);
 +            av_log(avctx, AV_LOG_INFO, "\n");
              return AVERROR(EINVAL);
          }
  
      x4->params.i_width          = avctx->width;
      x4->params.i_height         = avctx->height;
 -    x4->params.vui.i_sar_width  = avctx->sample_aspect_ratio.num;
 -    x4->params.vui.i_sar_height = avctx->sample_aspect_ratio.den;
 +    av_reduce(&sw, &sh, avctx->sample_aspect_ratio.num, avctx->sample_aspect_ratio.den, 4096);
 +    x4->params.vui.i_sar_width  = sw;
 +    x4->params.vui.i_sar_height = sh;
      x4->params.i_fps_num = x4->params.i_timebase_den = avctx->time_base.den;
      x4->params.i_fps_den = x4->params.i_timebase_num = avctx->time_base.num;
  
  
      x4->params.b_interlaced   = avctx->flags & CODEC_FLAG_INTERLACED_DCT;
  
 -    x4->params.b_open_gop     = !(avctx->flags & CODEC_FLAG_CLOSED_GOP);
 +//    x4->params.b_open_gop     = !(avctx->flags & CODEC_FLAG_CLOSED_GOP);
  
      x4->params.i_slice_count  = avctx->slices;
  
@@@ -580,13 -465,6 +580,13 @@@ static const enum PixelFormat pix_fmts_
      PIX_FMT_YUV444P10,
      PIX_FMT_NONE
  };
 +static const enum PixelFormat pix_fmts_8bit_rgb[] = {
 +#ifdef X264_CSP_BGR
 +    PIX_FMT_BGR24,
 +    PIX_FMT_RGB24,
 +#endif
 +    PIX_FMT_NONE
 +};
  
  static av_cold void X264_init_static(AVCodec *codec)
  {
@@@ -605,10 -483,6 +605,10 @@@ static const AVOption options[] = 
      { "tune",          "Tune the encoding params (cf. x264 --fullhelp)",  OFFSET(tune),          AV_OPT_TYPE_STRING, { 0 }, 0, 0, VE},
      { "profile",       "Set profile restrictions (cf. x264 --fullhelp) ", OFFSET(profile),       AV_OPT_TYPE_STRING, { 0 }, 0, 0, VE},
      { "fastfirstpass", "Use fast settings when encoding first pass",      OFFSET(fastfirstpass), AV_OPT_TYPE_INT,    { .i64 = 1 }, 0, 1, VE},
 +    {"level", "Specify level (as defined by Annex A)", OFFSET(level), AV_OPT_TYPE_STRING, {.str=NULL}, 0, 0, VE},
 +    {"passlogfile", "Filename for 2 pass stats", OFFSET(stats), AV_OPT_TYPE_STRING, {.str=NULL}, 0, 0, VE},
 +    {"wpredp", "Weighted prediction for P-frames", OFFSET(wpredp), AV_OPT_TYPE_STRING, {.str=NULL}, 0, 0, VE},
 +    {"x264opts", "x264 options", OFFSET(x264opts), AV_OPT_TYPE_STRING, {.str=NULL}, 0, 0, VE},
      { "crf",           "Select the quality for constant quality mode",    OFFSET(crf),           AV_OPT_TYPE_FLOAT,  {.dbl = -1 }, -1, FLT_MAX, VE },
      { "crf_max",       "In CRF mode, prevents VBV from lowering quality beyond this point.",OFFSET(crf_max), AV_OPT_TYPE_FLOAT, {.dbl = -1 }, -1, FLT_MAX, VE },
      { "qp",            "Constant quantization parameter rate control method",OFFSET(cqp),        AV_OPT_TYPE_INT,    { .i64 = -1 }, -1, INT_MAX, VE },
@@@ -663,24 -537,15 +663,24 @@@ static const AVClass class = 
      .version    = LIBAVUTIL_VERSION_INT,
  };
  
 +static const AVClass rgbclass = {
 +    .class_name = "libx264rgb",
 +    .item_name  = av_default_item_name,
 +    .option     = options,
 +    .version    = LIBAVUTIL_VERSION_INT,
 +};
 +
  static const AVCodecDefault x264_defaults[] = {
      { "b",                "0" },
      { "bf",               "-1" },
 +    { "flags2",           "0" },
      { "g",                "-1" },
      { "qmin",             "-1" },
      { "qmax",             "-1" },
      { "qdiff",            "-1" },
      { "qblur",            "-1" },
      { "qcomp",            "-1" },
 +//     { "rc_lookahead",     "-1" },
      { "refs",             "-1" },
      { "sc_threshold",     "-1" },
      { "trellis",          "-1" },
@@@ -711,18 -576,3 +711,18 @@@ AVCodec ff_libx264_encoder = 
      .defaults         = x264_defaults,
      .init_static_data = X264_init_static,
  };
 +
 +AVCodec ff_libx264rgb_encoder = {
 +    .name           = "libx264rgb",
 +    .type           = AVMEDIA_TYPE_VIDEO,
 +    .id             = AV_CODEC_ID_H264,
 +    .priv_data_size = sizeof(X264Context),
 +    .init           = X264_init,
 +    .encode2        = X264_frame,
 +    .close          = X264_close,
 +    .capabilities   = CODEC_CAP_DELAY,
 +    .long_name      = NULL_IF_CONFIG_SMALL("libx264 H.264 / AVC / MPEG-4 AVC / MPEG-4 part 10 RGB"),
 +    .priv_class     = &rgbclass,
 +    .defaults       = x264_defaults,
 +    .pix_fmts       = pix_fmts_8bit_rgb,
 +};
diff --combined libavcodec/motion_est.c
@@@ -5,20 -5,20 +5,20 @@@
   *
   * new motion estimation (X1/EPZS) by Michael Niedermayer <michaelni@gmx.at>
   *
 - * This file is part of Libav.
 + * This file is part of FFmpeg.
   *
 - * Libav is free software; you can redistribute it and/or
 + * FFmpeg is free software; you can redistribute it and/or
   * modify it under the terms of the GNU Lesser General Public
   * License as published by the Free Software Foundation; either
   * version 2.1 of the License, or (at your option) any later version.
   *
 - * Libav is distributed in the hope that it will be useful,
 + * FFmpeg is distributed in the hope that it will be useful,
   * but WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   * Lesser General Public License for more details.
   *
   * You should have received a copy of the GNU Lesser General Public
 - * License along with Libav; if not, write to the Free Software
 + * License along with FFmpeg; if not, write to the Free Software
   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
   */
  
@@@ -525,8 -525,8 +525,8 @@@ static inline void get_limits(MpegEncCo
      if (s->unrestricted_mv) {
          c->xmin = - x - 16;
          c->ymin = - y - 16;
 -        c->xmax = - x + s->mb_width *16;
 -        c->ymax = - y + s->mb_height*16;
 +        c->xmax = - x + s->width;
 +        c->ymax = - y + s->height;
      } else if (s->out_format == FMT_H261){
          // Search range of H261 is different from other codec standards
          c->xmin = (x > 15) ? - 15 : 0;
@@@ -565,11 -565,10 +565,11 @@@ static inline int h263_mv4_search(MpegE
      const int h=8;
      int block;
      int P[10][2];
 -    int dmin_sum=0, mx4_sum=0, my4_sum=0;
 +    int dmin_sum=0, mx4_sum=0, my4_sum=0, i;
      int same=1;
      const int stride= c->stride;
      uint8_t *mv_penalty= c->current_mv_penalty;
 +    int saftey_cliping= s->unrestricted_mv && (s->width&15) && (s->height&15);
  
      init_mv4_ref(c);
  
          const int mot_stride = s->b8_stride;
          const int mot_xy = s->block_index[block];
  
 +        if(saftey_cliping){
 +            c->xmax = - 16*s->mb_x + s->width  - 8*(block &1);
 +            c->ymax = - 16*s->mb_y + s->height - 8*(block>>1);
 +        }
 +
          P_LEFT[0] = s->current_picture.f.motion_val[0][mot_xy - 1][0];
          P_LEFT[1] = s->current_picture.f.motion_val[0][mot_xy - 1][1];
  
          }
          P_MV1[0]= mx;
          P_MV1[1]= my;
 +        if(saftey_cliping)
 +            for(i=0; i<10; i++){
 +                if(P[i][0] > (c->xmax<<shift)) P[i][0]= (c->xmax<<shift);
 +                if(P[i][1] > (c->ymax<<shift)) P[i][1]= (c->ymax<<shift);
 +            }
  
          dmin4 = epzs_motion_search4(s, &mx4, &my4, P, block, block, s->p_mv_table, (1<<16)>>shift);
  
@@@ -1151,7 -1140,7 +1151,7 @@@ void ff_estimate_p_frame_motion(MpegEnc
  
          dmin= c->sub_motion_search(s, &mx, &my, dmin, 0, 0, 0, 16);
          if(c->avctx->me_sub_cmp != c->avctx->mb_cmp && !c->skip)
-             dmin= ff_get_mb_score(s, mx, my, 0, 0, 0, 16, 1);
+             dmin= get_mb_score(s, mx, my, 0, 0, 0, 16, 1);
  
          if((s->flags&CODEC_FLAG_4MV)
             && !c->skip && varc>50<<8 && vard>10<<8){
@@@ -1323,7 -1312,7 +1323,7 @@@ static int ff_estimate_motion_b(MpegEnc
      dmin= c->sub_motion_search(s, &mx, &my, dmin, 0, ref_index, 0, 16);
  
      if(c->avctx->me_sub_cmp != c->avctx->mb_cmp && !c->skip)
-         dmin= ff_get_mb_score(s, mx, my, 0, ref_index, 0, 16, 1);
+         dmin= get_mb_score(s, mx, my, 0, ref_index, 0, 16, 1);
  
  //printf("%d %d %d %d//", s->mb_x, s->mb_y, mx, my);
  //    s->mb_type[mb_y*s->mb_width + mb_x]= mb_type;
@@@ -1635,7 -1624,7 +1635,7 @@@ static inline int direct_search(MpegEnc
          dmin = hpel_motion_search(s, &mx, &my, dmin, 0, 0, 0, 16);
  
      if(c->avctx->me_sub_cmp != c->avctx->mb_cmp && !c->skip)
-         dmin= ff_get_mb_score(s, mx, my, 0, 0, 0, 16, 1);
+         dmin= get_mb_score(s, mx, my, 0, 0, 0, 16, 1);
  
      get_limits(s, 16*mb_x, 16*mb_y); //restore c->?min/max, maybe not needed
  
@@@ -1867,12 -1856,12 +1867,12 @@@ void ff_fix_long_p_mvs(MpegEncContext 
      MotionEstContext * const c= &s->me;
      const int f_code= s->f_code;
      int y, range;
 -    assert(s->pict_type==AV_PICTURE_TYPE_P);
 +    av_assert0(s->pict_type==AV_PICTURE_TYPE_P);
  
      range = (((s->out_format == FMT_MPEG1 || s->msmpeg4_version) ? 8 : 16) << f_code);
  
 -    assert(range <= 16 || !s->msmpeg4_version);
 -    assert(range <=256 || !(s->codec_id == AV_CODEC_ID_MPEG2VIDEO && s->avctx->strict_std_compliance >= FF_COMPLIANCE_NORMAL));
 +    av_assert0(range <= 16 || !s->msmpeg4_version);
 +    av_assert0(range <=256 || !(s->codec_id == AV_CODEC_ID_MPEG2VIDEO && s->avctx->strict_std_compliance >= FF_COMPLIANCE_NORMAL));
  
      if(c->avctx->me_range && range > c->avctx->me_range) range= c->avctx->me_range;
  
@@@ -2,20 -2,20 +2,20 @@@
   * Motion estimation
   * Copyright (c) 2002-2004 Michael Niedermayer
   *
 - * This file is part of Libav.
 + * This file is part of FFmpeg.
   *
 - * Libav is free software; you can redistribute it and/or
 + * FFmpeg is free software; you can redistribute it and/or
   * modify it under the terms of the GNU Lesser General Public
   * License as published by the Free Software Foundation; either
   * version 2.1 of the License, or (at your option) any later version.
   *
 - * Libav is distributed in the hope that it will be useful,
 + * FFmpeg is distributed in the hope that it will be useful,
   * but WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   * Lesser General Public License for more details.
   *
   * You should have received a copy of the GNU Lesser General Public
 - * License along with Libav; if not, write to the Free Software
 + * License along with FFmpeg; if not, write to the Free Software
   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
   */
  
@@@ -89,18 -89,19 +89,18 @@@ static int hpel_motion_search(MpegEncCo
          const int b= score_map[(index+(1<<ME_MAP_SHIFT))&(ME_MAP_SIZE-1)]
                       + (mv_penalty[bx   - pred_x] + mv_penalty[by+2 - pred_y])*c->penalty_factor;
  
 +#if 1
          unsigned key;
          unsigned map_generation= c->map_generation;
 -#ifndef NDEBUG
 -        uint32_t *map= c->map;
 -#endif
          key= ((my-1)<<ME_MAP_MV_BITS) + (mx) + map_generation;
 -        assert(map[(index-(1<<ME_MAP_SHIFT))&(ME_MAP_SIZE-1)] == key);
 +        av_assert2(c->map[(index-(1<<ME_MAP_SHIFT))&(ME_MAP_SIZE-1)] == key);
          key= ((my+1)<<ME_MAP_MV_BITS) + (mx) + map_generation;
 -        assert(map[(index+(1<<ME_MAP_SHIFT))&(ME_MAP_SIZE-1)] == key);
 +        av_assert2(c->map[(index+(1<<ME_MAP_SHIFT))&(ME_MAP_SIZE-1)] == key);
          key= ((my)<<ME_MAP_MV_BITS) + (mx+1) + map_generation;
 -        assert(map[(index+1)&(ME_MAP_SIZE-1)] == key);
 +        av_assert2(c->map[(index+1)&(ME_MAP_SIZE-1)] == key);
          key= ((my)<<ME_MAP_MV_BITS) + (mx-1) + map_generation;
 -        assert(map[(index-1)&(ME_MAP_SIZE-1)] == key);
 +        av_assert2(c->map[(index-1)&(ME_MAP_SIZE-1)] == key);
 +#endif
          if(t<=b){
              CHECK_HALF_MV(0, 1, mx  ,my-1)
              if(l<=r){
              }
              CHECK_HALF_MV(0, 1, mx  , my)
          }
 -        assert(bx >= xmin*2 && bx <= xmax*2 && by >= ymin*2 && by <= ymax*2);
 +        av_assert2(bx >= xmin*2 && bx <= xmax*2 && by >= ymin*2 && by <= ymax*2);
      }
  
      *mx_ptr = bx;
@@@ -159,8 -160,9 +159,9 @@@ static int no_sub_motion_search(MpegEnc
      return dmin;
  }
  
- av_extern_inline int ff_get_mb_score(MpegEncContext * s, int mx, int my, int src_index,
-                                int ref_index, int size, int h, int add_rate)
+ static inline int get_mb_score(MpegEncContext *s, int mx, int my,
+                                int src_index, int ref_index, int size,
+                                int h, int add_rate)
  {
  //    const int check_luma= s->dsp.me_sub_cmp != s->dsp.mb_cmp;
      MotionEstContext * const c= &s->me;
      cmp_sub= s->dsp.mb_cmp[size];
      chroma_cmp_sub= s->dsp.mb_cmp[size+1];
  
 -//    assert(!c->skip);
 -//    assert(c->avctx->me_sub_cmp != c->avctx->mb_cmp);
 -
      d= cmp(s, mx>>(qpel+1), my>>(qpel+1), mx&mask, my&mask, size, h, ref_index, src_index, cmp_sub, chroma_cmp_sub, flags);
      //FIXME check cbp before adding penalty for (0,0) vector
      if(add_rate && (mx || my || size>0))
      return d;
  }
  
+ int ff_get_mb_score(MpegEncContext *s, int mx, int my, int src_index,
+                     int ref_index, int size, int h, int add_rate)
+ {
+     return get_mb_score(s, mx, my, src_index, ref_index, size, h, add_rate);
+ }
  #define CHECK_QUARTER_MV(dx, dy, x, y)\
  {\
      const int hx= 4*(x)+(dx);\
@@@ -298,11 -309,11 +305,11 @@@ static int qpel_motion_search(MpegEncCo
  
              cxy= 2*tl + (cx + cy)/4 - (cx2 + cy2) - 2*c;
  
 -            assert(16*cx2 + 4*cx + 32*c == 32*r);
 -            assert(16*cx2 - 4*cx + 32*c == 32*l);
 -            assert(16*cy2 + 4*cy + 32*c == 32*b);
 -            assert(16*cy2 - 4*cy + 32*c == 32*t);
 -            assert(16*cxy + 16*cy2 + 16*cx2 - 4*cy - 4*cx + 32*c == 32*tl);
 +            av_assert2(16*cx2 + 4*cx + 32*c == 32*r);
 +            av_assert2(16*cx2 - 4*cx + 32*c == 32*l);
 +            av_assert2(16*cy2 + 4*cy + 32*c == 32*b);
 +            av_assert2(16*cy2 - 4*cy + 32*c == 32*t);
 +            av_assert2(16*cxy + 16*cy2 + 16*cx2 - 4*cy - 4*cx + 32*c == 32*tl);
  
              for(ny= -3; ny <= 3; ny++){
                  for(nx= -3; nx <= 3; nx++){
              CHECK_QUARTER_MV(nx&3, ny&3, nx>>2, ny>>2)
          }
  
 -        assert(bx >= xmin*4 && bx <= xmax*4 && by >= ymin*4 && by <= ymax*4);
 +        av_assert2(bx >= xmin*4 && bx <= xmax*4 && by >= ymin*4 && by <= ymax*4);
  
          *mx_ptr = bx;
          *my_ptr = by;
  {\
      const unsigned key = ((y)<<ME_MAP_MV_BITS) + (x) + map_generation;\
      const int index= (((y)<<ME_MAP_SHIFT) + (x))&(ME_MAP_SIZE-1);\
 -    assert((x) >= xmin);\
 -    assert((x) <= xmax);\
 -    assert((y) >= ymin);\
 -    assert((y) <= ymax);\
 +    av_assert2((x) >= xmin);\
 +    av_assert2((x) <= xmax);\
 +    av_assert2((y) >= ymin);\
 +    av_assert2((y) <= ymax);\
  /*printf("check_mv %d %d\n", x, y);*/\
      if(map[index]!=key){\
          d= cmp(s, x, y, 0, 0, size, h, ref_index, src_index, cmpf, chroma_cmpf, flags);\
@@@ -884,7 -895,7 +891,7 @@@ static av_always_inline int epzs_motion
  
      map_generation= update_map_generation(c);
  
 -    assert(cmpf);
 +    av_assert2(cmpf);
      dmin= cmp(s, 0, 0, 0, 0, size, h, ref_index, src_index, cmpf, chroma_cmpf, flags);
      map[0]= map_generation;
      score_map[0]= dmin;
  }
  
  //this function is dedicated to the braindamaged gcc
- av_extern_inline int ff_epzs_motion_search(MpegEncContext * s, int *mx_ptr, int *my_ptr,
-                              int P[10][2], int src_index, int ref_index, int16_t (*last_mv)[2],
-                              int ref_mv_scale, int size, int h)
+ int ff_epzs_motion_search(MpegEncContext *s, int *mx_ptr, int *my_ptr,
+                           int P[10][2], int src_index, int ref_index,
+                           int16_t (*last_mv)[2], int ref_mv_scale,
+                           int size, int h)
  {
      MotionEstContext * const c= &s->me;
  //FIXME convert other functions in the same way if faster
@@@ -1,21 -1,21 +1,21 @@@
  /*
   * Matroska file demuxer
 - * Copyright (c) 2003-2008 The Libav Project
 + * Copyright (c) 2003-2008 The FFmpeg Project
   *
 - * 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
   */
  
@@@ -113,8 -113,7 +113,8 @@@ typedef struct 
      uint64_t display_height;
      uint64_t pixel_width;
      uint64_t pixel_height;
 -    uint64_t fourcc;
 +    EbmlBin color_space;
 +    uint64_t stereo_mode;
  } MatroskaTrackVideo;
  
  typedef struct {
  } MatroskaTrackAudio;
  
  typedef struct {
 +    uint64_t uid;
 +    uint64_t type;
 +} MatroskaTrackPlane;
 +
 +typedef struct {
 +    EbmlList combine_planes;
 +} MatroskaTrackOperation;
 +
 +typedef struct {
      uint64_t num;
      uint64_t uid;
      uint64_t type;
      uint64_t flag_forced;
      MatroskaTrackVideo video;
      MatroskaTrackAudio audio;
 +    MatroskaTrackOperation operation;
      EbmlList encodings;
  
      AVStream *stream;
@@@ -241,7 -230,6 +241,7 @@@ typedef struct 
      uint64_t time_scale;
      double   duration;
      char    *title;
 +    EbmlBin date_utc;
      EbmlList tracks;
      EbmlList attachments;
      EbmlList chapters;
@@@ -303,7 -291,7 +303,7 @@@ static EbmlSyntax matroska_info[] = 
      { MATROSKA_ID_TITLE,              EBML_UTF8,  0, offsetof(MatroskaDemuxContext,title) },
      { MATROSKA_ID_WRITINGAPP,         EBML_NONE },
      { MATROSKA_ID_MUXINGAPP,          EBML_NONE },
 -    { MATROSKA_ID_DATEUTC,            EBML_NONE },
 +    { MATROSKA_ID_DATEUTC,            EBML_BIN,  0, offsetof(MatroskaDemuxContext,date_utc) },
      { MATROSKA_ID_SEGMENTUID,         EBML_NONE },
      { 0 }
  };
@@@ -314,14 -302,14 +314,14 @@@ static EbmlSyntax matroska_track_video[
      { MATROSKA_ID_VIDEODISPLAYHEIGHT, EBML_UINT, 0, offsetof(MatroskaTrackVideo,display_height) },
      { MATROSKA_ID_VIDEOPIXELWIDTH,    EBML_UINT, 0, offsetof(MatroskaTrackVideo,pixel_width) },
      { MATROSKA_ID_VIDEOPIXELHEIGHT,   EBML_UINT, 0, offsetof(MatroskaTrackVideo,pixel_height) },
 -    { MATROSKA_ID_VIDEOCOLORSPACE,    EBML_UINT, 0, offsetof(MatroskaTrackVideo,fourcc) },
 +    { MATROSKA_ID_VIDEOCOLORSPACE,    EBML_BIN,  0, offsetof(MatroskaTrackVideo,color_space) },
 +    { MATROSKA_ID_VIDEOSTEREOMODE,    EBML_UINT, 0, offsetof(MatroskaTrackVideo,stereo_mode) },
      { MATROSKA_ID_VIDEOPIXELCROPB,    EBML_NONE },
      { MATROSKA_ID_VIDEOPIXELCROPT,    EBML_NONE },
      { MATROSKA_ID_VIDEOPIXELCROPL,    EBML_NONE },
      { MATROSKA_ID_VIDEOPIXELCROPR,    EBML_NONE },
      { MATROSKA_ID_VIDEODISPLAYUNIT,   EBML_NONE },
      { MATROSKA_ID_VIDEOFLAGINTERLACED,EBML_NONE },
 -    { MATROSKA_ID_VIDEOSTEREOMODE,    EBML_NONE },
      { MATROSKA_ID_VIDEOASPECTRATIO,   EBML_NONE },
      { 0 }
  };
@@@ -353,22 -341,6 +353,22 @@@ static EbmlSyntax matroska_track_encodi
      { 0 }
  };
  
 +static EbmlSyntax matroska_track_plane[] = {
 +    { MATROSKA_ID_TRACKPLANEUID,  EBML_UINT, 0, offsetof(MatroskaTrackPlane,uid) },
 +    { MATROSKA_ID_TRACKPLANETYPE, EBML_UINT, 0, offsetof(MatroskaTrackPlane,type) },
 +    { 0 }
 +};
 +
 +static EbmlSyntax matroska_track_combine_planes[] = {
 +    { MATROSKA_ID_TRACKPLANE, EBML_NEST, sizeof(MatroskaTrackPlane), offsetof(MatroskaTrackOperation,combine_planes), {.n=matroska_track_plane} },
 +    { 0 }
 +};
 +
 +static EbmlSyntax matroska_track_operation[] = {
 +    { MATROSKA_ID_TRACKCOMBINEPLANES, EBML_NEST, 0, 0, {.n=matroska_track_combine_planes} },
 +    { 0 }
 +};
 +
  static EbmlSyntax matroska_track[] = {
      { MATROSKA_ID_TRACKNUMBER,          EBML_UINT, 0, offsetof(MatroskaTrack,num) },
      { MATROSKA_ID_TRACKNAME,            EBML_UTF8, 0, offsetof(MatroskaTrack,name) },
      { MATROSKA_ID_TRACKFLAGFORCED,      EBML_UINT, 0, offsetof(MatroskaTrack,flag_forced), {.u=0} },
      { MATROSKA_ID_TRACKVIDEO,           EBML_NEST, 0, offsetof(MatroskaTrack,video), {.n=matroska_track_video} },
      { MATROSKA_ID_TRACKAUDIO,           EBML_NEST, 0, offsetof(MatroskaTrack,audio), {.n=matroska_track_audio} },
 +    { MATROSKA_ID_TRACKOPERATION,       EBML_NEST, 0, offsetof(MatroskaTrack,operation), {.n=matroska_track_operation} },
      { MATROSKA_ID_TRACKCONTENTENCODINGS,EBML_NEST, 0, 0, {.n=matroska_track_encodings} },
      { MATROSKA_ID_TRACKFLAGENABLED,     EBML_NONE },
      { MATROSKA_ID_TRACKFLAGLACING,      EBML_NONE },
@@@ -527,7 -498,7 +527,7 @@@ static EbmlSyntax matroska_segments[] 
  static EbmlSyntax matroska_blockgroup[] = {
      { MATROSKA_ID_BLOCK,          EBML_BIN,  0, offsetof(MatroskaBlock,bin) },
      { MATROSKA_ID_SIMPLEBLOCK,    EBML_BIN,  0, offsetof(MatroskaBlock,bin) },
 -    { MATROSKA_ID_BLOCKDURATION,  EBML_UINT, 0, offsetof(MatroskaBlock,duration), {.u=AV_NOPTS_VALUE} },
 +    { MATROSKA_ID_BLOCKDURATION,  EBML_UINT, 0, offsetof(MatroskaBlock,duration) },
      { MATROSKA_ID_BLOCKREFERENCE, EBML_UINT, 0, offsetof(MatroskaBlock,reference) },
      { 1,                          EBML_UINT, 0, offsetof(MatroskaBlock,non_simple), {.u=1} },
      { 0 }
@@@ -585,36 -556,6 +585,36 @@@ static EbmlSyntax matroska_clusters_inc
  
  static const char *const matroska_doctypes[] = { "matroska", "webm" };
  
 +static int matroska_resync(MatroskaDemuxContext *matroska, int64_t last_pos)
 +{
 +    AVIOContext *pb = matroska->ctx->pb;
 +    uint32_t id;
 +    matroska->current_id = 0;
 +    matroska->num_levels = 0;
 +
 +    // seek to next position to resync from
 +    if (avio_seek(pb, last_pos + 1, SEEK_SET) < 0 || avio_tell(pb) <= last_pos)
 +        goto eof;
 +
 +    id = avio_rb32(pb);
 +
 +    // try to find a toplevel element
 +    while (!url_feof(pb)) {
 +        if (id == MATROSKA_ID_INFO || id == MATROSKA_ID_TRACKS ||
 +            id == MATROSKA_ID_CUES || id == MATROSKA_ID_TAGS ||
 +            id == MATROSKA_ID_SEEKHEAD || id == MATROSKA_ID_ATTACHMENTS ||
 +            id == MATROSKA_ID_CLUSTER || id == MATROSKA_ID_CHAPTERS)
 +        {
 +            matroska->current_id = id;
 +            return 0;
 +        }
 +        id = (id << 8) | avio_r8(pb);
 +    }
 +eof:
 +    matroska->done = 1;
 +    return AVERROR_EOF;
 +}
 +
  /*
   * Return: Whether we reached the end of a level in the hierarchy or not.
   */
@@@ -652,7 -593,7 +652,7 @@@ static int ebml_read_num(MatroskaDemuxC
       * use it safely here to catch EOS. */
      if (!(total = avio_r8(pb))) {
          /* we might encounter EOS here */
 -        if (!pb->eof_reached) {
 +        if (!url_feof(pb)) {
              int64_t pos = avio_tell(pb);
              av_log(matroska->ctx, AV_LOG_ERROR,
                     "Read error at pos. %"PRIu64" (0x%"PRIx64")\n",
@@@ -946,10 -887,7 +946,10 @@@ static int ebml_parse_elem(MatroskaDemu
                       return ebml_parse_nest(matroska, syntax->def.n, data);
      case EBML_PASS:  return ebml_parse_id(matroska, syntax->def.n, id, data);
      case EBML_STOP:  return 1;
 -    default:         return avio_skip(pb,length)<0 ? AVERROR(EIO) : 0;
 +    default:
 +        if(ffio_limit(pb, length) != length)
 +            return AVERROR(EIO);
 +        return avio_skip(pb,length)<0 ? AVERROR(EIO) : 0;
      }
      if (res == AVERROR_INVALIDDATA)
          av_log(matroska->ctx, AV_LOG_ERROR, "Invalid element\n");
@@@ -1053,7 -991,7 +1053,7 @@@ static int matroska_decode_buffer(uint8
      int result = 0;
      int olen;
  
 -    if (pkt_size >= 10000000)
 +    if (pkt_size >= 10000000U)
          return AVERROR_INVALIDDATA;
  
      switch (encodings[0].compression.algo) {
          int header_size = encodings[0].compression.settings.size;
          uint8_t *header = encodings[0].compression.settings.data;
  
 +        if (header_size && !header) {
 +            av_log(0, AV_LOG_ERROR, "Compression size but no data in headerstrip\n");
 +            return -1;
 +        }
 +
          if (!header_size)
              return 0;
  
              pkt_data = newpktdata;
              zstream.avail_out = pkt_size - zstream.total_out;
              zstream.next_out = pkt_data + zstream.total_out;
 -            result = inflate(&zstream, Z_NO_FLUSH);
 +            if (pkt_data) {
 +                result = inflate(&zstream, Z_NO_FLUSH);
 +            } else
 +                result = Z_MEM_ERROR;
          } while (result==Z_OK && pkt_size<10000000);
          pkt_size = zstream.total_out;
          inflateEnd(&zstream);
              pkt_data = newpktdata;
              bzstream.avail_out = pkt_size - bzstream.total_out_lo32;
              bzstream.next_out = pkt_data + bzstream.total_out_lo32;
 -            result = BZ2_bzDecompress(&bzstream);
 +            if (pkt_data) {
 +                result = BZ2_bzDecompress(&bzstream);
 +            } else
 +                result = BZ_MEM_ERROR;
          } while (result==BZ_OK && pkt_size<10000000);
          pkt_size = bzstream.total_out_lo32;
          BZ2_bzDecompressEnd(&bzstream);
@@@ -1181,8 -1108,7 +1181,8 @@@ static void matroska_fix_ass_packet(Mat
      char *line, *layer, *ptr = pkt->data, *end = ptr+pkt->size;
      for (; *ptr!=',' && ptr<end-1; ptr++);
      if (*ptr == ',')
 -        layer = ++ptr;
 +        ptr++;
 +    layer = ptr;
      for (; *ptr!=',' && ptr<end-1; ptr++);
      if (*ptr == ',') {
          int64_t end_pts = pkt->pts + display_duration;
  
  static int matroska_merge_packets(AVPacket *out, AVPacket *in)
  {
 -    void *newdata = av_realloc(out->data, out->size+in->size);
 -    if (!newdata)
 -        return AVERROR(ENOMEM);
 -    out->data = newdata;
 -    memcpy(out->data+out->size, in->data, in->size);
 -    out->size += in->size;
 +    int ret = av_grow_packet(out, in->size);
 +    if (ret < 0)
 +        return ret;
 +    memcpy(out->data + out->size - in->size, in->data, in->size);
      av_destruct_packet(in);
      av_free(in);
      return 0;
@@@ -1226,7 -1154,7 +1226,7 @@@ static void matroska_convert_tag(AVForm
      int i;
  
      for (i=0; i < list->nb_elem; i++) {
 -        const char *lang = strcmp(tags[i].lang, "und") ? tags[i].lang : NULL;
 +        const char *lang= (tags[i].lang && strcmp(tags[i].lang, "und")) ? tags[i].lang : NULL;
  
          if (!tags[i].name) {
              av_log(s, AV_LOG_WARNING, "Skipping invalid tag with no TagName.\n");
@@@ -1357,20 -1285,26 +1357,20 @@@ static void matroska_execute_seekhead(M
              continue;
          }
  
 -        if (matroska_parse_seekhead_entry(matroska, i) < 0)
 +        if (matroska_parse_seekhead_entry(matroska, i) < 0) {
 +            // mark index as broken
 +            matroska->cues_parsing_deferred = -1;
              break;
 +        }
      }
  }
  
 -static void matroska_parse_cues(MatroskaDemuxContext *matroska) {
 -    EbmlList *seekhead_list = &matroska->seekhead;
 -    MatroskaSeekhead *seekhead = seekhead_list->elem;
 +static void matroska_add_index_entries(MatroskaDemuxContext *matroska) {
      EbmlList *index_list;
      MatroskaIndex *index;
      int index_scale = 1;
      int i, j;
  
 -    for (i = 0; i < seekhead_list->nb_elem; i++)
 -        if (seekhead[i].id == MATROSKA_ID_CUES)
 -            break;
 -    assert(i <= seekhead_list->nb_elem);
 -
 -    matroska_parse_seekhead_entry(matroska, i);
 -
      index_list = &matroska->index;
      index = index_list->elem;
      if (index_list->nb_elem
      }
  }
  
 +static void matroska_parse_cues(MatroskaDemuxContext *matroska) {
 +    EbmlList *seekhead_list = &matroska->seekhead;
 +    MatroskaSeekhead *seekhead = seekhead_list->elem;
 +    int i;
 +
 +    for (i = 0; i < seekhead_list->nb_elem; i++)
 +        if (seekhead[i].id == MATROSKA_ID_CUES)
 +            break;
 +    assert(i <= seekhead_list->nb_elem);
 +
 +    if (matroska_parse_seekhead_entry(matroska, i) < 0)
 +       matroska->cues_parsing_deferred = -1;
 +    matroska_add_index_entries(matroska);
 +}
 +
  static int matroska_aac_profile(char *codec_id)
  {
      static const char * const aac_profiles[] = { "MAIN", "LC", "SSR" };
@@@ -1428,17 -1347,6 +1428,17 @@@ static int matroska_aac_sri(int sampler
      return sri;
  }
  
 +static void matroska_metadata_creation_time(AVDictionary **metadata, int64_t date_utc)
 +{
 +    char buffer[32];
 +    /* Convert to seconds and adjust by number of seconds between 2001-01-01 and Epoch */
 +    time_t creation_time = date_utc / 1000000000 + 978307200;
 +    struct tm *ptm = gmtime(&creation_time);
 +    if (!ptm) return;
 +    strftime(buffer, sizeof(buffer), "%Y-%m-%d %H:%M:%S", ptm);
 +    av_dict_set(metadata, "creation_time", buffer, 0);
 +}
 +
  static int matroska_read_header(AVFormatContext *s)
  {
      MatroskaDemuxContext *matroska = s->priv_data;
      MatroskaChapter *chapters;
      MatroskaTrack *tracks;
      uint64_t max_start = 0;
 +    int64_t pos;
      Ebml ebml = { 0 };
      AVStream *st;
 -    int i, j, res;
 +    int i, j, k, res;
  
      matroska->ctx = s;
  
      /* First read the EBML header. */
      if (ebml_parse(matroska, ebml_syntax, &ebml)
          || ebml.version > EBML_VERSION       || ebml.max_size > sizeof(uint64_t)
 -        || ebml.id_length > sizeof(uint32_t) || ebml.doctype_version > 2) {
 +        || ebml.id_length > sizeof(uint32_t) || ebml.doctype_version > 3 || !ebml.doctype) {
          av_log(matroska->ctx, AV_LOG_ERROR,
                 "EBML header using unsupported features\n"
                 "(EBML version %"PRIu64", doctype %s, doc version %"PRIu64")\n",
                 ebml.version, ebml.doctype, ebml.doctype_version);
          ebml_free(ebml_syntax, &ebml);
          return AVERROR_PATCHWELCOME;
 +    } else if (ebml.doctype_version == 3) {
 +        av_log(matroska->ctx, AV_LOG_WARNING,
 +               "EBML header using unsupported features\n"
 +               "(EBML version %"PRIu64", doctype %s, doc version %"PRIu64")\n",
 +               ebml.version, ebml.doctype, ebml.doctype_version);
      }
      for (i = 0; i < FF_ARRAY_ELEMS(matroska_doctypes); i++)
          if (!strcmp(ebml.doctype, matroska_doctypes[i]))
      ebml_free(ebml_syntax, &ebml);
  
      /* The next thing is a segment. */
 -    if ((res = ebml_parse(matroska, matroska_segments, matroska)) < 0)
 -        return res;
 +    pos = avio_tell(matroska->ctx->pb);
 +    res = ebml_parse(matroska, matroska_segments, matroska);
 +    // try resyncing until we find a EBML_STOP type element.
 +    while (res != 1) {
 +        res = matroska_resync(matroska, pos);
 +        if (res < 0)
 +            return res;
 +        pos = avio_tell(matroska->ctx->pb);
 +        res = ebml_parse(matroska, matroska_segment, matroska);
 +    }
      matroska_execute_seekhead(matroska);
  
      if (!matroska->time_scale)
                                    * 1000 / AV_TIME_BASE;
      av_dict_set(&s->metadata, "title", matroska->title, 0);
  
 +    if (matroska->date_utc.size == 8)
 +        matroska_metadata_creation_time(&s->metadata, AV_RB64(matroska->date_utc.data));
 +
      tracks = matroska->tracks.elem;
      for (i=0; i < matroska->tracks.nb_elem; i++) {
          MatroskaTrack *track = &tracks[i];
          enum AVCodecID codec_id = AV_CODEC_ID_NONE;
 -        EbmlList *encodings_list = &tracks->encodings;
 +        EbmlList *encodings_list = &track->encodings;
          MatroskaTrackEncoding *encodings = encodings_list->elem;
          uint8_t *extradata = NULL;
          int extradata_size = 0;
          int extradata_offset = 0;
 +        uint32_t fourcc = 0;
          AVIOContext b;
  
          /* Apply some sanity checks. */
                  track->video.display_width = track->video.pixel_width;
              if (!track->video.display_height)
                  track->video.display_height = track->video.pixel_height;
 +            if (track->video.color_space.size == 4)
 +                fourcc = AV_RL32(track->video.color_space.data);
          } else if (track->type == MATROSKA_TRACK_TYPE_AUDIO) {
              if (!track->audio.out_samplerate)
                  track->audio.out_samplerate = track->audio.samplerate;
              && track->codec_priv.size >= 40
              && track->codec_priv.data != NULL) {
              track->ms_compat = 1;
 -            track->video.fourcc = AV_RL32(track->codec_priv.data + 16);
 -            codec_id = ff_codec_get_id(ff_codec_bmp_tags, track->video.fourcc);
 +            fourcc = AV_RL32(track->codec_priv.data + 16);
 +            codec_id = ff_codec_get_id(ff_codec_bmp_tags, fourcc);
              extradata_offset = 40;
          } else if (!strcmp(track->codec_id, "A_MS/ACM")
                     && track->codec_priv.size >= 14
          } else if (!strcmp(track->codec_id, "V_QUICKTIME")
                     && (track->codec_priv.size >= 86)
                     && (track->codec_priv.data != NULL)) {
 -            track->video.fourcc = AV_RL32(track->codec_priv.data);
 -            codec_id=ff_codec_get_id(ff_codec_movvideo_tags, track->video.fourcc);
 +            fourcc = AV_RL32(track->codec_priv.data);
 +            codec_id = ff_codec_get_id(ff_codec_movvideo_tags, fourcc);
 +        } else if (codec_id == AV_CODEC_ID_ALAC && track->codec_priv.size && track->codec_priv.size < INT_MAX-12) {
 +            /* Only ALAC's magic cookie is stored in Matroska's track headers.
 +               Create the "atom size", "tag", and "tag version" fields the
 +               decoder expects manually. */
 +            extradata_size = 12 + track->codec_priv.size;
 +            extradata = av_mallocz(extradata_size + FF_INPUT_BUFFER_PADDING_SIZE);
 +            if (extradata == NULL)
 +                return AVERROR(ENOMEM);
 +            AV_WB32(extradata, extradata_size);
 +            memcpy(&extradata[4], "alac", 4);
 +            AV_WB32(&extradata[8], 0);
 +            memcpy(&extradata[12], track->codec_priv.data, track->codec_priv.size);
          } else if (codec_id == AV_CODEC_ID_PCM_S16BE) {
              switch (track->audio.bitdepth) {
              case  8:  codec_id = AV_CODEC_ID_PCM_U8;     break;
                  extradata_size = 5;
              } else
                  extradata_size = 2;
 -        } else if (codec_id == AV_CODEC_ID_ALAC && track->codec_priv.size) {
 -            /* Only ALAC's magic cookie is stored in Matroska's track headers.
 -               Create the "atom size", "tag", and "tag version" fields the
 -               decoder expects manually. */
 -            extradata_size = 12 + track->codec_priv.size;
 -            extradata = av_mallocz(extradata_size + FF_INPUT_BUFFER_PADDING_SIZE);
 -            if (extradata == NULL)
 -                return AVERROR(ENOMEM);
 -            AV_WB32(extradata, extradata_size);
 -            memcpy(&extradata[4], "alac", 4);
 -            AV_WB32(&extradata[8], 0);
 -            memcpy(&extradata[12], track->codec_priv.data,
 -                                   track->codec_priv.size);
          } else if (codec_id == AV_CODEC_ID_TTA) {
              extradata_size = 30;
 -            extradata = av_mallocz(extradata_size);
 +            extradata = av_mallocz(extradata_size + FF_INPUT_BUFFER_PADDING_SIZE);
              if (extradata == NULL)
                  return AVERROR(ENOMEM);
              ffio_init_context(&b, extradata, extradata_size, 1,
          } else if (codec_id == AV_CODEC_ID_RA_144) {
              track->audio.out_samplerate = 8000;
              track->audio.channels = 1;
 -        } else if (codec_id == AV_CODEC_ID_RA_288 || codec_id == AV_CODEC_ID_COOK ||
 -                   codec_id == AV_CODEC_ID_ATRAC3 || codec_id == AV_CODEC_ID_SIPR) {
 +        } else if ((codec_id == AV_CODEC_ID_RA_288 || codec_id == AV_CODEC_ID_COOK ||
 +                    codec_id == AV_CODEC_ID_ATRAC3 || codec_id == AV_CODEC_ID_SIPR)
 +                    && track->codec_priv.data) {
              int flavor;
 +
              ffio_init_context(&b, track->codec_priv.data,track->codec_priv.size,
                            0, NULL, NULL, NULL, NULL);
              avio_skip(&b, 22);
          }
  
          if (track->type == MATROSKA_TRACK_TYPE_VIDEO) {
 +            MatroskaTrackPlane *planes = track->operation.combine_planes.elem;
 +
              st->codec->codec_type = AVMEDIA_TYPE_VIDEO;
 -            st->codec->codec_tag  = track->video.fourcc;
 +            st->codec->codec_tag  = fourcc;
              st->codec->width  = track->video.pixel_width;
              st->codec->height = track->video.pixel_height;
              av_reduce(&st->sample_aspect_ratio.num,
                        st->codec->height * track->video.display_width,
                        st->codec-> width * track->video.display_height,
                        255);
 -            if (st->codec->codec_id != AV_CODEC_ID_H264)
              st->need_parsing = AVSTREAM_PARSE_HEADERS;
              if (track->default_duration) {
                  av_reduce(&st->avg_frame_rate.num, &st->avg_frame_rate.den,
                  st->r_frame_rate = st->avg_frame_rate;
  #endif
              }
 +
 +            /* export stereo mode flag as metadata tag */
 +            if (track->video.stereo_mode && track->video.stereo_mode < MATROSKA_VIDEO_STEREO_MODE_COUNT)
 +                av_dict_set(&st->metadata, "stereo_mode", ff_matroska_video_stereo_mode[track->video.stereo_mode], 0);
 +
 +            /* if we have virtual track, mark the real tracks */
 +            for (j=0; j < track->operation.combine_planes.nb_elem; j++) {
 +                char buf[32];
 +                if (planes[j].type >= MATROSKA_VIDEO_STEREO_PLANE_COUNT)
 +                    continue;
 +                snprintf(buf, sizeof(buf), "%s_%d",
 +                         ff_matroska_video_stereo_plane[planes[j].type], i);
 +                for (k=0; k < matroska->tracks.nb_elem; k++)
 +                    if (planes[j].uid == tracks[k].uid) {
 +                        av_dict_set(&s->streams[k]->metadata,
 +                                    "stereo_mode", buf, 0);
 +                        break;
 +                    }
 +            }
          } else if (track->type == MATROSKA_TRACK_TYPE_AUDIO) {
              st->codec->codec_type = AVMEDIA_TYPE_AUDIO;
              st->codec->sample_rate = track->audio.out_samplerate;
              av_dict_set(&st->metadata, "mimetype", attachements[j].mime, 0);
              st->codec->codec_id = AV_CODEC_ID_NONE;
              st->codec->codec_type = AVMEDIA_TYPE_ATTACHMENT;
 -            st->codec->extradata  = av_malloc(attachements[j].bin.size);
 +            st->codec->extradata  = av_malloc(attachements[j].bin.size + FF_INPUT_BUFFER_PADDING_SIZE);
              if(st->codec->extradata == NULL)
                  break;
              st->codec->extradata_size = attachements[j].bin.size;
              max_start = chapters[i].start;
          }
  
 +    matroska_add_index_entries(matroska);
 +
      matroska_convert_tags(s);
  
      return 0;
@@@ -1902,7 -1767,7 +1902,7 @@@ static int matroska_parse_laces(Matrosk
          return 0;
      }
  
 -    assert(size > 0);
 +    av_assert0(size > 0);
      *laces = *data + 1;
      data += 1;
      size -= 1;
      }
  
      case 0x2: /* fixed-size lacing */
-         if (size != (size / *laces) * *laces) {
+         if (size % (*laces)) {
              res = AVERROR_INVALIDDATA;
              break;
          }
@@@ -1994,7 -1859,7 +1994,7 @@@ static int matroska_parse_rm_audio(Matr
                                     MatroskaTrack *track,
                                     AVStream *st,
                                     uint8_t *data, int size,
 -                                   uint64_t timecode, uint64_t duration,
 +                                   uint64_t timecode,
                                     int64_t pos)
  {
      int a = st->codec->block_align;
@@@ -2060,7 -1925,7 +2060,7 @@@ static int matroska_parse_frame(Matrosk
                                  MatroskaTrack *track,
                                  AVStream *st,
                                  uint8_t *data, int pkt_size,
 -                                uint64_t timecode, uint64_t duration,
 +                                uint64_t timecode, uint64_t lace_duration,
                                  int64_t pos, int is_keyframe)
  {
      MatroskaTrackEncoding *encodings = track->encodings.elem;
      else
          pkt->pts = timecode;
      pkt->pos = pos;
 -    if (st->codec->codec_id == AV_CODEC_ID_TEXT)
 -        pkt->convergence_duration = duration;
 -    else if (track->type != MATROSKA_TRACK_TYPE_SUBTITLE)
 -        pkt->duration = duration;
 +    if (st->codec->codec_id == AV_CODEC_ID_SUBRIP) {
 +        /*
 +         * For backward compatibility.
 +         * Historically, we have put subtitle duration
 +         * in convergence_duration, on the off chance
 +         * that the time_scale is less than 1us, which
 +         * could result in a 32bit overflow on the
 +         * normal duration field.
 +         */
 +        pkt->convergence_duration = lace_duration;
 +    }
 +
 +    if (track->type != MATROSKA_TRACK_TYPE_SUBTITLE ||
 +        lace_duration <= INT_MAX) {
 +        /*
 +         * For non subtitle tracks, just store the duration
 +         * as normal.
 +         *
 +         * If it's a subtitle track and duration value does
 +         * not overflow a uint32, then also store it normally.
 +         */
 +        pkt->duration = lace_duration;
 +    }
  
      if (st->codec->codec_id == AV_CODEC_ID_SSA)
 -        matroska_fix_ass_packet(matroska, pkt, duration);
 +        matroska_fix_ass_packet(matroska, pkt, lace_duration);
  
      if (matroska->prev_pkt &&
          timecode != AV_NOPTS_VALUE &&
@@@ -2156,7 -2002,7 +2156,7 @@@ static int matroska_parse_block(Matrosk
      int16_t block_time;
      uint32_t *lace_size = NULL;
      int n, flags, laces = 0;
 -    uint64_t num, duration;
 +    uint64_t num;
  
      if ((n = matroska_ebmlnum_uint(matroska, data, size, &num)) < 0) {
          av_log(matroska->ctx, AV_LOG_ERROR, "EBML block data error\n");
      st = track->stream;
      if (st->discard >= AVDISCARD_ALL)
          return res;
 +    av_assert1(block_duration != AV_NOPTS_VALUE);
  
      block_time = AV_RB16(data);
      data += 2;
      }
  
      if (matroska->skip_to_keyframe && track->type != MATROSKA_TRACK_TYPE_SUBTITLE) {
 -        if (!is_keyframe || timecode < matroska->skip_to_timecode)
 +        if (timecode < matroska->skip_to_timecode)
              return res;
 -        matroska->skip_to_keyframe = 0;
 +        if (!st->skip_to_keyframe) {
 +            av_log(matroska->ctx, AV_LOG_ERROR, "File is broken, keyframes not correctly marked!\n");
 +            matroska->skip_to_keyframe = 0;
 +        }
 +        if (is_keyframe)
 +            matroska->skip_to_keyframe = 0;
      }
  
      res = matroska_parse_laces(matroska, &data, size, (flags & 0x06) >> 1,
      if (res)
          goto end;
  
 -    if (block_duration != AV_NOPTS_VALUE) {
 -        duration = block_duration / laces;
 -        if (block_duration != duration * laces) {
 -            av_log(matroska->ctx, AV_LOG_WARNING,
 -                   "Incorrect block_duration, possibly corrupted container");
 -        }
 -    } else {
 -        duration = track->default_duration / matroska->time_scale;
 -        block_duration = duration * laces;
 -    }
 +    if (!block_duration)
 +        block_duration = track->default_duration * laces / matroska->time_scale;
  
 -    if (timecode != AV_NOPTS_VALUE)
 +    if (cluster_time != (uint64_t)-1 && (block_time >= 0 || cluster_time >= -block_time))
          track->end_timecode =
              FFMAX(track->end_timecode, timecode + block_duration);
  
      for (n = 0; n < laces; n++) {
 +        int64_t lace_duration = block_duration*(n+1) / laces - block_duration*n / laces;
 +
 +        if (lace_size[n] > size) {
 +            av_log(matroska->ctx, AV_LOG_ERROR, "Invalid packet size\n");
 +            break;
 +        }
 +
          if ((st->codec->codec_id == AV_CODEC_ID_RA_288 ||
               st->codec->codec_id == AV_CODEC_ID_COOK ||
               st->codec->codec_id == AV_CODEC_ID_SIPR ||
               st->codec->block_align && track->audio.sub_packet_size) {
  
              res = matroska_parse_rm_audio(matroska, track, st, data, size,
 -                                          timecode, duration, pos);
 +                                          timecode, pos);
              if (res)
                  goto end;
  
          } else {
              res = matroska_parse_frame(matroska, track, st, data, lace_size[n],
 -                                      timecode, duration,
 +                                      timecode, lace_duration,
                                        pos, !n? is_keyframe : 0);
              if (res)
                  goto end;
          }
  
          if (timecode != AV_NOPTS_VALUE)
 -            timecode = duration ? timecode + duration : AV_NOPTS_VALUE;
 +            timecode = lace_duration ? timecode + lace_duration : AV_NOPTS_VALUE;
          data += lace_size[n];
          size -= lace_size[n];
      }
@@@ -2297,7 -2138,7 +2297,7 @@@ static int matroska_parse_cluster_incre
          if (blocks[i].bin.size > 0 && blocks[i].bin.data) {
              int is_keyframe = blocks[i].non_simple ? !blocks[i].reference : -1;
              if (!blocks[i].non_simple)
 -                blocks[i].duration = AV_NOPTS_VALUE;
 +                blocks[i].duration = 0;
              res = matroska_parse_block(matroska,
                                         blocks[i].bin.data, blocks[i].bin.size,
                                         blocks[i].bin.pos,
@@@ -2327,9 -2168,11 +2327,9 @@@ static int matroska_parse_cluster(Matro
      res = ebml_parse(matroska, matroska_clusters, &cluster);
      blocks_list = &cluster.blocks;
      blocks = blocks_list->elem;
 -    for (i=0; i<blocks_list->nb_elem && !res; i++)
 +    for (i=0; i<blocks_list->nb_elem; i++)
          if (blocks[i].bin.size > 0 && blocks[i].bin.data) {
              int is_keyframe = blocks[i].non_simple ? !blocks[i].reference : -1;
 -            if (!blocks[i].non_simple)
 -                blocks[i].duration = AV_NOPTS_VALUE;
              res=matroska_parse_block(matroska,
                                       blocks[i].bin.data, blocks[i].bin.size,
                                       blocks[i].bin.pos,  cluster.timecode,
                                       pos);
          }
      ebml_free(matroska_cluster, &cluster);
 -    if (res < 0)  matroska->done = 1;
      return res;
  }
  
  static int matroska_read_packet(AVFormatContext *s, AVPacket *pkt)
  {
      MatroskaDemuxContext *matroska = s->priv_data;
 -    int ret = 0;
  
 -    while (!ret && matroska_deliver_packet(matroska, pkt)) {
 +    while (matroska_deliver_packet(matroska, pkt)) {
 +        int64_t pos = avio_tell(matroska->ctx->pb);
          if (matroska->done)
              return AVERROR_EOF;
 -        ret = matroska_parse_cluster(matroska);
 -    }
 -
 -    if (ret == AVERROR_INVALIDDATA && pkt->data) {
 -        pkt->flags |= AV_PKT_FLAG_CORRUPT;
 -        return 0;
 +        if (matroska_parse_cluster(matroska) < 0)
 +            matroska_resync(matroska, pos);
      }
  
 -    return ret;
 +    return 0;
  }
  
  static int matroska_read_seek(AVFormatContext *s, int stream_index,
      int i, index, index_sub, index_min;
  
      /* Parse the CUES now since we need the index data to seek. */
 -    if (matroska->cues_parsing_deferred) {
 -        matroska_parse_cues(matroska);
 +    if (matroska->cues_parsing_deferred > 0) {
          matroska->cues_parsing_deferred = 0;
 +        matroska_parse_cues(matroska);
      }
  
      if (!st->nb_index_entries)
 -        return 0;
 +        goto err;
      timestamp = FFMAX(timestamp, st->index_entries[0].timestamp);
  
      if ((index = av_index_search_timestamp(st, timestamp, flags)) < 0) {
      }
  
      matroska_clear_queue(matroska);
 -    if (index < 0)
 -        return 0;
 +    if (index < 0 || (matroska->cues_parsing_deferred < 0 && index == st->nb_index_entries - 1))
 +        goto err;
  
      index_min = index;
      for (i=0; i < matroska->tracks.nb_elem; i++) {
  
      avio_seek(s->pb, st->index_entries[index_min].pos, SEEK_SET);
      matroska->current_id = 0;
 +    st->skip_to_keyframe =
      matroska->skip_to_keyframe = !(flags & AVSEEK_FLAG_ANY);
      matroska->skip_to_timecode = st->index_entries[index].timestamp;
      matroska->done = 0;
 +    matroska->num_levels = 0;
      ff_update_cur_dts(s, st, st->index_entries[index].timestamp);
      return 0;
 +err:
 +    // slightly hackish but allows proper fallback to
 +    // the generic seeking code.
 +    matroska_clear_queue(matroska);
 +    matroska->current_id = 0;
 +    st->skip_to_keyframe =
 +    matroska->skip_to_keyframe = 0;
 +    matroska->done = 0;
 +    matroska->num_levels = 0;
 +    return -1;
  }
  
  static int matroska_read_close(AVFormatContext *s)
diff --combined libavformat/utils.c
@@@ -1,21 -1,21 +1,21 @@@
  /*
 - * various utility functions for use within Libav
 + * various utility functions for use within FFmpeg
   * 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
   */
  
@@@ -25,9 -25,7 +25,9 @@@
  #include "avio_internal.h"
  #include "internal.h"
  #include "libavcodec/internal.h"
 +#include "libavcodec/raw.h"
  #include "libavcodec/bytestream.h"
 +#include "libavutil/avassert.h"
  #include "libavutil/opt.h"
  #include "libavutil/dict.h"
  #include "libavutil/pixdesc.h"
@@@ -38,7 -36,6 +38,7 @@@
  #include "libavutil/mathematics.h"
  #include "libavutil/parseutils.h"
  #include "libavutil/time.h"
 +#include "libavutil/timestamp.h"
  #include "riff.h"
  #include "audiointerleave.h"
  #include "url.h"
  
  /**
   * @file
 - * various utility functions for use within Libav
 + * various utility functions for use within FFmpeg
   */
  
  unsigned avformat_version(void)
  {
 +    av_assert0(LIBAVFORMAT_VERSION_MICRO >= 100);
      return LIBAVFORMAT_VERSION_INT;
  }
  
  const char *avformat_configuration(void)
  {
 -    return LIBAV_CONFIGURATION;
 +    return FFMPEG_CONFIGURATION;
  }
  
  const char *avformat_license(void)
  {
  #define LICENSE_PREFIX "libavformat license: "
 -    return LICENSE_PREFIX LIBAV_LICENSE + sizeof(LICENSE_PREFIX) - 1;
 +    return LICENSE_PREFIX FFMPEG_LICENSE + sizeof(LICENSE_PREFIX) - 1;
 +}
 +
 +#define RELATIVE_TS_BASE (INT64_MAX - (1LL<<48))
 +
 +static int is_relative(int64_t ts) {
 +    return ts > (RELATIVE_TS_BASE - (1LL<<48));
  }
  
  /* fraction handling */
@@@ -227,7 -217,7 +227,7 @@@ AVOutputFormat *av_guess_format(const c
      score_max = 0;
      while ((fmt = av_oformat_next(fmt))) {
          score = 0;
 -        if (fmt->name && short_name && !av_strcasecmp(fmt->name, short_name))
 +        if (fmt->name && short_name && match_format(short_name, fmt->name))
              score += 100;
          if (fmt->mime_type && mime_type && !strcmp(fmt->mime_type, mime_type))
              score += 10;
@@@ -274,33 -264,10 +274,33 @@@ AVInputFormat *av_find_input_format(con
      return NULL;
  }
  
 +int ffio_limit(AVIOContext *s, int size)
 +{
 +    if(s->maxsize>=0){
 +        int64_t remaining= s->maxsize - avio_tell(s);
 +        if(remaining < size){
 +            int64_t newsize= avio_size(s);
 +            if(!s->maxsize || s->maxsize<newsize)
 +                s->maxsize= newsize - !newsize;
 +            remaining= s->maxsize - avio_tell(s);
 +            remaining= FFMAX(remaining, 0);
 +        }
 +
 +        if(s->maxsize>=0 && remaining+1 < size){
 +            av_log(0, remaining ? AV_LOG_ERROR : AV_LOG_DEBUG, "Truncating packet of size %d to %"PRId64"\n", size, remaining+1);
 +            size= remaining+1;
 +        }
 +    }
 +    return size;
 +}
  
  int av_get_packet(AVIOContext *s, AVPacket *pkt, int size)
  {
 -    int ret= av_new_packet(pkt, size);
 +    int ret;
 +    int orig_size = size;
 +    size= ffio_limit(s, size);
 +
 +    ret= av_new_packet(pkt, size);
  
      if(ret<0)
          return ret;
          av_free_packet(pkt);
      else
          av_shrink_packet(pkt, ret);
 +    if (pkt->size < orig_size)
 +        pkt->flags |= AV_PKT_FLAG_CORRUPT;
  
      return ret;
  }
@@@ -340,19 -305,19 +340,19 @@@ int av_filename_number_test(const char 
      return filename && (av_get_frame_filename(buf, sizeof(buf), filename, 1)>=0);
  }
  
 -AVInputFormat *av_probe_input_format2(AVProbeData *pd, int is_opened, int *score_max)
 +AVInputFormat *av_probe_input_format3(AVProbeData *pd, int is_opened, int *score_ret)
  {
      AVProbeData lpd = *pd;
      AVInputFormat *fmt1 = NULL, *fmt;
 -    int score, id3 = 0;
 +    int score, nodat = 0, score_max=0;
  
      if (lpd.buf_size > 10 && ff_id3v2_match(lpd.buf, ID3v2_DEFAULT_MAGIC)) {
          int id3len = ff_id3v2_tag_len(lpd.buf);
          if (lpd.buf_size > id3len + 16) {
              lpd.buf += id3len;
              lpd.buf_size -= id3len;
 -        }
 -        id3 = 1;
 +        }else
 +            nodat = 1;
      }
  
      fmt = NULL;
          score = 0;
          if (fmt1->read_probe) {
              score = fmt1->read_probe(&lpd);
 +            if(fmt1->extensions && av_match_ext(lpd.filename, fmt1->extensions))
 +                score = FFMAX(score, nodat ? AVPROBE_SCORE_MAX/4-1 : 1);
          } else if (fmt1->extensions) {
              if (av_match_ext(lpd.filename, fmt1->extensions)) {
                  score = 50;
              }
          }
 -        if (score > *score_max) {
 -            *score_max = score;
 +        if (score > score_max) {
 +            score_max = score;
              fmt = fmt1;
 -        }else if (score == *score_max)
 +        }else if (score == score_max)
              fmt = NULL;
      }
 -
 -    /* a hack for files with huge id3v2 tags -- try to guess by file extension. */
 -    if (!fmt && is_opened && *score_max < AVPROBE_SCORE_MAX/4) {
 -        while ((fmt = av_iformat_next(fmt)))
 -            if (fmt->extensions && av_match_ext(lpd.filename, fmt->extensions)) {
 -                *score_max = AVPROBE_SCORE_MAX/4;
 -                break;
 -            }
 -    }
 -
 -    if (!fmt && id3 && *score_max < AVPROBE_SCORE_MAX/4-1) {
 -        while ((fmt = av_iformat_next(fmt)))
 -            if (fmt->extensions && av_match_ext("mp3", fmt->extensions)) {
 -                *score_max = AVPROBE_SCORE_MAX/4-1;
 -                break;
 -            }
 -    }
 +    *score_ret= score_max;
  
      return fmt;
  }
  
 +AVInputFormat *av_probe_input_format2(AVProbeData *pd, int is_opened, int *score_max)
 +{
 +    int score_ret;
 +    AVInputFormat *fmt= av_probe_input_format3(pd, is_opened, &score_ret);
 +    if(score_ret > *score_max){
 +        *score_max= score_ret;
 +        return fmt;
 +    }else
 +        return NULL;
 +}
 +
  AVInputFormat *av_probe_input_format(AVProbeData *pd, int is_opened){
      int score=0;
      return av_probe_input_format2(pd, is_opened, &score);
  }
  
 -static int set_codec_from_probe_data(AVFormatContext *s, AVStream *st, AVProbeData *pd, int score)
 +static int set_codec_from_probe_data(AVFormatContext *s, AVStream *st, AVProbeData *pd)
  {
      static const struct {
          const char *name; enum AVCodecID id; enum AVMediaType type;
          { "dts"      , AV_CODEC_ID_DTS       , AVMEDIA_TYPE_AUDIO },
          { "eac3"     , AV_CODEC_ID_EAC3      , AVMEDIA_TYPE_AUDIO },
          { "h264"     , AV_CODEC_ID_H264      , AVMEDIA_TYPE_VIDEO },
 +        { "loas"     , AV_CODEC_ID_AAC_LATM  , AVMEDIA_TYPE_AUDIO },
          { "m4v"      , AV_CODEC_ID_MPEG4     , AVMEDIA_TYPE_VIDEO },
          { "mp3"      , AV_CODEC_ID_MP3       , AVMEDIA_TYPE_AUDIO },
          { "mpegvideo", AV_CODEC_ID_MPEG2VIDEO, AVMEDIA_TYPE_VIDEO },
          { 0 }
      };
 -    AVInputFormat *fmt = av_probe_input_format2(pd, 1, &score);
 +    int score;
 +    AVInputFormat *fmt = av_probe_input_format3(pd, 1, &score);
  
      if (fmt) {
          int i;
              }
          }
      }
 -    return !!fmt;
 +    return score;
  }
  
  /************************************************************/
  /* input media file */
  
 +int av_demuxer_open(AVFormatContext *ic){
 +    int err;
 +
 +    if (ic->iformat->read_header) {
 +        err = ic->iformat->read_header(ic);
 +        if (err < 0)
 +            return err;
 +    }
 +
 +    if (ic->pb && !ic->data_offset)
 +        ic->data_offset = avio_tell(ic->pb);
 +
 +    return 0;
 +}
 +
 +
  /** size of probe buffer, for guessing file type from file contents */
  #define PROBE_BUF_MIN 2048
  #define PROBE_BUF_MAX (1<<20)
@@@ -477,19 -427,13 +477,19 @@@ int av_probe_input_buffer(AVIOContext *
          probe_size = FFMIN(probe_size<<1, FFMAX(max_probe_size, probe_size+1))) {
          int score = probe_size < max_probe_size ? AVPROBE_SCORE_MAX/4 : 0;
          int buf_offset = (probe_size == PROBE_BUF_MIN) ? 0 : probe_size>>1;
 +        void *buftmp;
  
          if (probe_size < offset) {
              continue;
          }
  
          /* read probe data */
 -        buf = av_realloc(buf, probe_size + AVPROBE_PADDING_SIZE);
 +        buftmp = av_realloc(buf, probe_size + AVPROBE_PADDING_SIZE);
 +        if(!buftmp){
 +            av_free(buf);
 +            return AVERROR(ENOMEM);
 +        }
 +        buf=buftmp;
          if ((ret = avio_read(pb, buf + buf_offset, probe_size - buf_offset)) < 0) {
              /* fail if error was not end of file, otherwise, lower score */
              if (ret != AVERROR_EOF) {
          *fmt = av_probe_input_format2(&pd, 1, &score);
          if(*fmt){
              if(score <= AVPROBE_SCORE_MAX/4){ //this can only be true in the last iteration
 -                av_log(logctx, AV_LOG_WARNING, "Format detected only with low score of %d, misdetection possible!\n", score);
 +                av_log(logctx, AV_LOG_WARNING, "Format %s detected only with low score of %d, misdetection possible!\n", (*fmt)->name, score);
              }else
 -                av_log(logctx, AV_LOG_DEBUG, "Probed with size=%d and score=%d\n", probe_size, score);
 +                av_log(logctx, AV_LOG_DEBUG, "Format %s probed with size=%d and score=%d\n", (*fmt)->name, probe_size, score);
          }
      }
  
@@@ -537,8 -481,7 +537,8 @@@ static int init_input(AVFormatContext *
          if (!s->iformat)
              return av_probe_input_buffer(s->pb, &s->iformat, filename, s, 0, s->probesize);
          else if (s->iformat->flags & AVFMT_NOFILE)
 -            return AVERROR(EINVAL);
 +            av_log(s, AV_LOG_WARNING, "Custom AVIOContext makes no sense and "
 +                                      "will be ignored with AVFMT_NOFILE format.\n");
          return 0;
      }
  
          (!s->iformat && (s->iformat = av_probe_input_format(&pd, 0))))
          return 0;
  
 -    if ((ret = avio_open2(&s->pb, filename, AVIO_FLAG_READ,
 +    if ((ret = avio_open2(&s->pb, filename, AVIO_FLAG_READ | s->avio_flags,
                            &s->interrupt_callback, options)) < 0)
          return ret;
      if (s->iformat)
@@@ -571,7 -514,7 +571,7 @@@ static AVPacket *add_to_pktbuf(AVPacket
      return &pktl->pkt;
  }
  
 -static void queue_attached_pictures(AVFormatContext *s)
 +void avformat_queue_attached_pictures(AVFormatContext *s)
  {
      int i;
      for (i = 0; i < s->nb_streams; i++)
@@@ -592,10 -535,6 +592,10 @@@ int avformat_open_input(AVFormatContex
  
      if (!s && !(s = avformat_alloc_context()))
          return AVERROR(ENOMEM);
 +    if (!s->av_class){
 +        av_log(0, AV_LOG_ERROR, "Input context has not been properly allocated by avformat_alloc_context() and is not NULL either\n");
 +        return AVERROR(EINVAL);
 +    }
      if (fmt)
          s->iformat = fmt;
  
      if (s->pb)
          ff_id3v2_read(s, ID3v2_DEFAULT_MAGIC, &id3v2_extra_meta);
  
 -    if (s->iformat->read_header)
 +    if (!(s->flags&AVFMT_FLAG_PRIV_OPT) && s->iformat->read_header)
          if ((ret = s->iformat->read_header(s)) < 0)
              goto fail;
  
          goto fail;
      ff_id3v2_free_extra_meta(&id3v2_extra_meta);
  
 -    queue_attached_pictures(s);
 +    avformat_queue_attached_pictures(s);
  
 -    if (s->pb && !s->data_offset)
 +    if (!(s->flags&AVFMT_FLAG_PRIV_OPT) && s->pb && !s->data_offset)
          s->data_offset = avio_tell(s->pb);
  
      s->raw_packet_buffer_remaining_size = RAW_PACKET_BUFFER_SIZE;
@@@ -674,59 -613,37 +674,63 @@@ fail
  
  static void probe_codec(AVFormatContext *s, AVStream *st, const AVPacket *pkt)
  {
 -    if(st->codec->codec_id == AV_CODEC_ID_PROBE){
 +    if(st->request_probe>0){
          AVProbeData *pd = &st->probe_data;
 -        av_log(s, AV_LOG_DEBUG, "probing stream %d\n", st->index);
 +        int end;
 +        av_log(s, AV_LOG_DEBUG, "probing stream %d pp:%d\n", st->index, st->probe_packets);
          --st->probe_packets;
  
          if (pkt) {
 -            pd->buf = av_realloc(pd->buf, pd->buf_size+pkt->size+AVPROBE_PADDING_SIZE);
 +            uint8_t *new_buf = av_realloc(pd->buf, pd->buf_size+pkt->size+AVPROBE_PADDING_SIZE);
 +            if(!new_buf)
 +                goto no_packet;
 +            pd->buf = new_buf;
              memcpy(pd->buf+pd->buf_size, pkt->data, pkt->size);
              pd->buf_size += pkt->size;
              memset(pd->buf+pd->buf_size, 0, AVPROBE_PADDING_SIZE);
          } else {
 +no_packet:
              st->probe_packets = 0;
 -                av_log(s, AV_LOG_ERROR, "nothing to probe for stream %d\n",
+             if (!pd->buf_size) {
 -                return;
++                av_log(s, AV_LOG_WARNING, "nothing to probe for stream %d\n",
+                        st->index);
+             }
          }
  
 -        if (!st->probe_packets ||
 -            av_log2(pd->buf_size) != av_log2(pd->buf_size - pkt->size)) {
 -            set_codec_from_probe_data(s, st, pd, st->probe_packets > 0 ? AVPROBE_SCORE_MAX/4 : 0);
 -            if(st->codec->codec_id != AV_CODEC_ID_PROBE){
 +        end=    s->raw_packet_buffer_remaining_size <= 0
 +                || st->probe_packets<=0;
 +
 +        if(end || av_log2(pd->buf_size) != av_log2(pd->buf_size - pkt->size)){
 +            int score= set_codec_from_probe_data(s, st, pd);
 +            if(    (st->codec->codec_id != AV_CODEC_ID_NONE && score > AVPROBE_SCORE_MAX/4)
 +                || end){
                  pd->buf_size=0;
                  av_freep(&pd->buf);
 -                av_log(s, AV_LOG_DEBUG, "probed stream %d\n", st->index);
 +                st->request_probe= -1;
 +                if(st->codec->codec_id != AV_CODEC_ID_NONE){
 +                    av_log(s, AV_LOG_DEBUG, "probed stream %d\n", st->index);
 +                }else
 +                    av_log(s, AV_LOG_WARNING, "probed stream %d failed\n", st->index);
              }
          }
      }
  }
  
 +static void force_codec_ids(AVFormatContext *s, AVStream *st)
 +{
 +    switch(st->codec->codec_type){
 +    case AVMEDIA_TYPE_VIDEO:
 +        if(s->video_codec_id)   st->codec->codec_id= s->video_codec_id;
 +        break;
 +    case AVMEDIA_TYPE_AUDIO:
 +        if(s->audio_codec_id)   st->codec->codec_id= s->audio_codec_id;
 +        break;
 +    case AVMEDIA_TYPE_SUBTITLE:
 +        if(s->subtitle_codec_id)st->codec->codec_id= s->subtitle_codec_id;
 +        break;
 +    }
 +}
 +
  int ff_read_packet(AVFormatContext *s, AVPacket *pkt)
  {
      int ret, i;
          if (pktl) {
              *pkt = pktl->pkt;
              st = s->streams[pkt->stream_index];
 -            if (st->codec->codec_id != AV_CODEC_ID_PROBE || !st->probe_packets ||
 -                s->raw_packet_buffer_remaining_size < pkt->size) {
 -                AVProbeData *pd;
 -                if (st->probe_packets) {
 -                    probe_codec(s, st, NULL);
 -                }
 -                pd = &st->probe_data;
 -                av_freep(&pd->buf);
 -                pd->buf_size = 0;
 +            if(st->request_probe <= 0){
                  s->raw_packet_buffer = pktl->next;
                  s->raw_packet_buffer_remaining_size += pkt->size;
                  av_free(pktl);
              }
          }
  
+         pkt->data = NULL;
+         pkt->size = 0;
          av_init_packet(pkt);
          ret= s->iformat->read_packet(s, pkt);
          if (ret < 0) {
                  if (st->probe_packets) {
                      probe_codec(s, st, NULL);
                  }
 +                av_assert0(st->request_probe <= 0);
              }
              continue;
          }
              continue;
          }
  
 -        st= s->streams[pkt->stream_index];
 +        if(!(s->flags & AVFMT_FLAG_KEEP_SIDE_DATA))
 +            av_packet_merge_side_data(pkt);
  
 -        switch(st->codec->codec_type){
 -        case AVMEDIA_TYPE_VIDEO:
 -            if(s->video_codec_id)   st->codec->codec_id= s->video_codec_id;
 -            break;
 -        case AVMEDIA_TYPE_AUDIO:
 -            if(s->audio_codec_id)   st->codec->codec_id= s->audio_codec_id;
 -            break;
 -        case AVMEDIA_TYPE_SUBTITLE:
 -            if(s->subtitle_codec_id)st->codec->codec_id= s->subtitle_codec_id;
 -            break;
 +        if(pkt->stream_index >= (unsigned)s->nb_streams){
 +            av_log(s, AV_LOG_ERROR, "Invalid stream index %d\n", pkt->stream_index);
 +            continue;
          }
  
 -        if(!pktl && (st->codec->codec_id != AV_CODEC_ID_PROBE ||
 -                     !st->probe_packets))
 +        st= s->streams[pkt->stream_index];
 +
 +        force_codec_ids(s, st);
 +
 +        /* TODO: audio: time filter; video: frame reordering (pts != dts) */
 +        if (s->use_wallclock_as_timestamps)
 +            pkt->dts = pkt->pts = av_rescale_q(av_gettime(), AV_TIME_BASE_Q, st->time_base);
 +
 +        if(!pktl && st->request_probe <= 0)
              return ret;
  
          add_to_pktbuf(&s->raw_packet_buffer, pkt, &s->raw_packet_buffer_end);
@@@ -806,17 -731,6 +812,17 @@@ int av_read_packet(AVFormatContext *s, 
  
  /**********************************************************/
  
 +static int determinable_frame_size(AVCodecContext *avctx)
 +{
 +    if (/*avctx->codec_id == AV_CODEC_ID_AAC ||*/
 +        avctx->codec_id == AV_CODEC_ID_MP1 ||
 +        avctx->codec_id == AV_CODEC_ID_MP2 ||
 +        avctx->codec_id == AV_CODEC_ID_MP3/* ||
 +        avctx->codec_id == AV_CODEC_ID_CELT*/)
 +        return 1;
 +    return 0;
 +}
 +
  /**
   * Get the number of samples of an audio frame. Return -1 on error.
   */
@@@ -851,9 -765,9 +857,9 @@@ static void compute_frame_duration(int 
      *pden = 0;
      switch(st->codec->codec_type) {
      case AVMEDIA_TYPE_VIDEO:
 -        if (st->avg_frame_rate.num) {
 -            *pnum = st->avg_frame_rate.den;
 -            *pden = st->avg_frame_rate.num;
 +        if (st->r_frame_rate.num && !pc) {
 +            *pnum = st->r_frame_rate.den;
 +            *pden = st->r_frame_rate.num;
          } else if(st->time_base.num*1000LL > st->time_base.den) {
              *pnum = st->time_base.num;
              *pden = st->time_base.den;
      }
  }
  
 -static int is_intra_only(enum AVCodecID id)
 +static int is_intra_only(AVCodecContext *enc){
 +    const AVCodecDescriptor *desc;
 +
 +    if(enc->codec_type != AVMEDIA_TYPE_VIDEO)
 +        return 1;
 +
 +    desc = av_codec_get_codec_descriptor(enc);
 +    if (!desc) {
 +        desc = avcodec_descriptor_get(enc->codec_id);
 +        av_codec_set_codec_descriptor(enc, desc);
 +    }
 +    if (desc)
 +        return !!(desc->props & AV_CODEC_PROP_INTRA_ONLY);
 +    return 0;
 +}
 +
 +static int has_decode_delay_been_guessed(AVStream *st)
  {
 -    const AVCodecDescriptor *d = avcodec_descriptor_get(id);
 -    if (!d)
 -        return 0;
 -    if (d->type == AVMEDIA_TYPE_VIDEO && !(d->props & AV_CODEC_PROP_INTRA_ONLY))
 -        return 0;
 -    return 1;
 +    if(st->codec->codec_id != AV_CODEC_ID_H264) return 1;
 +#if CONFIG_H264_DECODER
 +    if(st->codec->has_b_frames &&
 +       avpriv_h264_has_num_reorder_frames(st->codec) == st->codec->has_b_frames)
 +        return 1;
 +#endif
 +    if(st->codec->has_b_frames<3)
 +        return st->nb_decoded_frames >= 7;
 +    else if(st->codec->has_b_frames<4)
 +        return st->nb_decoded_frames >= 18;
 +    else
 +        return st->nb_decoded_frames >= 20;
 +}
 +
 +static AVPacketList *get_next_pkt(AVFormatContext *s, AVStream *st, AVPacketList *pktl)
 +{
 +    if (pktl->next)
 +        return pktl->next;
 +    if (pktl == s->parse_queue_end)
 +        return s->packet_buffer;
 +    return NULL;
  }
  
  static void update_initial_timestamps(AVFormatContext *s, int stream_index,
                                        int64_t dts, int64_t pts)
  {
      AVStream *st= s->streams[stream_index];
 -    AVPacketList *pktl= s->packet_buffer;
 +    AVPacketList *pktl= s->parse_queue ? s->parse_queue : s->packet_buffer;
  
 -    if(st->first_dts != AV_NOPTS_VALUE || dts == AV_NOPTS_VALUE || st->cur_dts == AV_NOPTS_VALUE)
 +    if(st->first_dts != AV_NOPTS_VALUE || dts == AV_NOPTS_VALUE || st->cur_dts == AV_NOPTS_VALUE || is_relative(dts))
          return;
  
 -    st->first_dts= dts - st->cur_dts;
 +    st->first_dts= dts - (st->cur_dts - RELATIVE_TS_BASE);
      st->cur_dts= dts;
  
 -    for(; pktl; pktl= pktl->next){
 +    if (is_relative(pts))
 +        pts += st->first_dts - RELATIVE_TS_BASE;
 +
 +    for(; pktl; pktl= get_next_pkt(s, st, pktl)){
          if(pktl->pkt.stream_index != stream_index)
              continue;
 -        //FIXME think more about this check
 -        if(pktl->pkt.pts != AV_NOPTS_VALUE && pktl->pkt.pts == pktl->pkt.dts)
 -            pktl->pkt.pts += st->first_dts;
 +        if(is_relative(pktl->pkt.pts))
 +            pktl->pkt.pts += st->first_dts - RELATIVE_TS_BASE;
  
 -        if(pktl->pkt.dts != AV_NOPTS_VALUE)
 -            pktl->pkt.dts += st->first_dts;
 +        if(is_relative(pktl->pkt.dts))
 +            pktl->pkt.dts += st->first_dts - RELATIVE_TS_BASE;
  
          if(st->start_time == AV_NOPTS_VALUE && pktl->pkt.pts != AV_NOPTS_VALUE)
              st->start_time= pktl->pkt.pts;
  static void update_initial_durations(AVFormatContext *s, AVStream *st,
                                       int stream_index, int duration)
  {
 -    AVPacketList *pktl= s->packet_buffer;
 -    int64_t cur_dts= 0;
 +    AVPacketList *pktl= s->parse_queue ? s->parse_queue : s->packet_buffer;
 +    int64_t cur_dts= RELATIVE_TS_BASE;
  
      if(st->first_dts != AV_NOPTS_VALUE){
          cur_dts= st->first_dts;
 -        for(; pktl; pktl= pktl->next){
 +        for(; pktl; pktl= get_next_pkt(s, st, pktl)){
              if(pktl->pkt.stream_index == stream_index){
                  if(pktl->pkt.pts != pktl->pkt.dts || pktl->pkt.dts != AV_NOPTS_VALUE || pktl->pkt.duration)
                      break;
                  cur_dts -= duration;
              }
          }
 -        pktl= s->packet_buffer;
 +        if(pktl && pktl->pkt.dts != st->first_dts) {
 +            av_log(s, AV_LOG_DEBUG, "first_dts %s not matching first dts %s in que\n", av_ts2str(st->first_dts), av_ts2str(pktl->pkt.dts));
 +            return;
 +        }
 +        if(!pktl) {
 +            av_log(s, AV_LOG_DEBUG, "first_dts %s but no packet with dts in ques\n", av_ts2str(st->first_dts));
 +            return;
 +        }
 +        pktl= s->parse_queue ? s->parse_queue : s->packet_buffer;
          st->first_dts = cur_dts;
 -    }else if(st->cur_dts)
 +    }else if(st->cur_dts != RELATIVE_TS_BASE)
          return;
  
 -    for(; pktl; pktl= pktl->next){
 +    for(; pktl; pktl= get_next_pkt(s, st, pktl)){
          if(pktl->pkt.stream_index != stream_index)
              continue;
 -        if(pktl->pkt.pts == pktl->pkt.dts && pktl->pkt.dts == AV_NOPTS_VALUE
 +        if(pktl->pkt.pts == pktl->pkt.dts && (pktl->pkt.dts == AV_NOPTS_VALUE || pktl->pkt.dts == st->first_dts)
             && !pktl->pkt.duration){
              pktl->pkt.dts= cur_dts;
              if(!st->codec->has_b_frames)
                  pktl->pkt.pts= cur_dts;
 -            cur_dts += duration;
 -            if (st->codec->codec_type != AVMEDIA_TYPE_AUDIO)
 +//            if (st->codec->codec_type != AVMEDIA_TYPE_AUDIO)
                  pktl->pkt.duration = duration;
          }else
              break;
 +        cur_dts = pktl->pkt.dts + pktl->pkt.duration;
      }
 -    if(st->first_dts == AV_NOPTS_VALUE)
 +    if(!pktl)
          st->cur_dts= cur_dts;
  }
  
@@@ -1012,10 -885,6 +1018,10 @@@ static void compute_pkt_fields(AVFormat
      if((s->flags & AVFMT_FLAG_IGNDTS) && pkt->pts != AV_NOPTS_VALUE)
          pkt->dts= AV_NOPTS_VALUE;
  
 +    if (st->codec->codec_id != AV_CODEC_ID_H264 && pc && pc->pict_type == AV_PICTURE_TYPE_B)
 +        //FIXME Set low_delay = 0 when has_b_frames = 1
 +        st->codec->has_b_frames = 1;
 +
      /* do we have a video B-frame ? */
      delay= st->codec->has_b_frames;
      presentation_delayed = 0;
          pc && pc->pict_type != AV_PICTURE_TYPE_B)
          presentation_delayed = 1;
  
 -    if(pkt->pts != AV_NOPTS_VALUE && pkt->dts != AV_NOPTS_VALUE && pkt->dts > pkt->pts && st->pts_wrap_bits<63
 -       /*&& pkt->dts-(1LL<<st->pts_wrap_bits) < pkt->pts*/){
 -        pkt->dts -= 1LL<<st->pts_wrap_bits;
 +    if(pkt->pts != AV_NOPTS_VALUE && pkt->dts != AV_NOPTS_VALUE && st->pts_wrap_bits<63 && pkt->dts - (1LL<<(st->pts_wrap_bits-1)) > pkt->pts){
 +        if(is_relative(st->cur_dts) || pkt->dts - (1LL<<(st->pts_wrap_bits-1)) > st->cur_dts) {
 +            pkt->dts -= 1LL<<st->pts_wrap_bits;
 +        } else
 +            pkt->pts += 1LL<<st->pts_wrap_bits;
      }
  
      // some mpeg2 in mpeg-ps lack dts (issue171 / input_file.mpg)
      // we take the conservative approach and discard both
      // Note, if this is misbehaving for a H.264 file then possibly presentation_delayed is not set correctly.
      if(delay==1 && pkt->dts == pkt->pts && pkt->dts != AV_NOPTS_VALUE && presentation_delayed){
 -        av_log(s, AV_LOG_DEBUG, "invalid dts/pts combination\n");
 -        pkt->dts= pkt->pts= AV_NOPTS_VALUE;
 +        av_log(s, AV_LOG_DEBUG, "invalid dts/pts combination %"PRIi64"\n", pkt->dts);
 +        if(strcmp(s->iformat->name, "mov,mp4,m4a,3gp,3g2,mj2")) // otherwise we discard correct timestamps for vc1-wmapro.ism
 +            pkt->dts= AV_NOPTS_VALUE;
      }
  
 -    if (pkt->duration == 0 && st->codec->codec_type != AVMEDIA_TYPE_AUDIO) {
 +    if (pkt->duration == 0) {
          compute_frame_duration(&num, &den, st, pc, pkt);
          if (den && num) {
              pkt->duration = av_rescale_rnd(1, num * (int64_t)st->time_base.den, den * (int64_t)st->time_base.num, AV_ROUND_DOWN);
 -
 -            if(pkt->duration != 0 && s->packet_buffer)
 -                update_initial_durations(s, st, pkt->stream_index, pkt->duration);
          }
      }
 +    if(pkt->duration != 0 && (s->packet_buffer || s->parse_queue))
 +        update_initial_durations(s, st, pkt->stream_index, pkt->duration);
  
      /* correct timestamps with byte offset if demuxers only have timestamps
         on packet boundaries */
      if(pkt->dts != AV_NOPTS_VALUE && pkt->pts != AV_NOPTS_VALUE && pkt->pts > pkt->dts)
          presentation_delayed = 1;
  
 -//    av_log(NULL, AV_LOG_DEBUG, "IN delayed:%d pts:%"PRId64", dts:%"PRId64" cur_dts:%"PRId64" st:%d pc:%p\n", presentation_delayed, pkt->pts, pkt->dts, st->cur_dts, pkt->stream_index, pc);
 +//    av_log(NULL, AV_LOG_DEBUG, "IN delayed:%d pts:%s, dts:%s cur_dts:%s st:%d pc:%p duration:%d\n",
 +//           presentation_delayed, av_ts2str(pkt->pts), av_ts2str(pkt->dts), av_ts2str(st->cur_dts), pkt->stream_index, pc, pkt->duration);
      /* interpolate PTS and DTS if they are not present */
      //We skip H264 currently because delay and has_b_frames are not reliably set
      if((delay==0 || (delay==1 && pc)) && st->codec->codec_id != AV_CODEC_ID_H264){
              by knowing the future */
          } else if (pkt->pts != AV_NOPTS_VALUE ||
                     pkt->dts != AV_NOPTS_VALUE ||
 -                   pkt->duration              ||
 -                   st->codec->codec_type == AVMEDIA_TYPE_AUDIO) {
 +                   pkt->duration                ) {
              int duration = pkt->duration;
 -            if (!duration && st->codec->codec_type == AVMEDIA_TYPE_AUDIO) {
 -                compute_frame_duration(&num, &den, st, pc, pkt);
 -                if (den && num) {
 -                    duration = av_rescale_rnd(1, num * (int64_t)st->time_base.den,
 -                                                 den * (int64_t)st->time_base.num,
 -                                                 AV_ROUND_DOWN);
 -                    if (duration != 0 && s->packet_buffer) {
 -                        update_initial_durations(s, st, pkt->stream_index,
 -                                                 duration);
 -                    }
 +
 +            if(st->cur_dts != AV_NOPTS_VALUE && pkt->pts != AV_NOPTS_VALUE && duration){
 +                int64_t old_diff= FFABS(st->cur_dts - duration - pkt->pts);
 +                int64_t new_diff= FFABS(st->cur_dts - pkt->pts);
 +                if(   old_diff < new_diff && old_diff < (duration>>3)
 +                   && st->codec->codec_type == AVMEDIA_TYPE_VIDEO
 +                   && (!strcmp(s->iformat->name, "mpeg") ||
 +                       !strcmp(s->iformat->name, "mpegts"))){
 +                    pkt->pts += duration;
 +                    av_log(s, AV_LOG_WARNING, "Adjusting PTS forward\n");
 +//                    av_log(NULL, AV_LOG_DEBUG, "id:%d old:%"PRId64" new:%"PRId64" dur:%d cur:%s size:%d\n",
 +//                           pkt->stream_index, old_diff, new_diff, pkt->duration, av_ts2str(st->cur_dts), pkt->size);
                  }
              }
  
 -            if (pkt->pts != AV_NOPTS_VALUE || pkt->dts != AV_NOPTS_VALUE ||
 -                duration) {
 -                /* presentation is not delayed : PTS and DTS are the same */
 -                if (pkt->pts == AV_NOPTS_VALUE)
 -                    pkt->pts = pkt->dts;
 -                update_initial_timestamps(s, pkt->stream_index, pkt->pts,
 -                                          pkt->pts);
 -                if (pkt->pts == AV_NOPTS_VALUE)
 -                    pkt->pts = st->cur_dts;
 -                pkt->dts = pkt->pts;
 -                if (pkt->pts != AV_NOPTS_VALUE)
 -                    st->cur_dts = pkt->pts + duration;
 -            }
 +            /* presentation is not delayed : PTS and DTS are the same */
 +            if (pkt->pts == AV_NOPTS_VALUE)
 +                pkt->pts = pkt->dts;
 +            update_initial_timestamps(s, pkt->stream_index, pkt->pts,
 +                                      pkt->pts);
 +            if (pkt->pts == AV_NOPTS_VALUE)
 +                pkt->pts = st->cur_dts;
 +            pkt->dts = pkt->pts;
 +            if (pkt->pts != AV_NOPTS_VALUE)
 +                st->cur_dts = pkt->pts + duration;
          }
      }
  
 -    if(pkt->pts != AV_NOPTS_VALUE && delay <= MAX_REORDER_DELAY){
 +    if(pkt->pts != AV_NOPTS_VALUE && delay <= MAX_REORDER_DELAY && has_decode_delay_been_guessed(st)){
          st->pts_buffer[0]= pkt->pts;
          for(i=0; i<delay && st->pts_buffer[i] > st->pts_buffer[i+1]; i++)
              FFSWAP(int64_t, st->pts_buffer[i], st->pts_buffer[i+1]);
          if(pkt->dts == AV_NOPTS_VALUE)
              pkt->dts= st->pts_buffer[0];
 -        if(st->codec->codec_id == AV_CODEC_ID_H264){ // we skipped it above so we try here
 -            update_initial_timestamps(s, pkt->stream_index, pkt->dts, pkt->pts); // this should happen on the first packet
 -        }
 -        if(pkt->dts > st->cur_dts)
 -            st->cur_dts = pkt->dts;
      }
 +    if(st->codec->codec_id == AV_CODEC_ID_H264){ // we skipped it above so we try here
 +        update_initial_timestamps(s, pkt->stream_index, pkt->dts, pkt->pts); // this should happen on the first packet
 +    }
 +    if(pkt->dts > st->cur_dts)
 +        st->cur_dts = pkt->dts;
  
 -//    av_log(NULL, AV_LOG_ERROR, "OUTdelayed:%d/%d pts:%"PRId64", dts:%"PRId64" cur_dts:%"PRId64"\n", presentation_delayed, delay, pkt->pts, pkt->dts, st->cur_dts);
 +//    av_log(NULL, AV_LOG_ERROR, "OUTdelayed:%d/%d pts:%s, dts:%s cur_dts:%s\n",
 +//           presentation_delayed, delay, av_ts2str(pkt->pts), av_ts2str(pkt->dts), av_ts2str(st->cur_dts));
  
      /* update flags */
 -    if (is_intra_only(st->codec->codec_id))
 +    if (is_intra_only(st->codec))
          pkt->flags |= AV_PKT_FLAG_KEY;
      if (pc)
          pkt->convergence_duration = pc->convergence_duration;
@@@ -1192,9 -1059,6 +1198,9 @@@ static int parse_packet(AVFormatContex
          av_init_packet(&flush_pkt);
          pkt = &flush_pkt;
          got_output = 1;
 +    } else if (!size && st->parser->flags & PARSER_FLAG_COMPLETE_FRAMES) {
 +        // preserve 0-size sync packets
 +        compute_pkt_fields(s, st, st->parser, pkt);
      }
  
      while (size > 0 || (pkt == &flush_pkt && got_output)) {
                                 pkt->pts, pkt->dts, pkt->pos);
  
          pkt->pts = pkt->dts = AV_NOPTS_VALUE;
 +        pkt->pos = -1;
          /* increment read pointer */
          data += len;
          size -= len;
          out_pkt.dts = st->parser->dts;
          out_pkt.pos = st->parser->pos;
  
 +        if(st->need_parsing == AVSTREAM_PARSE_FULL_RAW)
 +            out_pkt.pos = st->parser->frame_offset;
 +
          if (st->parser->key_frame == 1 ||
              (st->parser->key_frame == -1 &&
               st->parser->pict_type == AV_PICTURE_TYPE_I))
              out_pkt.flags |= AV_PKT_FLAG_KEY;
  
 -        compute_pkt_fields(s, st, st->parser, &out_pkt);
 +        if(st->parser->key_frame == -1 && st->parser->pict_type==AV_PICTURE_TYPE_NONE && (pkt->flags&AV_PKT_FLAG_KEY))
 +            out_pkt.flags |= AV_PKT_FLAG_KEY;
  
 -        if ((s->iformat->flags & AVFMT_GENERIC_INDEX) &&
 -            out_pkt.flags & AV_PKT_FLAG_KEY) {
 -            ff_reduce_index(s, st->index);
 -            av_add_index_entry(st, st->parser->frame_offset, out_pkt.dts,
 -                               0, 0, AVINDEX_KEYFRAME);
 -        }
 +        compute_pkt_fields(s, st, st->parser, &out_pkt);
  
          if (out_pkt.data == pkt->data && out_pkt.size == pkt->size) {
              out_pkt.destruct = pkt->destruct;
@@@ -1323,17 -1187,17 +1329,17 @@@ static int read_frame_internal(AVFormat
          if (cur_pkt.pts != AV_NOPTS_VALUE &&
              cur_pkt.dts != AV_NOPTS_VALUE &&
              cur_pkt.pts < cur_pkt.dts) {
 -            av_log(s, AV_LOG_WARNING, "Invalid timestamps stream=%d, pts=%"PRId64", dts=%"PRId64", size=%d\n",
 +            av_log(s, AV_LOG_WARNING, "Invalid timestamps stream=%d, pts=%s, dts=%s, size=%d\n",
                     cur_pkt.stream_index,
 -                   cur_pkt.pts,
 -                   cur_pkt.dts,
 +                   av_ts2str(cur_pkt.pts),
 +                   av_ts2str(cur_pkt.dts),
                     cur_pkt.size);
          }
          if (s->debug & FF_FDEBUG_TS)
 -            av_log(s, AV_LOG_DEBUG, "ff_read_packet stream=%d, pts=%"PRId64", dts=%"PRId64", size=%d, duration=%d, flags=%d\n",
 +            av_log(s, AV_LOG_DEBUG, "ff_read_packet stream=%d, pts=%s, dts=%s, size=%d, duration=%d, flags=%d\n",
                     cur_pkt.stream_index,
 -                   cur_pkt.pts,
 -                   cur_pkt.dts,
 +                   av_ts2str(cur_pkt.pts),
 +                   av_ts2str(cur_pkt.dts),
                     cur_pkt.size,
                     cur_pkt.duration,
                     cur_pkt.flags);
          if (st->need_parsing && !st->parser && !(s->flags & AVFMT_FLAG_NOPARSE)) {
              st->parser = av_parser_init(st->codec->codec_id);
              if (!st->parser) {
 +                av_log(s, AV_LOG_VERBOSE, "parser not found for codec "
 +                       "%s, packets or times may be invalid.\n",
 +                       avcodec_get_name(st->codec->codec_id));
                  /* no parser available: just output the raw packets */
                  st->need_parsing = AVSTREAM_PARSE_NONE;
              } else if(st->need_parsing == AVSTREAM_PARSE_HEADERS) {
                  st->parser->flags |= PARSER_FLAG_COMPLETE_FRAMES;
              } else if(st->need_parsing == AVSTREAM_PARSE_FULL_ONCE) {
                  st->parser->flags |= PARSER_FLAG_ONCE;
 +            } else if(st->need_parsing == AVSTREAM_PARSE_FULL_RAW) {
 +                st->parser->flags |= PARSER_FLAG_USE_CODEC_TS;
              }
          }
  
              /* free packet */
              av_free_packet(&cur_pkt);
          }
 +        if (pkt->flags & AV_PKT_FLAG_KEY)
 +            st->skip_to_keyframe = 0;
 +        if (st->skip_to_keyframe) {
 +            av_free_packet(&cur_pkt);
 +            got_packet = 0;
 +        }
      }
  
      if (!got_packet && s->parse_queue)
          ret = read_from_packet_buffer(&s->parse_queue, &s->parse_queue_end, pkt);
  
      if(s->debug & FF_FDEBUG_TS)
 -        av_log(s, AV_LOG_DEBUG, "read_frame_internal stream=%d, pts=%"PRId64", dts=%"PRId64", size=%d, duration=%d, flags=%d\n",
 +        av_log(s, AV_LOG_DEBUG, "read_frame_internal stream=%d, pts=%s, dts=%s, size=%d, duration=%d, flags=%d\n",
              pkt->stream_index,
 -            pkt->pts,
 -            pkt->dts,
 +            av_ts2str(pkt->pts),
 +            av_ts2str(pkt->dts),
              pkt->size,
              pkt->duration,
              pkt->flags);
@@@ -1399,18 -1252,15 +1405,18 @@@ int av_read_frame(AVFormatContext *s, A
  {
      const int genpts = s->flags & AVFMT_FLAG_GENPTS;
      int          eof = 0;
 +    int ret;
 +    AVStream *st;
  
 -    if (!genpts)
 -        return s->packet_buffer ? read_from_packet_buffer(&s->packet_buffer,
 +    if (!genpts) {
 +        ret = s->packet_buffer ? read_from_packet_buffer(&s->packet_buffer,
                                                            &s->packet_buffer_end,
                                                            pkt) :
                                    read_frame_internal(s, pkt);
 +        goto return_packet;
 +    }
  
      for (;;) {
 -        int ret;
          AVPacketList *pktl = s->packet_buffer;
  
          if (pktl) {
  
              if (next_pkt->dts != AV_NOPTS_VALUE) {
                  int wrap_bits = s->streams[next_pkt->stream_index]->pts_wrap_bits;
 +                // last dts seen for this stream. if any of packets following
 +                // current one had no dts, we will set this to AV_NOPTS_VALUE.
 +                int64_t last_dts = next_pkt->dts;
                  while (pktl && next_pkt->pts == AV_NOPTS_VALUE) {
                      if (pktl->pkt.stream_index == next_pkt->stream_index &&
 -                        (av_compare_mod(next_pkt->dts, pktl->pkt.dts, 2LL << (wrap_bits - 1)) < 0) &&
 -                         av_compare_mod(pktl->pkt.pts, pktl->pkt.dts, 2LL << (wrap_bits - 1))) { //not b frame
 -                        next_pkt->pts = pktl->pkt.dts;
 +                        (av_compare_mod(next_pkt->dts, pktl->pkt.dts, 2LL << (wrap_bits - 1)) < 0)) {
 +                        if (av_compare_mod(pktl->pkt.pts, pktl->pkt.dts, 2LL << (wrap_bits - 1))) { //not b frame
 +                            next_pkt->pts = pktl->pkt.dts;
 +                        }
 +                        if (last_dts != AV_NOPTS_VALUE) {
 +                            // Once last dts was set to AV_NOPTS_VALUE, we don't change it.
 +                            last_dts = pktl->pkt.dts;
 +                        }
                      }
                      pktl = pktl->next;
                  }
 +                if (eof && next_pkt->pts == AV_NOPTS_VALUE && last_dts != AV_NOPTS_VALUE) {
 +                    // Fixing the last reference frame had none pts issue (For MXF etc).
 +                    // We only do this when
 +                    // 1. eof.
 +                    // 2. we are not able to resolve a pts value for current packet.
 +                    // 3. the packets for this stream at the end of the files had valid dts.
 +                    next_pkt->pts = last_dts + next_pkt->duration;
 +                }
                  pktl = s->packet_buffer;
              }
  
              /* read packet from packet buffer, if there is data */
              if (!(next_pkt->pts == AV_NOPTS_VALUE &&
 -                  next_pkt->dts != AV_NOPTS_VALUE && !eof))
 -                return read_from_packet_buffer(&s->packet_buffer,
 +                  next_pkt->dts != AV_NOPTS_VALUE && !eof)) {
 +                ret = read_from_packet_buffer(&s->packet_buffer,
                                                 &s->packet_buffer_end, pkt);
 +                goto return_packet;
 +            }
          }
  
          ret = read_frame_internal(s, pkt);
                            &s->packet_buffer_end)) < 0)
              return AVERROR(ENOMEM);
      }
 +
 +return_packet:
 +
 +    st = s->streams[pkt->stream_index];
 +    if (st->skip_samples) {
 +        uint8_t *p = av_packet_new_side_data(pkt, AV_PKT_DATA_SKIP_SAMPLES, 10);
 +        AV_WL32(p, st->skip_samples);
 +        av_log(s, AV_LOG_DEBUG, "demuxer injecting skip %d\n", st->skip_samples);
 +        st->skip_samples = 0;
 +    }
 +
 +    if ((s->iformat->flags & AVFMT_GENERIC_INDEX) && pkt->flags & AV_PKT_FLAG_KEY) {
 +        ff_reduce_index(s, st->index);
 +        av_add_index_entry(st, pkt->pos, pkt->dts, 0, 0, AVINDEX_KEYFRAME);
 +    }
 +
 +    if (is_relative(pkt->dts))
 +        pkt->dts -= RELATIVE_TS_BASE;
 +    if (is_relative(pkt->pts))
 +        pkt->pts -= RELATIVE_TS_BASE;
 +
 +    return ret;
  }
  
  /* XXX: suppress the packet queue */
@@@ -1543,8 -1353,7 +1549,8 @@@ void ff_read_frame_flush(AVFormatContex
              st->parser = NULL;
          }
          st->last_IP_pts = AV_NOPTS_VALUE;
 -        st->cur_dts = AV_NOPTS_VALUE; /* we set the current DTS to an unspecified origin */
 +        if(st->first_dts == AV_NOPTS_VALUE) st->cur_dts = RELATIVE_TS_BASE;
 +        else                                st->cur_dts = AV_NOPTS_VALUE; /* we set the current DTS to an unspecified origin */
          st->reference_dts = AV_NOPTS_VALUE;
  
          st->probe_packets = MAX_PROBE_PACKETS;
@@@ -1591,12 -1400,6 +1597,12 @@@ int ff_add_index_entry(AVIndexEntry **i
      if((unsigned)*nb_index_entries + 1 >= UINT_MAX / sizeof(AVIndexEntry))
          return -1;
  
 +    if(timestamp == AV_NOPTS_VALUE)
 +        return AVERROR(EINVAL);
 +
 +    if (is_relative(timestamp)) //FIXME this maintains previous behavior but we should shift by the correct offset once known
 +        timestamp -= RELATIVE_TS_BASE;
 +
      entries = av_fast_realloc(*index_entries,
                                index_entries_allocated_size,
                                (*nb_index_entries + 1) *
@@@ -1693,7 -1496,7 +1699,7 @@@ int ff_seek_frame_binary(AVFormatContex
      if (stream_index < 0)
          return -1;
  
 -    av_dlog(s, "read_seek: %d %"PRId64"\n", stream_index, target_ts);
 +    av_dlog(s, "read_seek: %d %s\n", stream_index, av_ts2str(target_ts));
  
      ts_max=
      ts_min= AV_NOPTS_VALUE;
          if(e->timestamp <= target_ts || e->pos == e->min_distance){
              pos_min= e->pos;
              ts_min= e->timestamp;
 -            av_dlog(s, "using cached pos_min=0x%"PRIx64" dts_min=%"PRId64"\n",
 -                    pos_min,ts_min);
 +            av_dlog(s, "using cached pos_min=0x%"PRIx64" dts_min=%s\n",
 +                    pos_min, av_ts2str(ts_min));
          }else{
              assert(index==0);
          }
              pos_max= e->pos;
              ts_max= e->timestamp;
              pos_limit= pos_max - e->min_distance;
 -            av_dlog(s, "using cached pos_max=0x%"PRIx64" pos_limit=0x%"PRIx64" dts_max=%"PRId64"\n",
 -                    pos_max,pos_limit, ts_max);
 +            av_dlog(s, "using cached pos_max=0x%"PRIx64" pos_limit=0x%"PRIx64" dts_max=%s\n",
 +                    pos_max, pos_limit, av_ts2str(ts_max));
          }
      }
  
      if ((ret = avio_seek(s->pb, pos, SEEK_SET)) < 0)
          return ret;
  
 +    ff_read_frame_flush(s);
      ff_update_cur_dts(s, st, ts);
  
      return 0;
@@@ -1752,7 -1554,7 +1758,7 @@@ int64_t ff_gen_search(AVFormatContext *
      int64_t start_pos, filesize;
      int no_change;
  
 -    av_dlog(s, "gen_seek: %d %"PRId64"\n", stream_index, target_ts);
 +    av_dlog(s, "gen_seek: %d %s\n", stream_index, av_ts2str(target_ts));
  
      if(ts_min == AV_NOPTS_VALUE){
          pos_min = s->data_offset;
              return -1;
      }
  
 +    if(ts_min >= target_ts){
 +        *ts_ret= ts_min;
 +        return pos_min;
 +    }
 +
      if(ts_max == AV_NOPTS_VALUE){
          int step= 1024;
          filesize = avio_size(s->pb);
          pos_limit= pos_max;
      }
  
 +    if(ts_max <= target_ts){
 +        *ts_ret= ts_max;
 +        return pos_max;
 +    }
 +
      if(ts_min > ts_max){
          return -1;
      }else if(ts_min == ts_max){
  
      no_change=0;
      while (pos_min < pos_limit) {
 -        av_dlog(s, "pos_min=0x%"PRIx64" pos_max=0x%"PRIx64" dts_min=%"PRId64" dts_max=%"PRId64"\n",
 -                pos_min, pos_max, ts_min, ts_max);
 +        av_dlog(s, "pos_min=0x%"PRIx64" pos_max=0x%"PRIx64" dts_min=%s dts_max=%s\n",
 +                pos_min, pos_max, av_ts2str(ts_min), av_ts2str(ts_max));
          assert(pos_limit <= pos_max);
  
          if(no_change==0){
              no_change++;
          else
              no_change=0;
 -        av_dlog(s, "%"PRId64" %"PRId64" %"PRId64" / %"PRId64" %"PRId64" %"PRId64" target:%"PRId64" limit:%"PRId64" start:%"PRId64" noc:%d\n",
 -                pos_min, pos, pos_max, ts_min, ts, ts_max, target_ts,
 +        av_dlog(s, "%"PRId64" %"PRId64" %"PRId64" / %s %s %s target:%s limit:%"PRId64" start:%"PRId64" noc:%d\n",
 +                pos_min, pos, pos_max,
 +                av_ts2str(ts_min), av_ts2str(ts), av_ts2str(ts_max), av_ts2str(target_ts),
                  pos_limit, start_pos, no_change);
          if(ts == AV_NOPTS_VALUE){
              av_log(s, AV_LOG_ERROR, "read_timestamp() failed in the middle\n");
  
      pos = (flags & AVSEEK_FLAG_BACKWARD) ? pos_min : pos_max;
      ts  = (flags & AVSEEK_FLAG_BACKWARD) ?  ts_min :  ts_max;
 +#if 0
      pos_min = pos;
      ts_min = read_timestamp(s, stream_index, &pos_min, INT64_MAX);
      pos_min++;
      ts_max = read_timestamp(s, stream_index, &pos_min, INT64_MAX);
 -    av_dlog(s, "pos=0x%"PRIx64" %"PRId64"<=%"PRId64"<=%"PRId64"\n",
 -            pos, ts_min, target_ts, ts_max);
 +    av_dlog(s, "pos=0x%"PRIx64" %s<=%s<=%s\n",
 +            pos, av_ts2str(ts_min), av_ts2str(target_ts), av_ts2str(ts_max));
 +#endif
      *ts_ret= ts;
      return pos;
  }
@@@ -1897,7 -1686,6 +1903,7 @@@ static int seek_frame_generic(AVFormatC
  
      if(index < 0 || index==st->nb_index_entries-1){
          AVPacket pkt;
 +        int nonkey=0;
  
          if(st->nb_index_entries){
              assert(st->index_entries);
              if (read_status < 0)
                  break;
              av_free_packet(&pkt);
 -            if(stream_index == pkt.stream_index){
 -                if((pkt.flags & AV_PKT_FLAG_KEY) && pkt.dts > timestamp)
 +            if(stream_index == pkt.stream_index && pkt.dts > timestamp){
 +                if(pkt.flags & AV_PKT_FLAG_KEY)
                      break;
 +                if(nonkey++ > 1000 && st->codec->codec_id != AV_CODEC_ID_CDGRAPHICS){
 +                    av_log(s, AV_LOG_ERROR,"seek_frame_generic failed as this stream seems to contain no keyframes after the target timestamp, %d non keyframes found\n", nonkey);
 +                    break;
 +                }
              }
          }
          index = av_index_search_timestamp(st, timestamp, flags);
@@@ -1993,7 -1777,7 +1999,7 @@@ int av_seek_frame(AVFormatContext *s, i
      int ret = seek_frame_internal(s, stream_index, timestamp, flags);
  
      if (ret >= 0)
 -        queue_attached_pictures(s);
 +        avformat_queue_attached_pictures(s);
  
      return ret;
  }
@@@ -2009,7 -1793,7 +2015,7 @@@ int avformat_seek_file(AVFormatContext 
          ret = s->iformat->read_seek2(s, stream_index, min_ts, ts, max_ts, flags);
  
          if (ret >= 0)
 -            queue_attached_pictures(s);
 +            avformat_queue_attached_pictures(s);
          return ret;
      }
  
      }
  
      //Fallback to old API if new is not implemented but old is
 -    //Note the old has somewat different sematics
 -    if(s->iformat->read_seek || 1)
 -        return av_seek_frame(s, stream_index, ts, flags | (ts - min_ts > (uint64_t)(max_ts - ts) ? AVSEEK_FLAG_BACKWARD : 0));
 +    //Note the old has somewhat different semantics
 +    if (s->iformat->read_seek || 1) {
 +        int dir = (ts - (uint64_t)min_ts > (uint64_t)max_ts - ts ? AVSEEK_FLAG_BACKWARD : 0);
 +        int ret = av_seek_frame(s, stream_index, ts, flags | dir);
 +        if (ret<0 && ts != min_ts && max_ts != ts) {
 +            ret = av_seek_frame(s, stream_index, dir ? max_ts : min_ts, flags | dir);
 +            if (ret >= 0)
 +                ret = av_seek_frame(s, stream_index, ts, flags | (dir^AVSEEK_FLAG_BACKWARD));
 +        }
 +        return ret;
 +    }
  
      // try some generic seek like seek_frame_generic() but with new ts semantics
  }
@@@ -2062,24 -1838,19 +2068,24 @@@ static int has_duration(AVFormatContex
   */
  static void update_stream_timings(AVFormatContext *ic)
  {
 -    int64_t start_time, start_time1, end_time, end_time1;
 +    int64_t start_time, start_time1, start_time_text, end_time, end_time1;
      int64_t duration, duration1, filesize;
      int i;
      AVStream *st;
  
      start_time = INT64_MAX;
 +    start_time_text = INT64_MAX;
      end_time = INT64_MIN;
      duration = INT64_MIN;
      for(i = 0;i < ic->nb_streams; i++) {
          st = ic->streams[i];
          if (st->start_time != AV_NOPTS_VALUE && st->time_base.den) {
              start_time1= av_rescale_q(st->start_time, st->time_base, AV_TIME_BASE_Q);
 -            start_time = FFMIN(start_time, start_time1);
 +            if (st->codec->codec_type == AVMEDIA_TYPE_SUBTITLE || st->codec->codec_type == AVMEDIA_TYPE_DATA) {
 +                if (start_time1 < start_time_text)
 +                    start_time_text = start_time1;
 +            } else
 +                start_time = FFMIN(start_time, start_time1);
              if (st->duration != AV_NOPTS_VALUE) {
                  end_time1 = start_time1
                            + av_rescale_q(st->duration, st->time_base, AV_TIME_BASE_Q);
              duration = FFMAX(duration, duration1);
          }
      }
 +    if (start_time == INT64_MAX || (start_time > start_time_text && start_time - start_time_text < AV_TIME_BASE))
 +        start_time = start_time_text;
 +    else if(start_time > start_time_text)
 +        av_log(ic, AV_LOG_VERBOSE, "Ignoring outlier non primary stream starttime %f\n", start_time_text / (float)AV_TIME_BASE);
 +
      if (start_time != INT64_MAX) {
          ic->start_time = start_time;
          if (end_time != INT64_MIN)
              duration = FFMAX(duration, end_time - start_time);
      }
 -    if (duration != INT64_MIN) {
 +    if (duration != INT64_MIN && duration > 0 && ic->duration == AV_NOPTS_VALUE) {
          ic->duration = duration;
 -        if (ic->pb && (filesize = avio_size(ic->pb)) > 0) {
 +    }
 +        if (ic->pb && (filesize = avio_size(ic->pb)) > 0 && ic->duration != AV_NOPTS_VALUE) {
              /* compute the bitrate */
              ic->bit_rate = (double)filesize * 8.0 * AV_TIME_BASE /
                  (double)ic->duration;
          }
 -    }
  }
  
  static void fill_all_stream_timings(AVFormatContext *ic)
@@@ -2258,17 -2024,14 +2264,17 @@@ static void estimate_timings(AVFormatCo
          file_size && ic->pb->seekable) {
          /* get accurate estimate from the PTSes */
          estimate_timings_from_pts(ic, old_offset);
 +        ic->duration_estimation_method = AVFMT_DURATION_FROM_PTS;
      } else if (has_duration(ic)) {
          /* at least one component has timings - we use them for all
             the components */
          fill_all_stream_timings(ic);
 +        ic->duration_estimation_method = AVFMT_DURATION_FROM_STREAM;
      } else {
          av_log(ic, AV_LOG_WARNING, "Estimating duration from bitrate, this may be inaccurate\n");
          /* less precise: use bitrate info */
          estimate_timings_from_bit_rate(ic);
 +        ic->duration_estimation_method = AVFMT_DURATION_FROM_BITRATE;
      }
      update_stream_timings(ic);
  
      }
  }
  
 -static int has_codec_parameters(AVStream *st)
 +static int has_codec_parameters(AVStream *st, const char **errmsg_ptr)
  {
      AVCodecContext *avctx = st->codec;
 -    int val;
 +
 +#define FAIL(errmsg) do {                                         \
 +        if (errmsg_ptr)                                           \
 +            *errmsg_ptr = errmsg;                                 \
 +        return 0;                                                 \
 +    } while (0)
 +
      switch (avctx->codec_type) {
      case AVMEDIA_TYPE_AUDIO:
 -        val = avctx->sample_rate && avctx->channels;
 +        if (!avctx->frame_size && determinable_frame_size(avctx))
 +            FAIL("unspecified frame size");
          if (st->info->found_decoder >= 0 && avctx->sample_fmt == AV_SAMPLE_FMT_NONE)
 -            return 0;
 +            FAIL("unspecified sample format");
 +        if (!avctx->sample_rate)
 +            FAIL("unspecified sample rate");
 +        if (!avctx->channels)
 +            FAIL("unspecified number of channels");
          break;
      case AVMEDIA_TYPE_VIDEO:
 -        val = avctx->width;
 +        if (!avctx->width)
 +            FAIL("unspecified size");
          if (st->info->found_decoder >= 0 && avctx->pix_fmt == PIX_FMT_NONE)
 -            return 0;
 +            FAIL("unspecified pixel format");
          break;
 -    default:
 -        val = 1;
 +    case AVMEDIA_TYPE_SUBTITLE:
 +        if (avctx->codec_id == AV_CODEC_ID_HDMV_PGS_SUBTITLE && !avctx->width)
 +            FAIL("unspecified size");
          break;
 +    case AVMEDIA_TYPE_DATA:
 +        if(avctx->codec_id == AV_CODEC_ID_NONE) return 1;
      }
 -    return avctx->codec_id != AV_CODEC_ID_NONE && val != 0;
 -}
  
 -static int has_decode_delay_been_guessed(AVStream *st)
 -{
 -    return st->codec->codec_id != AV_CODEC_ID_H264 ||
 -        st->info->nb_decoded_frames >= 6;
 +    if (avctx->codec_id == AV_CODEC_ID_NONE)
 +        FAIL("unknown codec");
 +    return 1;
  }
  
  /* returns 1 or 0 if or if not decoded data was returned, or a negative error */
@@@ -2334,7 -2085,6 +2340,7 @@@ static int try_decode_frame(AVStream *s
      const AVCodec *codec;
      int got_picture = 1, ret = 0;
      AVFrame picture;
 +    AVSubtitle subtitle;
      AVPacket pkt = *avpkt;
  
      if (!avcodec_is_open(st->codec) && !st->info->found_decoder) {
  
      while ((pkt.size > 0 || (!pkt.data && got_picture)) &&
             ret >= 0 &&
 -           (!has_codec_parameters(st)         ||
 +           (!has_codec_parameters(st, NULL)   ||
             !has_decode_delay_been_guessed(st) ||
             (!st->codec_info_nb_frames && st->codec->codec->capabilities & CODEC_CAP_CHANNEL_CONF))) {
          got_picture = 0;
          case AVMEDIA_TYPE_AUDIO:
              ret = avcodec_decode_audio4(st->codec, &picture, &got_picture, &pkt);
              break;
 +        case AVMEDIA_TYPE_SUBTITLE:
 +            ret = avcodec_decode_subtitle2(st->codec, &subtitle,
 +                                           &got_picture, &pkt);
 +            ret = pkt.size;
 +            break;
          default:
              break;
          }
          if (ret >= 0) {
              if (got_picture)
 -                st->info->nb_decoded_frames++;
 +                st->nb_decoded_frames++;
              pkt.data += ret;
              pkt.size -= ret;
              ret       = got_picture;
          }
      }
 +    if(!pkt.data && !got_picture)
 +        return -1;
      return ret;
  }
  
@@@ -2467,8 -2210,8 +2473,8 @@@ static void compute_chapters_end(AVForm
  }
  
  static int get_std_framerate(int i){
 -    if(i<60*12) return i*1001;
 -    else        return ((const int[]){24,30,60,12,15})[i-60*12]*1000*12;
 +    if(i<60*12) return (i+1)*1001;
 +    else        return ((const int[]){24,30,60,12,15,48})[i-60*12]*1000*12;
  }
  
  /*
@@@ -2491,13 -2234,6 +2497,13 @@@ static int tb_unreliable(AVCodecContex
      return 0;
  }
  
 +#if FF_API_FORMAT_PARAMETERS
 +int av_find_stream_info(AVFormatContext *ic)
 +{
 +    return avformat_find_stream_info(ic, NULL);
 +}
 +#endif
 +
  int avformat_find_stream_info(AVFormatContext *ic, AVDictionary **options)
  {
      int i, count, ret, read_size, j;
      AVPacket pkt1, *pkt;
      int64_t old_offset = avio_tell(ic->pb);
      int orig_nb_streams = ic->nb_streams;        // new streams might appear, no options for those
 +    int flush_codecs = ic->probesize > 0;
 +
 +    if(ic->pb)
 +        av_log(ic, AV_LOG_DEBUG, "File position before avformat_find_stream_info() is %"PRId64"\n", avio_tell(ic->pb));
  
      for(i=0;i<ic->nb_streams;i++) {
          const AVCodec *codec;
          AVDictionary *thread_opt = NULL;
          st = ic->streams[i];
  
 +        if (st->codec->codec_type == AVMEDIA_TYPE_VIDEO ||
 +            st->codec->codec_type == AVMEDIA_TYPE_SUBTITLE) {
 +/*            if(!st->time_base.num)
 +                st->time_base= */
 +            if(!st->codec->time_base.num)
 +                st->codec->time_base= st->time_base;
 +        }
          //only for the split stuff
          if (!st->parser && !(ic->flags & AVFMT_FLAG_NOPARSE)) {
              st->parser = av_parser_init(st->codec->codec_id);
 -            if(st->need_parsing == AVSTREAM_PARSE_HEADERS && st->parser){
 -                st->parser->flags |= PARSER_FLAG_COMPLETE_FRAMES;
 +            if(st->parser){
 +                if(st->need_parsing == AVSTREAM_PARSE_HEADERS){
 +                    st->parser->flags |= PARSER_FLAG_COMPLETE_FRAMES;
 +                } else if(st->need_parsing == AVSTREAM_PARSE_FULL_RAW) {
 +                    st->parser->flags |= PARSER_FLAG_USE_CODEC_TS;
 +                }
 +            } else if (st->need_parsing) {
 +                av_log(ic, AV_LOG_VERBOSE, "parser not found for codec "
 +                       "%s, packets or times may be invalid.\n",
 +                       avcodec_get_name(st->codec->codec_id));
              }
          }
          codec = st->codec->codec ? st->codec->codec :
                                : &thread_opt);
  
          //try to just open decoders, in case this is enough to get parameters
 -        if (!has_codec_parameters(st)) {
 +        if (!has_codec_parameters(st, NULL)) {
              if (codec && !st->codec->codec)
                  avcodec_open2(st->codec, codec, options ? &options[i]
                                : &thread_opt);
              int fps_analyze_framecount = 20;
  
              st = ic->streams[i];
 -            if (!has_codec_parameters(st))
 +            if (!has_codec_parameters(st, NULL))
                  break;
              /* if the timebase is coarse (like the usual millisecond precision
                 of mkv), we need to analyze more frames to reliably arrive at
              if (ic->fps_probe_size >= 0)
                  fps_analyze_framecount = ic->fps_probe_size;
              /* variable fps and no guess at the real fps */
 -            if(   tb_unreliable(st->codec) && !st->avg_frame_rate.num
 -               && st->codec_info_nb_frames < fps_analyze_framecount
 +            if(   tb_unreliable(st->codec) && !(st->r_frame_rate.num && st->avg_frame_rate.num)
 +               && st->info->duration_count < fps_analyze_framecount
                 && st->codec->codec_type == AVMEDIA_TYPE_VIDEO)
                  break;
              if(st->parser && st->parser->parser->split && !st->codec->extradata)
                  /* if we found the info for all the codecs, we can stop */
                  ret = count;
                  av_log(ic, AV_LOG_DEBUG, "All info found\n");
 +                flush_codecs = 0;
                  break;
              }
          }
          if (read_size >= ic->probesize) {
              ret = count;
              av_log(ic, AV_LOG_DEBUG, "Probe buffer size limit %d reached\n", ic->probesize);
 +            for (i = 0; i < ic->nb_streams; i++)
 +                if (!ic->streams[i]->r_frame_rate.num &&
 +                    ic->streams[i]->info->duration_count <= 1)
 +                    av_log(ic, AV_LOG_WARNING,
 +                           "Stream #%d: not enough frames to estimate rate; "
 +                           "consider increasing probesize\n", i);
              break;
          }
  
  
          if (ret < 0) {
              /* EOF or error*/
 -            AVPacket empty_pkt = { 0 };
 -            int err = 0;
 -            av_init_packet(&empty_pkt);
 -
 -            ret = -1; /* we could not have all the codec parameters before EOF */
 -            for(i=0;i<ic->nb_streams;i++) {
 -                st = ic->streams[i];
 -
 -                /* flush the decoders */
 -                if (st->info->found_decoder == 1) {
 -                    do {
 -                        err = try_decode_frame(st, &empty_pkt,
 -                                               (options && i < orig_nb_streams) ?
 -                                               &options[i] : NULL);
 -                    } while (err > 0 && !has_codec_parameters(st));
 -                }
 -
 -                if (err < 0) {
 -                    av_log(ic, AV_LOG_WARNING,
 -                           "decoding for stream %d failed\n", st->index);
 -                } else if (!has_codec_parameters(st)) {
 -                    char buf[256];
 -                    avcodec_string(buf, sizeof(buf), st->codec, 0);
 -                    av_log(ic, AV_LOG_WARNING,
 -                           "Could not find codec parameters (%s)\n", buf);
 -                } else {
 -                    ret = 0;
 -                }
 -            }
              break;
          }
  
              /* check for non-increasing dts */
              if (st->info->fps_last_dts != AV_NOPTS_VALUE &&
                  st->info->fps_last_dts >= pkt->dts) {
 -                av_log(ic, AV_LOG_WARNING, "Non-increasing DTS in stream %d: "
 +                av_log(ic, AV_LOG_DEBUG, "Non-increasing DTS in stream %d: "
                         "packet %d with DTS %"PRId64", packet %d with DTS "
                         "%"PRId64"\n", st->index, st->info->fps_last_dts_idx,
                         st->info->fps_last_dts, st->codec_info_nb_frames, pkt->dts);
              }
              st->info->fps_last_dts = pkt->dts;
              st->info->fps_last_dts_idx = st->codec_info_nb_frames;
 -
 -            /* check max_analyze_duration */
 -            if (av_rescale_q(pkt->dts - st->info->fps_first_dts, st->time_base,
 -                             AV_TIME_BASE_Q) >= ic->max_analyze_duration) {
 -                av_log(ic, AV_LOG_WARNING, "max_analyze_duration reached\n");
 +        }
 +        if (st->codec_info_nb_frames>1) {
 +            int64_t t=0;
 +            if (st->time_base.den > 0)
 +                t = av_rescale_q(st->info->codec_info_duration, st->time_base, AV_TIME_BASE_Q);
 +            if (st->avg_frame_rate.num > 0)
 +                t = FFMAX(t, av_rescale_q(st->codec_info_nb_frames, av_inv_q(st->avg_frame_rate), AV_TIME_BASE_Q));
 +
 +            if (t >= ic->max_analyze_duration) {
 +                av_log(ic, AV_LOG_WARNING, "max_analyze_duration %d reached at %"PRId64"\n", ic->max_analyze_duration, t);
                  break;
              }
 +            st->info->codec_info_duration += pkt->duration;
          }
  #if FF_API_R_FRAME_RATE
          {
              int64_t last = st->info->last_dts;
  
              if(pkt->dts != AV_NOPTS_VALUE && last != AV_NOPTS_VALUE && pkt->dts > last){
 +                double dts= (is_relative(pkt->dts) ?  pkt->dts - RELATIVE_TS_BASE : pkt->dts) * av_q2d(st->time_base);
                  int64_t duration= pkt->dts - last;
 -                double dur= duration * av_q2d(st->time_base);
  
 -                if (st->info->duration_count < 2)
 -                    memset(st->info->duration_error, 0, sizeof(st->info->duration_error));
 -                for (i=1; i<FF_ARRAY_ELEMS(st->info->duration_error); i++) {
 +//                 if(st->codec->codec_type == AVMEDIA_TYPE_VIDEO)
 +//                     av_log(NULL, AV_LOG_ERROR, "%f\n", dts);
 +                for (i=0; i<FF_ARRAY_ELEMS(st->info->duration_error[0][0]); i++) {
                      int framerate= get_std_framerate(i);
 -                    int ticks= lrintf(dur*framerate/(1001*12));
 -                    double error = dur - (double)ticks*1001*12 / framerate;
 -                    st->info->duration_error[i] += error*error;
 +                    double sdts= dts*framerate/(1001*12);
 +                    for(j=0; j<2; j++){
 +                        int ticks= lrintf(sdts+j*0.5);
 +                        double error= sdts - ticks + j*0.5;
 +                        st->info->duration_error[j][0][i] += error;
 +                        st->info->duration_error[j][1][i] += error*error;
 +                    }
                  }
                  st->info->duration_count++;
                  // ignore the first 4 values, they might have some random jitter
                  if (st->info->duration_count > 3)
                      st->info->duration_gcd = av_gcd(st->info->duration_gcd, duration);
              }
 -            if (last == AV_NOPTS_VALUE || st->info->duration_count <= 1)
 +            if (pkt->dts != AV_NOPTS_VALUE)
                  st->info->last_dts = pkt->dts;
          }
  #endif
          count++;
      }
  
 +    if (flush_codecs) {
 +        AVPacket empty_pkt = { 0 };
 +        int err = 0;
 +        av_init_packet(&empty_pkt);
 +
 +        ret = -1; /* we could not have all the codec parameters before EOF */
 +        for(i=0;i<ic->nb_streams;i++) {
 +            const char *errmsg;
 +
 +            st = ic->streams[i];
 +
 +            /* flush the decoders */
 +            if (st->info->found_decoder == 1) {
 +                do {
 +                    err = try_decode_frame(st, &empty_pkt,
 +                                            (options && i < orig_nb_streams) ?
 +                                            &options[i] : NULL);
 +                } while (err > 0 && !has_codec_parameters(st, NULL));
 +
 +                if (err < 0) {
 +                    av_log(ic, AV_LOG_INFO,
 +                        "decoding for stream %d failed\n", st->index);
 +                }
 +            }
 +
 +            if (!has_codec_parameters(st, &errmsg)) {
 +                char buf[256];
 +                avcodec_string(buf, sizeof(buf), st->codec, 0);
 +                av_log(ic, AV_LOG_WARNING,
 +                       "Could not find codec parameters for stream %d (%s): %s\n"
 +                       "Consider increasing the value for the 'analyzeduration' and 'probesize' options\n",
 +                       i, buf, errmsg);
 +            } else {
 +                ret = 0;
 +            }
 +        }
 +    }
 +
      // close codecs which were opened in try_decode_frame()
      for(i=0;i<ic->nb_streams;i++) {
          st = ic->streams[i];
      for(i=0;i<ic->nb_streams;i++) {
          st = ic->streams[i];
          if (st->codec->codec_type == AVMEDIA_TYPE_VIDEO) {
 +            if(st->codec->codec_id == AV_CODEC_ID_RAWVIDEO && !st->codec->codec_tag && !st->codec->bits_per_coded_sample){
 +                uint32_t tag= avcodec_pix_fmt_to_codec_tag(st->codec->pix_fmt);
 +                if(ff_find_pix_fmt(ff_raw_pix_fmt_tags, tag) == st->codec->pix_fmt)
 +                    st->codec->codec_tag= tag;
 +            }
 +
              /* estimate average framerate if not set by demuxer */
 -            if (!st->avg_frame_rate.num && st->info->fps_last_dts != st->info->fps_first_dts) {
 -                int64_t delta_dts = st->info->fps_last_dts - st->info->fps_first_dts;
 -                int delta_packets = st->info->fps_last_dts_idx - st->info->fps_first_dts_idx;
 +            if (st->codec_info_nb_frames>2 && !st->avg_frame_rate.num && st->info->codec_info_duration) {
                  int      best_fps = 0;
                  double best_error = 0.01;
  
                  av_reduce(&st->avg_frame_rate.num, &st->avg_frame_rate.den,
 -                          delta_packets*(int64_t)st->time_base.den,
 -                          delta_dts*(int64_t)st->time_base.num, 60000);
 +                          (st->codec_info_nb_frames-2)*(int64_t)st->time_base.den,
 +                          st->info->codec_info_duration*(int64_t)st->time_base.num, 60000);
  
                  /* round guessed framerate to a "standard" framerate if it's
                   * within 1% of the original estimate*/
                                best_fps, 12*1001, INT_MAX);
                  }
              }
 -#if FF_API_R_FRAME_RATE
              // the check for tb_unreliable() is not completely correct, since this is not about handling
              // a unreliable/inexact time base, but a time base that is finer than necessary, as e.g.
              // ipmovie.c produces.
 -            if (tb_unreliable(st->codec) && st->info->duration_count > 15 && st->info->duration_gcd > 1 && !st->r_frame_rate.num)
 +            if (tb_unreliable(st->codec) && st->info->duration_count > 15 && st->info->duration_gcd > FFMAX(1, st->time_base.den/(500LL*st->time_base.num)) && !st->r_frame_rate.num)
                  av_reduce(&st->r_frame_rate.num, &st->r_frame_rate.den, st->time_base.den, st->time_base.num * st->info->duration_gcd, INT_MAX);
              if (st->info->duration_count && !st->r_frame_rate.num
                  && tb_unreliable(st->codec)) {
                  int num = 0;
 -                double best_error= 2*av_q2d(st->time_base);
 -                best_error = best_error*best_error*st->info->duration_count*1000*12*30;
 -
 -                for (j=1; j<FF_ARRAY_ELEMS(st->info->duration_error); j++) {
 -                    double error = st->info->duration_error[j] * get_std_framerate(j);
 -                    if(error < best_error){
 -                        best_error= error;
 -                        num = get_std_framerate(j);
 +                double best_error= 0.01;
 +
 +                for (j=0; j<FF_ARRAY_ELEMS(st->info->duration_error[0][0]); j++) {
 +                    int k;
 +
 +                    if(st->info->codec_info_duration && st->info->codec_info_duration*av_q2d(st->time_base) < (1001*12.0)/get_std_framerate(j))
 +                        continue;
 +                    if(!st->info->codec_info_duration && 1.0 < (1001*12.0)/get_std_framerate(j))
 +                        continue;
 +                    for(k=0; k<2; k++){
 +                        int n= st->info->duration_count;
 +                        double a= st->info->duration_error[k][0][j] / n;
 +                        double error= st->info->duration_error[k][1][j]/n - a*a;
 +
 +                        if(error < best_error && best_error> 0.000000001){
 +                            best_error= error;
 +                            num = get_std_framerate(j);
 +                        }
 +                        if(error < 0.02)
 +                            av_log(NULL, AV_LOG_DEBUG, "rfps: %f %f\n", get_std_framerate(j) / 12.0/1001, error);
                      }
                  }
                  // do not increase frame rate by more than 1 % in order to match a standard rate.
                  if (num && (!st->r_frame_rate.num || (double)num/(12*1001) < 1.01 * av_q2d(st->r_frame_rate)))
                      av_reduce(&st->r_frame_rate.num, &st->r_frame_rate.den, num, 12*1001, INT_MAX);
              }
 -#endif
 +
 +            if (!st->r_frame_rate.num){
 +                if(    st->codec->time_base.den * (int64_t)st->time_base.num
 +                    <= st->codec->time_base.num * st->codec->ticks_per_frame * (int64_t)st->time_base.den){
 +                    st->r_frame_rate.num = st->codec->time_base.den;
 +                    st->r_frame_rate.den = st->codec->time_base.num * st->codec->ticks_per_frame;
 +                }else{
 +                    st->r_frame_rate.num = st->time_base.den;
 +                    st->r_frame_rate.den = st->time_base.num;
 +                }
 +            }
          }else if(st->codec->codec_type == AVMEDIA_TYPE_AUDIO) {
              if(!st->codec->bits_per_coded_sample)
                  st->codec->bits_per_coded_sample= av_get_bits_per_sample(st->codec->codec_id);
          }
      }
  
 +    if(ic->probesize)
      estimate_timings(ic, old_offset);
  
      compute_chapters_end(ic);
              ic->streams[i]->codec->thread_count = 0;
          av_freep(&ic->streams[i]->info);
      }
 +    if(ic->pb)
 +        av_log(ic, AV_LOG_DEBUG, "File position after avformat_find_stream_info() is %"PRId64"\n", avio_tell(ic->pb));
      return ret;
  }
  
 -static AVProgram *find_program_from_stream(AVFormatContext *ic, int s)
 +AVProgram *av_find_program_from_stream(AVFormatContext *ic, AVProgram *last, int s)
  {
      int i, j;
  
 -    for (i = 0; i < ic->nb_programs; i++)
 -        for (j = 0; j < ic->programs[i]->nb_stream_indexes; j++)
 -            if (ic->programs[i]->stream_index[j] == s)
 -                return ic->programs[i];
 +    for (i = 0; i < ic->nb_programs; i++) {
 +        if (ic->programs[i] == last) {
 +            last = NULL;
 +        } else {
 +            if (!last)
 +                for (j = 0; j < ic->programs[i]->nb_stream_indexes; j++)
 +                    if (ic->programs[i]->stream_index[j] == s)
 +                        return ic->programs[i];
 +        }
 +    }
      return NULL;
  }
  
@@@ -2939,7 -2596,7 +2945,7 @@@ int av_find_best_stream(AVFormatContex
      AVCodec *decoder = NULL, *best_decoder = NULL;
  
      if (related_stream >= 0 && wanted_stream_nb < 0) {
 -        AVProgram *p = find_program_from_stream(ic, related_stream);
 +        AVProgram *p = av_find_program_from_stream(ic, NULL, related_stream);
          if (p) {
              program = p->stream_index;
              nb_streams = p->nb_stream_indexes;
@@@ -2999,35 -2656,31 +3005,35 @@@ int av_read_pause(AVFormatContext *s
      return AVERROR(ENOSYS);
  }
  
 +void ff_free_stream(AVFormatContext *s, AVStream *st){
 +    av_assert0(s->nb_streams>0);
 +    av_assert0(s->streams[ s->nb_streams-1 ] == st);
 +
 +    if (st->parser) {
 +        av_parser_close(st->parser);
 +    }
 +    if (st->attached_pic.data)
 +        av_free_packet(&st->attached_pic);
 +    av_dict_free(&st->metadata);
 +    av_freep(&st->index_entries);
 +    av_freep(&st->codec->extradata);
 +    av_freep(&st->codec->subtitle_header);
 +    av_freep(&st->codec);
 +    av_freep(&st->priv_data);
 +    av_freep(&st->info);
 +    av_freep(&s->streams[ --s->nb_streams ]);
 +}
 +
  void avformat_free_context(AVFormatContext *s)
  {
      int i;
 -    AVStream *st;
  
      av_opt_free(s);
      if (s->iformat && s->iformat->priv_class && s->priv_data)
          av_opt_free(s->priv_data);
  
 -    for(i=0;i<s->nb_streams;i++) {
 -        /* free all data in a stream component */
 -        st = s->streams[i];
 -        if (st->parser) {
 -            av_parser_close(st->parser);
 -        }
 -        if (st->attached_pic.data)
 -            av_free_packet(&st->attached_pic);
 -        av_dict_free(&st->metadata);
 -        av_free(st->index_entries);
 -        av_free(st->codec->extradata);
 -        av_free(st->codec->subtitle_header);
 -        av_free(st->codec);
 -        av_free(st->priv_data);
 -        av_free(st->info);
 -        av_free(st);
 +    for(i=s->nb_streams-1; i>=0; i--) {
 +        ff_free_stream(s, s->streams[i]);
      }
      for(i=s->nb_programs-1; i>=0; i--) {
          av_dict_free(&s->programs[i]->metadata);
      av_freep(&s->priv_data);
      while(s->nb_chapters--) {
          av_dict_free(&s->chapters[s->nb_chapters]->metadata);
 -        av_free(s->chapters[s->nb_chapters]);
 +        av_freep(&s->chapters[s->nb_chapters]);
      }
      av_freep(&s->chapters);
      av_dict_free(&s->metadata);
@@@ -3076,16 -2729,6 +3082,16 @@@ void avformat_close_input(AVFormatConte
      avio_close(pb);
  }
  
 +#if FF_API_NEW_STREAM
 +AVStream *av_new_stream(AVFormatContext *s, int id)
 +{
 +    AVStream *st = avformat_new_stream(s, NULL);
 +    if (st)
 +        st->id = id;
 +    return st;
 +}
 +#endif
 +
  AVStream *avformat_new_stream(AVFormatContext *s, AVCodec *c)
  {
      AVStream *st;
          av_free(st);
          return NULL;
      }
 +    st->info->last_dts = AV_NOPTS_VALUE;
  
      st->codec = avcodec_alloc_context3(c);
      if (s->iformat) {
             but durations get some timestamps, formats with some unknown
             timestamps have their first few packets buffered and the
             timestamps corrected before they are returned to the user */
 -    st->cur_dts = 0;
 +    st->cur_dts = s->iformat ? RELATIVE_TS_BASE : 0;
      st->first_dts = AV_NOPTS_VALUE;
      st->probe_packets = MAX_PROBE_PACKETS;
  
@@@ -3193,69 -2835,6 +3199,69 @@@ AVChapter *avpriv_new_chapter(AVFormatC
  /************************************************************/
  /* output media file */
  
 +int avformat_alloc_output_context2(AVFormatContext **avctx, AVOutputFormat *oformat,
 +                                   const char *format, const char *filename)
 +{
 +    AVFormatContext *s = avformat_alloc_context();
 +    int ret = 0;
 +
 +    *avctx = NULL;
 +    if (!s)
 +        goto nomem;
 +
 +    if (!oformat) {
 +        if (format) {
 +            oformat = av_guess_format(format, NULL, NULL);
 +            if (!oformat) {
 +                av_log(s, AV_LOG_ERROR, "Requested output format '%s' is not a suitable output format\n", format);
 +                ret = AVERROR(EINVAL);
 +                goto error;
 +            }
 +        } else {
 +            oformat = av_guess_format(NULL, filename, NULL);
 +            if (!oformat) {
 +                ret = AVERROR(EINVAL);
 +                av_log(s, AV_LOG_ERROR, "Unable to find a suitable output format for '%s'\n",
 +                       filename);
 +                goto error;
 +            }
 +        }
 +    }
 +
 +    s->oformat = oformat;
 +    if (s->oformat->priv_data_size > 0) {
 +        s->priv_data = av_mallocz(s->oformat->priv_data_size);
 +        if (!s->priv_data)
 +            goto nomem;
 +        if (s->oformat->priv_class) {
 +            *(const AVClass**)s->priv_data= s->oformat->priv_class;
 +            av_opt_set_defaults(s->priv_data);
 +        }
 +    } else
 +        s->priv_data = NULL;
 +
 +    if (filename)
 +        av_strlcpy(s->filename, filename, sizeof(s->filename));
 +    *avctx = s;
 +    return 0;
 +nomem:
 +    av_log(s, AV_LOG_ERROR, "Out of memory\n");
 +    ret = AVERROR(ENOMEM);
 +error:
 +    avformat_free_context(s);
 +    return ret;
 +}
 +
 +#if FF_API_ALLOC_OUTPUT_CONTEXT
 +AVFormatContext *avformat_alloc_output_context(const char *format,
 +                                               AVOutputFormat *oformat, const char *filename)
 +{
 +    AVFormatContext *avctx;
 +    int ret = avformat_alloc_output_context2(&avctx, oformat, format, filename);
 +    return ret < 0 ? NULL : avctx;
 +}
 +#endif
 +
  static int validate_codec_tag(AVFormatContext *s, AVStream *st)
  {
      const AVCodecTag *avctag;
@@@ -3299,9 -2878,6 +3305,9 @@@ int avformat_write_header(AVFormatConte
          av_dict_copy(&tmp, *options, 0);
      if ((ret = av_opt_set_dict(s, &tmp)) < 0)
          goto fail;
 +    if (s->priv_data && s->oformat->priv_class && *(const AVClass**)s->priv_data==s->oformat->priv_class &&
 +        (ret = av_opt_set_dict(s->priv_data, &tmp)) < 0)
 +        goto fail;
  
      // some sanity checks
      if (s->nb_streams == 0 && !(s->oformat->flags & AVFMT_NOSTREAMS)) {
                  ret = AVERROR(EINVAL);
                  goto fail;
              }
 -            if(av_cmp_q(st->sample_aspect_ratio, st->codec->sample_aspect_ratio)){
 +            if(av_cmp_q(st->sample_aspect_ratio, st->codec->sample_aspect_ratio)
 +               && FFABS(av_q2d(st->sample_aspect_ratio) - av_q2d(st->codec->sample_aspect_ratio)) > 0.004*av_q2d(st->sample_aspect_ratio)
 +            ){
                  av_log(s, AV_LOG_ERROR, "Aspect ratio mismatch between muxer "
                         "(%d/%d) and encoder layer (%d/%d)\n",
                         st->sample_aspect_ratio.num, st->sample_aspect_ratio.den,
          }
  
          if(s->oformat->codec_tag){
 -            if(st->codec->codec_tag && st->codec->codec_id == AV_CODEC_ID_RAWVIDEO && av_codec_get_tag(s->oformat->codec_tag, st->codec->codec_id) == 0 && !validate_codec_tag(s, st)){
 -                //the current rawvideo encoding system ends up setting the wrong codec_tag for avi, we override it here
 +            if(   st->codec->codec_tag
 +               && st->codec->codec_id == AV_CODEC_ID_RAWVIDEO
 +               && (av_codec_get_tag(s->oformat->codec_tag, st->codec->codec_id) == 0 || av_codec_get_tag(s->oformat->codec_tag, st->codec->codec_id) ==MKTAG('r', 'a', 'w', ' '))
 +               && !validate_codec_tag(s, st)){
 +                //the current rawvideo encoding system ends up setting the wrong codec_tag for avi/mov, we override it here
                  st->codec->codec_tag= 0;
              }
              if(st->codec->codec_tag){
                  if (!validate_codec_tag(s, st)) {
 -                    char tagbuf[32];
 +                    char tagbuf[32], cortag[32];
                      av_get_codec_tag_string(tagbuf, sizeof(tagbuf), st->codec->codec_tag);
 +                    av_get_codec_tag_string(cortag, sizeof(cortag), av_codec_get_tag(s->oformat->codec_tag, st->codec->codec_id));
                      av_log(s, AV_LOG_ERROR,
 -                           "Tag %s/0x%08x incompatible with output codec id '%d'\n",
 -                           tagbuf, st->codec->codec_tag, st->codec->codec_id);
 +                           "Tag %s/0x%08x incompatible with output codec id '%d' (%s)\n",
 +                           tagbuf, st->codec->codec_tag, st->codec->codec_id, cortag);
                      ret = AVERROR_INVALIDDATA;
                      goto fail;
                  }
  
      if(s->oformat->write_header){
          ret = s->oformat->write_header(s);
 +        if (ret >= 0 && s->pb && s->pb->error < 0)
 +            ret = s->pb->error;
          if (ret < 0)
              goto fail;
      }
@@@ -3440,11 -3008,14 +3446,11 @@@ fail
  
  //FIXME merge with compute_pkt_fields
  static int compute_pkt_fields2(AVFormatContext *s, AVStream *st, AVPacket *pkt){
 -    int delay = FFMAX(st->codec->has_b_frames, !!st->codec->max_b_frames);
 +    int delay = FFMAX(st->codec->has_b_frames, st->codec->max_b_frames > 0);
      int num, den, frame_size, i;
  
 -    av_dlog(s, "compute_pkt_fields2: pts:%"PRId64" dts:%"PRId64" cur_dts:%"PRId64" b:%d size:%d st:%d\n",
 -            pkt->pts, pkt->dts, st->cur_dts, delay, pkt->size, pkt->stream_index);
 -
 -/*    if(pkt->pts == AV_NOPTS_VALUE && pkt->dts == AV_NOPTS_VALUE)
 -        return AVERROR(EINVAL);*/
 +    av_dlog(s, "compute_pkt_fields2: pts:%s dts:%s cur_dts:%s b:%d size:%d st:%d\n",
 +            av_ts2str(pkt->pts), av_ts2str(pkt->dts), av_ts2str(st->cur_dts), delay, pkt->size, pkt->stream_index);
  
      /* duration field */
      if (pkt->duration == 0) {
  
      //XXX/FIXME this is a temporary hack until all encoders output pts
      if((pkt->pts == 0 || pkt->pts == AV_NOPTS_VALUE) && pkt->dts == AV_NOPTS_VALUE && !delay){
 +        static int warned;
 +        if (!warned) {
 +            av_log(s, AV_LOG_WARNING, "Encoder did not produce proper pts, making some up.\n");
 +            warned = 1;
 +        }
          pkt->dts=
  //        pkt->pts= st->cur_dts;
          pkt->pts= st->pts.val;
          ((!(s->oformat->flags & AVFMT_TS_NONSTRICT) &&
            st->cur_dts >= pkt->dts) || st->cur_dts > pkt->dts)) {
          av_log(s, AV_LOG_ERROR,
 -               "Application provided invalid, non monotonically increasing dts to muxer in stream %d: %"PRId64" >= %"PRId64"\n",
 -               st->index, st->cur_dts, pkt->dts);
 +               "Application provided invalid, non monotonically increasing dts to muxer in stream %d: %s >= %s\n",
 +               st->index, av_ts2str(st->cur_dts), av_ts2str(pkt->dts));
          return AVERROR(EINVAL);
      }
      if(pkt->dts != AV_NOPTS_VALUE && pkt->pts != AV_NOPTS_VALUE && pkt->pts < pkt->dts){
 -        av_log(s, AV_LOG_ERROR, "pts < dts in stream %d\n", st->index);
 +        av_log(s, AV_LOG_ERROR, "pts (%s) < dts (%s) in stream %d\n",
 +               av_ts2str(pkt->pts), av_ts2str(pkt->dts), st->index);
          return AVERROR(EINVAL);
      }
  
 -//    av_log(s, AV_LOG_DEBUG, "av_write_frame: pts2:%"PRId64" dts2:%"PRId64"\n", pkt->pts, pkt->dts);
 +//    av_log(s, AV_LOG_DEBUG, "av_write_frame: pts2:%s dts2:%s\n", av_ts2str(pkt->pts), av_ts2str(pkt->dts));
      st->cur_dts= pkt->dts;
      st->pts.val= pkt->dts;
  
@@@ -3524,12 -3089,8 +3530,12 @@@ int av_write_frame(AVFormatContext *s, 
      int ret;
  
      if (!pkt) {
 -        if (s->oformat->flags & AVFMT_ALLOW_FLUSH)
 -            return s->oformat->write_packet(s, pkt);
 +        if (s->oformat->flags & AVFMT_ALLOW_FLUSH) {
 +            ret = s->oformat->write_packet(s, pkt);
 +            if (ret >= 0 && s->pb && s->pb->error < 0)
 +                ret = s->pb->error;
 +            return ret;
 +        }
          return 1;
      }
  
          return ret;
  
      ret= s->oformat->write_packet(s, pkt);
 +    if (ret >= 0 && s->pb && s->pb->error < 0)
 +        ret = s->pb->error;
  
      if (ret >= 0)
          s->streams[pkt->stream_index]->nb_frames++;
      return ret;
  }
  
 -void ff_interleave_add_packet(AVFormatContext *s, AVPacket *pkt,
 +#define CHUNK_START 0x1000
 +
 +int ff_interleave_add_packet(AVFormatContext *s, AVPacket *pkt,
                                int (*compare)(AVFormatContext *, AVPacket *, AVPacket *))
  {
      AVPacketList **next_point, *this_pktl;
 +    AVStream *st= s->streams[pkt->stream_index];
 +    int chunked= s->max_chunk_size || s->max_chunk_duration;
  
      this_pktl = av_mallocz(sizeof(AVPacketList));
 +    if (!this_pktl)
 +        return AVERROR(ENOMEM);
      this_pktl->pkt= *pkt;
      pkt->destruct= NULL;             // do not free original but only the copy
 -    av_dup_packet(&this_pktl->pkt);  // duplicate the packet if it uses non-alloced memory
 +    av_dup_packet(&this_pktl->pkt);  // duplicate the packet if it uses non-allocated memory
  
      if(s->streams[pkt->stream_index]->last_in_packet_buffer){
 -        next_point = &(s->streams[pkt->stream_index]->last_in_packet_buffer->next);
 -    }else
 +        next_point = &(st->last_in_packet_buffer->next);
 +    }else{
          next_point = &s->packet_buffer;
 +    }
  
      if(*next_point){
 +        if(chunked){
 +            uint64_t max= av_rescale_q(s->max_chunk_duration, AV_TIME_BASE_Q, st->time_base);
 +            if(   st->interleaver_chunk_size     + pkt->size     <= s->max_chunk_size-1U
 +               && st->interleaver_chunk_duration + pkt->duration <= max-1U){
 +                st->interleaver_chunk_size     += pkt->size;
 +                st->interleaver_chunk_duration += pkt->duration;
 +                goto next_non_null;
 +            }else{
 +                st->interleaver_chunk_size     =
 +                st->interleaver_chunk_duration = 0;
 +                this_pktl->pkt.flags |= CHUNK_START;
 +            }
 +        }
 +
          if(compare(s, &s->packet_buffer_end->pkt, pkt)){
 -            while(!compare(s, &(*next_point)->pkt, pkt)){
 +            while(   *next_point
 +                  && ((chunked && !((*next_point)->pkt.flags&CHUNK_START))
 +                      || !compare(s, &(*next_point)->pkt, pkt))){
                  next_point= &(*next_point)->next;
              }
 -            goto next_non_null;
 +            if(*next_point)
 +                goto next_non_null;
          }else{
              next_point = &(s->packet_buffer_end->next);
          }
@@@ -3605,7 -3140,6 +3611,7 @@@ next_non_null
  
      s->streams[pkt->stream_index]->last_in_packet_buffer=
      *next_point= this_pktl;
 +    return 0;
  }
  
  static int ff_interleave_compare_dts(AVFormatContext *s, AVPacket *next, AVPacket *pkt)
      AVStream *st2= s->streams[ next->stream_index];
      int comp = av_compare_ts(next->dts, st2->time_base, pkt->dts,
                               st->time_base);
 +    if(s->audio_preload && ((st->codec->codec_type == AVMEDIA_TYPE_AUDIO) != (st2->codec->codec_type == AVMEDIA_TYPE_AUDIO))){
 +        int64_t ts = av_rescale_q(pkt ->dts, st ->time_base, AV_TIME_BASE_Q) - s->audio_preload*(st ->codec->codec_type == AVMEDIA_TYPE_AUDIO);
 +        int64_t ts2= av_rescale_q(next->dts, st2->time_base, AV_TIME_BASE_Q) - s->audio_preload*(st2->codec->codec_type == AVMEDIA_TYPE_AUDIO);
 +        if(ts == ts2){
 +            ts= ( pkt ->dts* st->time_base.num*AV_TIME_BASE - s->audio_preload*(int64_t)(st ->codec->codec_type == AVMEDIA_TYPE_AUDIO)* st->time_base.den)*st2->time_base.den
 +               -( next->dts*st2->time_base.num*AV_TIME_BASE - s->audio_preload*(int64_t)(st2->codec->codec_type == AVMEDIA_TYPE_AUDIO)*st2->time_base.den)* st->time_base.den;
 +            ts2=0;
 +        }
 +        comp= (ts>ts2) - (ts<ts2);
 +    }
  
      if (comp == 0)
          return pkt->stream_index < next->stream_index;
@@@ -3634,46 -3158,17 +3640,46 @@@ int ff_interleave_packet_per_dts(AVForm
                                   AVPacket *pkt, int flush)
  {
      AVPacketList *pktl;
 -    int stream_count=0;
 -    int i;
 +    int stream_count=0, noninterleaved_count=0;
 +    int64_t delta_dts_max = 0;
 +    int i, ret;
  
      if(pkt){
 -        ff_interleave_add_packet(s, pkt, ff_interleave_compare_dts);
 +        ret = ff_interleave_add_packet(s, pkt, ff_interleave_compare_dts);
 +        if (ret < 0)
 +            return ret;
      }
  
 -    for(i=0; i < s->nb_streams; i++)
 -        stream_count+= !!s->streams[i]->last_in_packet_buffer;
 +    for(i=0; i < s->nb_streams; i++) {
 +        if (s->streams[i]->last_in_packet_buffer) {
 +            ++stream_count;
 +        } else if(s->streams[i]->codec->codec_type == AVMEDIA_TYPE_SUBTITLE) {
 +            ++noninterleaved_count;
 +        }
 +    }
  
 -    if(stream_count && (s->nb_streams == stream_count || flush)){
 +    if (s->nb_streams == stream_count) {
 +        flush = 1;
 +    } else if (!flush){
 +        for(i=0; i < s->nb_streams; i++) {
 +            if (s->streams[i]->last_in_packet_buffer) {
 +                int64_t delta_dts =
 +                    av_rescale_q(s->streams[i]->last_in_packet_buffer->pkt.dts,
 +                                s->streams[i]->time_base,
 +                                AV_TIME_BASE_Q) -
 +                    av_rescale_q(s->packet_buffer->pkt.dts,
 +                                s->streams[s->packet_buffer->pkt.stream_index]->time_base,
 +                                AV_TIME_BASE_Q);
 +                delta_dts_max= FFMAX(delta_dts_max, delta_dts);
 +            }
 +        }
 +        if(s->nb_streams == stream_count+noninterleaved_count &&
 +           delta_dts_max > 20*AV_TIME_BASE) {
 +            av_log(s, AV_LOG_DEBUG, "flushing with %d noninterleaved\n", noninterleaved_count);
 +            flush = 1;
 +        }
 +    }
 +    if(stream_count && flush){
          pktl= s->packet_buffer;
          *out= pktl->pkt;
  
@@@ -3728,8 -3223,8 +3734,8 @@@ int av_interleaved_write_frame(AVFormat
          if(st->codec->codec_type == AVMEDIA_TYPE_AUDIO && pkt->size==0)
              return 0;
  
 -        av_dlog(s, "av_interleaved_write_frame size:%d dts:%"PRId64" pts:%"PRId64"\n",
 -                pkt->size, pkt->dts, pkt->pts);
 +        av_dlog(s, "av_interleaved_write_frame size:%d dts:%s pts:%s\n",
 +                pkt->size, av_ts2str(pkt->dts), av_ts2str(pkt->pts));
          if((ret = compute_pkt_fields2(s, st, pkt)) < 0 && !(s->oformat->flags & AVFMT_NOTIMESTAMPS))
              return ret;
  
  
          if(ret<0)
              return ret;
 +        if(s->pb && s->pb->error)
 +            return s->pb->error;
      }
  }
  
@@@ -3780,18 -3273,15 +3786,18 @@@ int av_write_trailer(AVFormatContext *s
  
          if (ret < 0)
              goto fail;
 +        if(s->pb && s->pb->error)
 +            goto fail;
      }
  
      if (s->oformat->write_trailer)
          ret = s->oformat->write_trailer(s);
  
 -    if (!(s->oformat->flags & AVFMT_NOFILE))
 -        avio_flush(s->pb);
 -
  fail:
 +    if (s->pb)
 +       avio_flush(s->pb);
 +    if (ret == 0)
 +       ret = s->pb ? s->pb->error : 0;
      for (i = 0; i < s->nb_streams; i++) {
          av_freep(&s->streams[i]->priv_data);
          av_freep(&s->streams[i]->index_entries);
      return ret;
  }
  
 +int av_get_output_timestamp(struct AVFormatContext *s, int stream,
 +                            int64_t *dts, int64_t *wall)
 +{
 +    if (!s->oformat || !s->oformat->get_output_timestamp)
 +        return AVERROR(ENOSYS);
 +    s->oformat->get_output_timestamp(s, stream, dts, wall);
 +    return 0;
 +}
 +
  void ff_program_add_stream_index(AVFormatContext *ac, int progid, unsigned int idx)
  {
      int i, j;
@@@ -3853,21 -3334,8 +3859,21 @@@ static void dump_metadata(void *ctx, AV
  
          av_log(ctx, AV_LOG_INFO, "%sMetadata:\n", indent);
          while((tag=av_dict_get(m, "", tag, AV_DICT_IGNORE_SUFFIX))) {
 -            if(strcmp("language", tag->key))
 -                av_log(ctx, AV_LOG_INFO, "%s  %-16s: %s\n", indent, tag->key, tag->value);
 +            if(strcmp("language", tag->key)){
 +                const char *p = tag->value;
 +                av_log(ctx, AV_LOG_INFO, "%s  %-16s: ", indent, tag->key);
 +                while(*p) {
 +                    char tmp[256];
 +                    size_t len = strcspn(p, "\x8\xa\xb\xc\xd");
 +                    av_strlcpy(tmp, p, FFMIN(sizeof(tmp), len+1));
 +                    av_log(ctx, AV_LOG_INFO, "%s", tmp);
 +                    p += len;
 +                    if (*p == 0xd) av_log(ctx, AV_LOG_INFO, " ");
 +                    if (*p == 0xa) av_log(ctx, AV_LOG_INFO, "\n%s  %-16s: ", indent, "");
 +                    if (*p) p++;
 +                }
 +                av_log(ctx, AV_LOG_INFO, "\n");
 +            }
          }
      }
  }
@@@ -3881,7 -3349,7 +3887,7 @@@ static void dump_stream_format(AVFormat
      int g = av_gcd(st->time_base.num, st->time_base.den);
      AVDictionaryEntry *lang = av_dict_get(st->metadata, "language", NULL, 0);
      avcodec_string(buf, sizeof(buf), st->codec, is_output);
 -    av_log(NULL, AV_LOG_INFO, "    Stream #%d.%d", index, i);
 +    av_log(NULL, AV_LOG_INFO, "    Stream #%d:%d", index, i);
      /* the pid is an important information, so we display it */
      /* XXX: add a generic system */
      if (flags & AVFMT_SHOW_IDS)
                    st->codec->width*st->sample_aspect_ratio.num,
                    st->codec->height*st->sample_aspect_ratio.den,
                    1024*1024);
 -        av_log(NULL, AV_LOG_INFO, ", PAR %d:%d DAR %d:%d",
 +        av_log(NULL, AV_LOG_INFO, ", SAR %d:%d DAR %d:%d",
                   st->sample_aspect_ratio.num, st->sample_aspect_ratio.den,
                   display_aspect_ratio.num, display_aspect_ratio.den);
      }
@@@ -4148,27 -3616,11 +4154,27 @@@ static void pkt_dump_internal(void *avc
          av_hex_dump(f, pkt->data, pkt->size);
  }
  
 +#if FF_API_PKT_DUMP
 +void av_pkt_dump(FILE *f, AVPacket *pkt, int dump_payload)
 +{
 +    AVRational tb = { 1, AV_TIME_BASE };
 +    pkt_dump_internal(NULL, f, 0, pkt, dump_payload, tb);
 +}
 +#endif
 +
  void av_pkt_dump2(FILE *f, AVPacket *pkt, int dump_payload, AVStream *st)
  {
      pkt_dump_internal(NULL, f, 0, pkt, dump_payload, st->time_base);
  }
  
 +#if FF_API_PKT_DUMP
 +void av_pkt_dump_log(void *avcl, int level, AVPacket *pkt, int dump_payload)
 +{
 +    AVRational tb = { 1, AV_TIME_BASE };
 +    pkt_dump_internal(avcl, NULL, level, pkt, dump_payload, tb);
 +}
 +#endif
 +
  void av_pkt_dump_log2(void *avcl, int level, AVPacket *pkt, int dump_payload,
                        AVStream *st)
  {
@@@ -4182,7 -3634,7 +4188,7 @@@ void av_url_split(char *proto, int prot
                    char *path, int path_size,
                    const char *url)
  {
 -    const char *p, *ls, *at, *col, *brk;
 +    const char *p, *ls, *ls2, *at, *col, *brk;
  
      if (port_ptr)               *port_ptr = -1;
      if (proto_size > 0)         proto[0] = 0;
  
      /* separate path from hostname */
      ls = strchr(p, '/');
 +    ls2 = strchr(p, '?');
      if(!ls)
 -        ls = strchr(p, '?');
 +        ls = ls2;
 +    else if (ls && ls2)
 +        ls = FFMIN(ls, ls2);
      if(ls)
          av_strlcpy(path, ls, path_size);
      else
@@@ -4288,14 -3737,6 +4294,14 @@@ int ff_hex_to_data(uint8_t *data, cons
      return len;
  }
  
 +#if FF_API_SET_PTS_INFO
 +void av_set_pts_info(AVStream *s, int pts_wrap_bits,
 +                     unsigned int pts_num, unsigned int pts_den)
 +{
 +    avpriv_set_pts_info(s, pts_wrap_bits, pts_num, pts_den);
 +}
 +#endif
 +
  void avpriv_set_pts_info(AVStream *s, int pts_wrap_bits,
                           unsigned int pts_num, unsigned int pts_den)
  {
          av_log(NULL, AV_LOG_WARNING, "st:%d has too large timebase, reducing\n", s->index);
  
      if(new_tb.num <= 0 || new_tb.den <= 0) {
 -        av_log(NULL, AV_LOG_ERROR, "Ignoring attempt to set invalid timebase for st:%d\n", s->index);
 +        av_log(NULL, AV_LOG_ERROR, "Ignoring attempt to set invalid timebase %d/%d for st:%d\n", new_tb.num, new_tb.den, s->index);
          return;
      }
      s->time_base = new_tb;
 +    av_codec_set_pkt_timebase(s->codec, new_tb);
      s->pts_wrap_bits = pts_wrap_bits;
  }
  
@@@ -4494,14 -3934,20 +4500,14 @@@ void ff_make_absolute_url(char *buf, in
  
  int64_t ff_iso8601_to_unix_time(const char *datestr)
  {
 -#if HAVE_STRPTIME
      struct tm time1 = {0}, time2 = {0};
      char *ret1, *ret2;
 -    ret1 = strptime(datestr, "%Y - %m - %d %T", &time1);
 -    ret2 = strptime(datestr, "%Y - %m - %dT%T", &time2);
 +    ret1 = av_small_strptime(datestr, "%Y - %m - %d %H:%M:%S", &time1);
 +    ret2 = av_small_strptime(datestr, "%Y - %m - %dT%H:%M:%S", &time2);
      if (ret2 && !ret1)
          return av_timegm(&time2);
      else
          return av_timegm(&time1);
 -#else
 -    av_log(NULL, AV_LOG_WARNING, "strptime() unavailable on this system, cannot convert "
 -                                 "the date string.\n");
 -    return 0;
 -#endif
  }
  
  int avformat_query_codec(AVOutputFormat *ofmt, enum AVCodecID codec_id, int std_compliance)
@@@ -4589,87 -4035,3 +4595,87 @@@ const struct AVCodecTag *avformat_get_r
  {
      return ff_codec_wav_tags;
  }
 +
 +AVRational av_guess_sample_aspect_ratio(AVFormatContext *format, AVStream *stream, AVFrame *frame)
 +{
 +    AVRational undef = {0, 1};
 +    AVRational stream_sample_aspect_ratio = stream ? stream->sample_aspect_ratio : undef;
 +    AVRational codec_sample_aspect_ratio  = stream && stream->codec ? stream->codec->sample_aspect_ratio : undef;
 +    AVRational frame_sample_aspect_ratio  = frame  ? frame->sample_aspect_ratio  : codec_sample_aspect_ratio;
 +
 +    av_reduce(&stream_sample_aspect_ratio.num, &stream_sample_aspect_ratio.den,
 +               stream_sample_aspect_ratio.num,  stream_sample_aspect_ratio.den, INT_MAX);
 +    if (stream_sample_aspect_ratio.num <= 0 || stream_sample_aspect_ratio.den <= 0)
 +        stream_sample_aspect_ratio = undef;
 +
 +    av_reduce(&frame_sample_aspect_ratio.num, &frame_sample_aspect_ratio.den,
 +               frame_sample_aspect_ratio.num,  frame_sample_aspect_ratio.den, INT_MAX);
 +    if (frame_sample_aspect_ratio.num <= 0 || frame_sample_aspect_ratio.den <= 0)
 +        frame_sample_aspect_ratio = undef;
 +
 +    if (stream_sample_aspect_ratio.num)
 +        return stream_sample_aspect_ratio;
 +    else
 +        return frame_sample_aspect_ratio;
 +}
 +
 +int avformat_match_stream_specifier(AVFormatContext *s, AVStream *st,
 +                                    const char *spec)
 +{
 +    if (*spec <= '9' && *spec >= '0') /* opt:index */
 +        return strtol(spec, NULL, 0) == st->index;
 +    else if (*spec == 'v' || *spec == 'a' || *spec == 's' || *spec == 'd' ||
 +             *spec == 't') { /* opt:[vasdt] */
 +        enum AVMediaType type;
 +
 +        switch (*spec++) {
 +        case 'v': type = AVMEDIA_TYPE_VIDEO;      break;
 +        case 'a': type = AVMEDIA_TYPE_AUDIO;      break;
 +        case 's': type = AVMEDIA_TYPE_SUBTITLE;   break;
 +        case 'd': type = AVMEDIA_TYPE_DATA;       break;
 +        case 't': type = AVMEDIA_TYPE_ATTACHMENT; break;
 +        default:  av_assert0(0);
 +        }
 +        if (type != st->codec->codec_type)
 +            return 0;
 +        if (*spec++ == ':') { /* possibly followed by :index */
 +            int i, index = strtol(spec, NULL, 0);
 +            for (i = 0; i < s->nb_streams; i++)
 +                if (s->streams[i]->codec->codec_type == type && index-- == 0)
 +                   return i == st->index;
 +            return 0;
 +        }
 +        return 1;
 +    } else if (*spec == 'p' && *(spec + 1) == ':') {
 +        int prog_id, i, j;
 +        char *endptr;
 +        spec += 2;
 +        prog_id = strtol(spec, &endptr, 0);
 +        for (i = 0; i < s->nb_programs; i++) {
 +            if (s->programs[i]->id != prog_id)
 +                continue;
 +
 +            if (*endptr++ == ':') {
 +                int stream_idx = strtol(endptr, NULL, 0);
 +                return stream_idx >= 0 &&
 +                    stream_idx < s->programs[i]->nb_stream_indexes &&
 +                    st->index == s->programs[i]->stream_index[stream_idx];
 +            }
 +
 +            for (j = 0; j < s->programs[i]->nb_stream_indexes; j++)
 +                if (st->index == s->programs[i]->stream_index[j])
 +                    return 1;
 +        }
 +        return 0;
 +    } else if (*spec == '#') {
 +        int sid;
 +        char *endptr;
 +        sid = strtol(spec + 1, &endptr, 0);
 +        if (!*endptr)
 +            return st->id == sid;
 +    } else if (!*spec) /* empty specifier, matches everything */
 +        return 1;
 +
 +    av_log(s, AV_LOG_ERROR, "Invalid stream specifier: %s.\n", spec);
 +    return AVERROR(EINVAL);
 +}
diff --combined libavutil/arm/asm.S
@@@ -1,20 -1,20 +1,20 @@@
  /*
   * Copyright (c) 2008 Mans Rullgard <mans@mansr.com>
   *
 - * 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
   */
  
@@@ -66,6 -66,7 +66,7 @@@ ELF     .eabi_attribute 25, \va
          .set            .Lpic_gp, 0
      .macro endfunc
        .if .Lpic_idx
+         .align          2
          .altmacro
          put_pic         %(.Lpic_idx - 1)
          .noaltmacro
@@@ -142,7 -143,7 +143,7 @@@ ELF     .size   \name, . - \nam
      .if \indir
          ldr             \rd, [pc, \rd]
      .else
-         add             \rd, pc,  \rd
+         add             \rd, pc
      .endif
          def_pic         \val - (.Lpic\@ + (8 >> CONFIG_THUMB)), .Lpicoff\@
  .endm