Merge remote-tracking branch 'qatar/master'
authorMichael Niedermayer <michaelni@gmx.at>
Sun, 18 Mar 2012 22:12:35 +0000 (23:12 +0100)
committerMichael Niedermayer <michaelni@gmx.at>
Sun, 18 Mar 2012 22:39:42 +0000 (23:39 +0100)
* qatar/master:
  fate: make compare() function compatible with POSIX bc
  Update Janne's email address.
  APIchanges: Replace Subversion revision numbers by Git hashes.
  bytestream: Eliminate one level of pointless macro indirection.
  xwd: convert to bytestream2.
  vqavideo: port to bytestream2 API
  Read preset files with suffix .avpreset
  prores: allow user to set fixed quantiser
  lavf: remove some disabled code.
  lavf: only set average frame rate for video.
  lavf: remove a pointless check.
  avcodec: add XBM encoder

Conflicts:
Changelog
cmdutils.c
cmdutils.h
doc/APIchanges
libavcodec/Makefile
libavcodec/avcodec.h
libavcodec/version.h
libavcodec/vqavideo.c
libavformat/img2enc.c
libavformat/utils.c

Merged-by: Michael Niedermayer <michaelni@gmx.at>
18 files changed:
1  2 
Changelog
cmdutils.c
cmdutils.h
doc/APIchanges
doc/general.texi
libavcodec/Makefile
libavcodec/aacdec.c
libavcodec/allcodecs.c
libavcodec/avcodec.h
libavcodec/bytestream.h
libavcodec/proresenc_kostya.c
libavcodec/version.h
libavcodec/vqavideo.c
libavformat/img2.c
libavformat/img2enc.c
libavformat/utils.c
tests/fate-run.sh
tests/ref/fate/vqa-cc

diff --cc Changelog
+++ b/Changelog
@@@ -1,68 -1,41 +1,69 @@@
  Entries are sorted chronologically from oldest to youngest within each release,
  releases are sorted from youngest to oldest.
  
 -version <next>:
 -
 -- XWD encoder and decoder
 -- Support for fragmentation in the mov/mp4 muxer
 -- ISMV (Smooth Streaming) muxer
 +version next:
 +- v408 Quicktime and Microsoft AYUV Uncompressed 4:4:4:4 encoder and decoder
 +- setfield filter
  - CDXL demuxer and decoder
  - Apple ProRes encoder
 +- ffprobe -count_packets and -count_frames options
  - Sun Rasterfile Encoder
 -- remove libpostproc
  - ID3v2 attached pictures reading and writing
  - WMA Lossless decoder
 +- bluray protocol
 +- blackdetect filter
 +- libutvideo encoder wrapper (--enable-libutvideo)
 +- swapuv filter
 +- bbox filter
+ - XBM encoder
  
  
 -version 0.8:
 -
 +version 0.10:
 +- Fixes: CVE-2011-3929, CVE-2011-3934, CVE-2011-3935, CVE-2011-3936,
 +         CVE-2011-3937, CVE-2011-3940, CVE-2011-3941, CVE-2011-3944,
 +         CVE-2011-3945, CVE-2011-3946, CVE-2011-3947, CVE-2011-3949,
 +         CVE-2011-3950, CVE-2011-3951, CVE-2011-3952
 +- v410 Quicktime Uncompressed 4:4:4 10-bit encoder and decoder
 +- SBaGen (SBG) binaural beats script demuxer
 +- OpenMG Audio muxer
 +- Timecode extraction in DV and MOV
 +- thumbnail video filter
 +- XML output in ffprobe
 +- asplit audio filter
 +- tinterlace video filter
 +- astreamsync audio filter
 +- amerge audio filter
 +- ISMV (Smooth Streaming) muxer
  - GSM audio parser
  - SMJPEG muxer
 -
 -
 -version 0.8_beta2:
 -
 +- XWD encoder and decoder
  - Automatic thread count based on detection number of (available) CPU cores
 -- Deprecate libpostproc. If desired, the switch --enable-postproc will
 -  enable it but it may be removed in a later Libav release.
 +- y41p Brooktree Uncompressed 4:1:1 12-bit encoder and decoder
 +- ffprobe -show_error option
 +- Avid 1:1 10-bit RGB Packer codec
 +- v308 Quicktime Uncompressed 4:4:4 encoder and decoder
 +- yuv4 libquicktime packed 4:2:0 encoder and decoder
 +- ffprobe -show_frames option
 +- silencedetect audio filter
 +- ffprobe -show_program_version, -show_library_versions, -show_versions options
  - rv34: frame-level multi-threading
  - optimized iMDCT transform on x86 using SSE for for mpegaudiodec
 +- Improved PGS subtitle decoder
 +- dumpgraph option to lavfi device
 +- r210 and r10k encoders
 +- ffwavesynth decoder
 +- aviocat tool
 +- ffeval tool
  
  
 -version 0.8_beta1:
 +version 0.9:
  
 +- openal input device added
 +- boxblur filter added
  - BWF muxer
  - Flash Screen Video 2 decoder
 -- ffplay/ffprobe/ffserver renamed to avplay/avprobe/avserver
 -- ffmpeg deprecated, added avconv, which is almost the same for now, except
 +- lavfi input device added
 +- added avconv, which is almost the same for now, except
  for a few incompatible changes in the options, which will hopefully make them
  easier to use. The changes are:
      * The options placement is now strictly enforced! While in theory the
diff --cc cmdutils.c
@@@ -1063,8 -877,8 +1063,8 @@@ FILE *get_preset_file(char *filename, s
              f = fopen(filename, "r");
              if (!f && codec_name) {
                  snprintf(filename, filename_size,
 -                         "%s%s/%s-%s.avpreset",
 -                         base[i], i != 1 ? "" : "/.avconv", codec_name,
 +                         "%s%s/%s-%s.ffpreset",
-                          base[i],  i != 1 ? "" : "/.ffmpeg", codec_name,
++                         base[i], i != 1 ? "" : "/.ffmpeg", codec_name,
                           preset_name);
                  f = fopen(filename, "r");
              }
diff --cc cmdutils.h
@@@ -352,12 -351,11 +352,12 @@@ int cmdutils_read_file(const char *file
   * Get a file corresponding to a preset file.
   *
   * If is_path is non-zero, look for the file in the path preset_name.
 - * Otherwise search for a file named arg.avpreset in the directories
 - * $AVCONV_DATADIR (if set), $HOME/.avconv, and in the datadir defined
 - * at configuration time, in that order. If no such file is found and
 + * Otherwise search for a file named arg.ffpreset in the directories
 + * $FFMPEG_DATADIR (if set), $HOME/.ffmpeg, and in the datadir defined
 + * at configuration time or in a "ffpresets" folder along the executable
 + * on win32, in that order. If no such file is found and
   * codec_name is defined, then search for a file named
-  * codec_name-preset_name.ffpreset in the above-mentioned directories.
+  * codec_name-preset_name.avpreset in the above-mentioned directories.
   *
   * @param filename buffer where the name of the found filename is written
   * @param filename_size size in bytes of the filename buffer
diff --cc doc/APIchanges
@@@ -599,22 -424,16 +599,22 @@@ API changes, most recent first
  2011-02-02 - dfd2a00 - lavu 50.37.0 - log.h
    Make av_dlog public.
  
- 2011-01-15 - r26374 - lavfi 1.74.0 - AVFilterBufferRefAudioProps
 +2011-01-31 - 7b3ea55 - lavfi 1.76.0 - vsrc_buffer
 +  Add sample_aspect_ratio fields to vsrc_buffer arguments
 +
 +2011-01-31 - 910b5b8 - lavfi 1.75.0 - AVFilterLink sample_aspect_ratio
 +  Add sample_aspect_ratio field to AVFilterLink.
 +
+ 2011-01-15 - a242ac3 - lavfi 1.74.0 - AVFilterBufferRefAudioProps
    Rename AVFilterBufferRefAudioProps.samples_nb to nb_samples.
  
- 2011-01-14 - r26330 - lavf 52.93.0 - av_metadata_copy()
+ 2011-01-14 - 7f88a5b - lavf 52.93.0 - av_metadata_copy()
    Add av_metadata_copy() in avformat.h.
  
- 2011-01-07 - r26262 - lavc 52.107.0 - deprecate reordered_opaque
+ 2011-01-07 - 81c623f - lavc 52.107.0 - deprecate reordered_opaque
    Deprecate reordered_opaque in favor of pkt_pts/dts.
  
- 2011-01-07 - r26261 - lavc 52.106.0 - pkt_dts
+ 2011-01-07 - 1919fea - lavc 52.106.0 - pkt_dts
    Add pkt_dts to AVFrame, this will in the future allow multithreading decoders
    to not mess up dts.
  
Simple merge
@@@ -481,7 -440,7 +481,8 @@@ OBJS-$(CONFIG_WS_SND1_DECODER)         
  OBJS-$(CONFIG_XAN_DPCM_DECODER)        += dpcm.o
  OBJS-$(CONFIG_XAN_WC3_DECODER)         += xan.o
  OBJS-$(CONFIG_XAN_WC4_DECODER)         += xxan.o
 +OBJS-$(CONFIG_XBIN_DECODER)            += bintext.o cga_data.o
+ OBJS-$(CONFIG_XBM_ENCODER)             += xbmenc.o
  OBJS-$(CONFIG_XL_DECODER)              += xl.o
  OBJS-$(CONFIG_XSUB_DECODER)            += xsubdec.o
  OBJS-$(CONFIG_XSUB_ENCODER)            += xsubenc.o
@@@ -5,11 -5,11 +5,11 @@@
   *
   * AAC LATM decoder
   * Copyright (c) 2008-2010 Paul Kendall <paul@kcbbs.gen.nz>
-  * Copyright (c) 2010      Janne Grunau <janne-ffmpeg@jannau.net>
+  * Copyright (c) 2010      Janne Grunau <janne-libav@jannau.net>
   *
 - * 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.
@@@ -249,11 -230,10 +249,12 @@@ void avcodec_register_all(void
      REGISTER_DECODER (WNV1, wnv1);
      REGISTER_DECODER (XAN_WC3, xan_wc3);
      REGISTER_DECODER (XAN_WC4, xan_wc4);
+     REGISTER_ENCODER (XBM, xbm);
      REGISTER_DECODER (XL, xl);
      REGISTER_ENCDEC  (XWD, xwd);
 +    REGISTER_ENCDEC  (Y41P, y41p);
      REGISTER_DECODER (YOP, yop);
 +    REGISTER_ENCDEC  (YUV4, yuv4);
      REGISTER_ENCDEC  (ZLIB, zlib);
      REGISTER_ENCDEC  (ZMBV, zmbv);
  
@@@ -247,15 -245,7 +247,16 @@@ enum CodecID 
      CODEC_ID_V410,
      CODEC_ID_XWD,
      CODEC_ID_CDXL,
+     CODEC_ID_XBM,
 +    CODEC_ID_Y41P       = MKBETAG('Y','4','1','P'),
 +    CODEC_ID_ESCAPE130  = MKBETAG('E','1','3','0'),
 +    CODEC_ID_AVRP       = MKBETAG('A','V','R','P'),
 +
 +    CODEC_ID_G2M        = MKBETAG( 0 ,'G','2','M'),
 +    CODEC_ID_AYUV       = MKBETAG('A','Y','U','V'),
 +    CODEC_ID_V308       = MKBETAG('V','3','0','8'),
 +    CODEC_ID_V408       = MKBETAG('V','4','0','8'),
 +    CODEC_ID_YUV4       = MKBETAG('Y','U','V','4'),
  
      /* various PCM "codecs" */
      CODEC_ID_FIRST_AUDIO = 0x10000,     ///< A dummy id pointing at the start of audio codecs
Simple merge
Simple merge
@@@ -21,8 -21,8 +21,8 @@@
  #define AVCODEC_VERSION_H
  
  #define LIBAVCODEC_VERSION_MAJOR 54
- #define LIBAVCODEC_VERSION_MINOR  10
 -#define LIBAVCODEC_VERSION_MINOR  9
 -#define LIBAVCODEC_VERSION_MICRO  0
++#define LIBAVCODEC_VERSION_MINOR  11
 +#define LIBAVCODEC_VERSION_MICRO 100
  
  #define LIBAVCODEC_VERSION_INT  AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
                                                 LIBAVCODEC_VERSION_MINOR, \
@@@ -136,14 -133,9 +133,13 @@@ static av_cold int vqa_decode_init(AVCo
      }
  
      /* load up the VQA parameters from the header */
-     vqa_header = (unsigned char *)s->avctx->extradata;
-     s->vqa_version = vqa_header[0];
+     s->vqa_version = s->avctx->extradata[0];
 +    if (s->vqa_version < 1 || s->vqa_version > 3) {
 +        av_log(s->avctx, AV_LOG_ERROR, "  VQA video: unsupported version %d\n", s->vqa_version);
 +        return -1;
 +    }
-     s->width = AV_RL16(&vqa_header[6]);
-     s->height = AV_RL16(&vqa_header[8]);
+     s->width = AV_RL16(&s->avctx->extradata[6]);
+     s->height = AV_RL16(&s->avctx->extradata[8]);
      if(av_image_check_size(s->width, s->height, 0, avctx)){
          s->width= s->height= 0;
          return -1;
@@@ -410,16 -399,14 +404,15 @@@ static int vqa_decode_chunk(VqaContext 
          if (chunk_size / 3 > 256) {
              av_log(s->avctx, AV_LOG_ERROR, "  VQA video: problem: found a palette chunk with %d colors\n",
                  chunk_size / 3);
-             return;
+             return AVERROR_INVALIDDATA;
          }
-         cpl0_chunk += CHUNK_PREAMBLE_SIZE;
          for (i = 0; i < chunk_size / 3; i++) {
              /* scale by 4 to transform 6-bit palette -> 8-bit */
-             r = s->buf[cpl0_chunk++] * 4;
-             g = s->buf[cpl0_chunk++] * 4;
-             b = s->buf[cpl0_chunk++] * 4;
+             r = bytestream2_get_byteu(&s->gb) * 4;
+             g = bytestream2_get_byteu(&s->gb) * 4;
+             b = bytestream2_get_byteu(&s->gb) * 4;
 -            s->palette[i] = (r << 16) | (g << 8) | (b);
 +            s->palette[i] = 0xFF << 24 | r << 16 | g << 8 | b;
 +            s->palette[i] |= s->palette[i] >> 6 & 0x30303;
          }
      }
  
Simple merge
@@@ -151,9 -128,9 +151,9 @@@ static const AVClass img2mux_class = 
  AVOutputFormat ff_image2_muxer = {
      .name           = "image2",
      .long_name      = NULL_IF_CONFIG_SMALL("image2 sequence"),
 -    .extensions     = "bmp,dpx,jpeg,jpg,ljpg,pam,pbm,pcx,pgm,pgmyuv,png,"
 -                      "ppm,sgi,tga,tif,tiff,jp2,xwd,sun,ras,rs,im1,im8,im24,"
 +    .extensions     = "bmp,dpx,jls,jpeg,jpg,ljpg,pam,pbm,pcx,pgm,pgmyuv,png,"
 +                      "ppm,sgi,tga,tif,tiff,jp2,j2c,xwd,sun,ras,rs,im1,im8,im24,"
-                       "sunras",
+                       "sunras,xbm",
      .priv_data_size = sizeof(VideoMuxData),
      .video_codec    = CODEC_ID_MJPEG,
      .write_header   = write_header,
@@@ -2593,17 -2410,11 +2582,17 @@@ int avformat_find_stream_info(AVFormatC
      }
      for(i=0;i<ic->nb_streams;i++) {
          st = ic->streams[i];
-         if (st->codec_info_nb_frames>2 && !st->avg_frame_rate.num && st->info->codec_info_duration)
-             av_reduce(&st->avg_frame_rate.num, &st->avg_frame_rate.den,
-                      (st->codec_info_nb_frames-2)*(int64_t)st->time_base.den,
-                       st->info->codec_info_duration*(int64_t)st->time_base.num, 60000);
          if (st->codec->codec_type == AVMEDIA_TYPE_VIDEO) {
 +            if(st->codec->codec_id == 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;
 +            }
 +
+             if (st->codec_info_nb_frames>2 && !st->avg_frame_rate.num && st->info->codec_info_duration)
+                 av_reduce(&st->avg_frame_rate.num, &st->avg_frame_rate.den,
+                           (st->codec_info_nb_frames-2)*(int64_t)st->time_base.den,
+                           st->info->codec_info_duration*(int64_t)st->time_base.num, 60000);
              // 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.
Simple merge
@@@ -5,72 -5,71 +5,71 @@@
  0,          1,          1,        1,   192000, 0x00000000
  0,          2,          2,        1,   192000, 0x00000000
  0,          3,          3,        1,   192000, 0x00000000
 -0,          4,          4,        1,   192000, 0xcd900ccc
 -0,          5,          5,        1,   192000, 0xfd496438
 -0,          6,          6,        1,   192000, 0x965f0bf3
 -0,          7,          7,        1,   192000, 0x378fca5f
 +0,          4,          4,        1,   192000, 0x9ee00ccf
 +0,          5,          5,        1,   192000, 0x67256507
 +0,          6,          6,        1,   192000, 0x74c70e87
 +0,          7,          7,        1,   192000, 0x8ecdce9a
  1,      11024,      11024,     1470,     2940, 0x0f3c64cb
 -0,          8,          8,        1,   192000, 0x5ccd8966
 +0,          8,          8,        1,   192000, 0xc40f8efd
  1,      12494,      12494,     1470,     2940, 0xc90b9e78
 -0,          9,          9,        1,   192000, 0x859676f9
 +0,          9,          9,        1,   192000, 0xb8107dfb
  1,      13964,      13964,     1470,     2940, 0x146246a3
 -0,         10,         10,        1,   192000, 0x820bfb1c
 +0,         10,         10,        1,   192000, 0xb4e504eb
  1,      15434,      15434,     1470,     2940, 0xd22c714e
 -0,         11,         11,        1,   192000, 0x7570cc05
 +0,         11,         11,        1,   192000, 0x0c7fdb95
  1,      16904,      16904,     1470,     2940, 0xd86b681e
 -0,         12,         12,        1,   192000, 0xf38bdb06
 +0,         12,         12,        1,   192000, 0x58c9f045
  1,      18374,      18374,     1470,     2940, 0x12ec8186
 -0,         13,         13,        1,   192000, 0x9b0cbb44
 +0,         13,         13,        1,   192000, 0xcba9d0e9
  1,      19844,      19844,     1470,     2940, 0x69aa85b6
 -0,         14,         14,        1,   192000, 0x0ed70665
 +0,         14,         14,        1,   192000, 0x392a20f6
  1,      21314,      21314,     1470,     2940, 0xb24d33b0
 -0,         15,         15,        1,   192000, 0xd16de7fc
 +0,         15,         15,        1,   192000, 0xc37905cc
  1,      22784,      22784,     1470,     2940, 0x3f7b0f0d
 -0,         16,         16,        1,   192000, 0x97afb484
 +0,         16,         16,        1,   192000, 0xe278cf95
  1,      24254,      24254,     1470,     2940, 0x64f10f7e
 -0,         17,         17,        1,   192000, 0x012893f3
 +0,         17,         17,        1,   192000, 0x3d03b01d
  1,      25724,      25724,     1470,     2940, 0xd6ea379a
 -0,         18,         18,        1,   192000, 0x742a4b43
 +0,         18,         18,        1,   192000, 0x16a26f28
  1,      27194,      27194,     1470,     2940, 0x7c38e830
 -0,         19,         19,        1,   192000, 0x309dcd75
 +0,         19,         19,        1,   192000, 0xdd17f51c
  1,      28664,      28664,     1470,     2940, 0xc28ff132
 -0,         20,         20,        1,   192000, 0xed7814ac
 +0,         20,         20,        1,   192000, 0x19703b85
  1,      30134,      30134,     1470,     2940, 0xe7b11629
 -0,         21,         21,        1,   192000, 0xdb7de3d7
 +0,         21,         21,        1,   192000, 0xe51f0e70
  1,      31604,      31604,     1470,     2940, 0xeb86fdcb
 -0,         22,         22,        1,   192000, 0xe18679a3
 +0,         22,         22,        1,   192000, 0x6f94ad2a
  1,      33074,      33074,     1470,     2940, 0x5508f586
 -0,         23,         23,        1,   192000, 0xb1f213f4
 +0,         23,         23,        1,   192000, 0x71e449f1
  1,      34544,      34544,     1470,     2940, 0xf4fa1f1b
 -0,         24,         24,        1,   192000, 0x33c99b5c
 +0,         24,         24,        1,   192000, 0x1dcacc52
  1,      36014,      36014,     1470,     2940, 0x9e5ff976
 -0,         25,         25,        1,   192000, 0xf66c0c91
 +0,         25,         25,        1,   192000, 0x49c23f58
  1,      37484,      37484,     1470,     2940, 0xcfc4e08f
 -0,         26,         26,        1,   192000, 0x929cdc73
 +0,         26,         26,        1,   192000, 0x4ce61551
  1,      38954,      38954,     1470,     2940, 0x74bde7ed
 -0,         27,         27,        1,   192000, 0xa723fc3b
 +0,         27,         27,        1,   192000, 0xe54832d5
  1,      40424,      40424,     1470,     2940, 0x3e4ae245
 -0,         28,         28,        1,   192000, 0xe6395ccc
 +0,         28,         28,        1,   192000, 0xbae28a59
  1,      41894,      41894,     1470,     2940, 0x4c6a8e56
 -0,         29,         29,        1,   192000, 0x147fbf74
 +0,         29,         29,        1,   192000, 0xe8a4efbe
  1,      43364,      43364,     1470,     2940, 0xa09d86ab
 -0,         30,         30,        1,   192000, 0x3ec62d28
 +0,         30,         30,        1,   192000, 0xe9e96883
  1,      44834,      44834,     1470,     2940, 0xc8531912
 -0,         31,         31,        1,   192000, 0x22104ffb
 +0,         31,         31,        1,   192000, 0xa5468c49
  1,      46304,      46304,     1470,     2940, 0xa5f266aa
 -0,         32,         32,        1,   192000, 0x91f25f58
 +0,         32,         32,        1,   192000, 0x7ec6936a
  1,      47774,      47774,     1470,     2940, 0x587a4187
 -0,         33,         33,        1,   192000, 0xc91b0e4e
 +0,         33,         33,        1,   192000, 0x46e53ee4
  1,      49244,      49244,     1470,     2940, 0x14752d45
 -0,         34,         34,        1,   192000, 0x4683df56
 +0,         34,         34,        1,   192000, 0x937b168a
  1,      50714,      50714,     1470,     2940, 0x558cde10
 -0,         35,         35,        1,   192000, 0x8ef8932a
 +0,         35,         35,        1,   192000, 0xed76cec4
  1,      52184,      52184,     1470,     2940, 0x735fee38
 -0,         36,         36,        1,   192000, 0xce6c0ec0
 +0,         36,         36,        1,   192000, 0x4b9f454d
  1,      53654,      53654,     1470,     2940, 0xac8bb6c8
 -0,         37,         37,        1,   192000, 0xcc10e2a0
 +0,         37,         37,        1,   192000, 0xb58c1566
  1,      55124,      55124,     1470,     2940, 0xa503c73b
- 0,         38,         38,        1,   192000, 0xb58c1566
  1,      56594,      56594,     1470,     2940, 0x7cd588a3
  1,      58064,      58064,     1470,     2940, 0xa6974b04
  1,      59534,      59534,     1470,     2940, 0xbf448241