Merge commit '5e80fb7ff226f136dbcf3fed00a2966bf8e9bd70'
authorMichael Niedermayer <michaelni@gmx.at>
Thu, 6 Nov 2014 10:21:47 +0000 (11:21 +0100)
committerMichael Niedermayer <michaelni@gmx.at>
Thu, 6 Nov 2014 10:21:47 +0000 (11:21 +0100)
* commit '5e80fb7ff226f136dbcf3fed00a2966bf8e9bd70':
  lavc: add a public API for parsing vorbis packets.

Conflicts:
doc/APIchanges
libavcodec/Makefile
libavcodec/version.h
libavcodec/vorbis_parser.c

Merged-by: Michael Niedermayer <michaelni@gmx.at>
1  2 
doc/APIchanges
libavcodec/Makefile
libavcodec/libvorbisenc.c
libavcodec/version.h
libavcodec/vorbis_parser.c
libavcodec/vorbis_parser.h
libavcodec/vorbis_parser_internal.h
libavformat/oggparsevorbis.c

diff --cc doc/APIchanges
@@@ -15,6 -13,12 +15,9 @@@ libavutil:     2014-08-0
  
  API changes, most recent first:
  
 -2014-10-xx - xxxxxxx - lavu 54.5.0 - time.h
 -  Add av_gettime_relative().
 -
+ 2014-11-xx - xxxxxxx - lavc 56.6.0 - vorbis_parser.h
+   Add a public API for parsing vorbis packets.
  2014-10-xx - xxxxxxx - lavc 56.5.0 - avcodec.h
    Replace AVCodecContext.time_base used for decoding
    with AVCodecContext.framerate.
@@@ -28,9 -25,8 +29,10 @@@ OBJS = allcodecs.
         options.o                                                        \
         parser.o                                                         \
         raw.o                                                            \
 +       resample.o                                                       \
 +       resample2.o                                                      \
         utils.o                                                          \
+        vorbis_parser.o                                                  \
  
  # subsystems
  OBJS-$(CONFIG_AANDCTTABLES)            += aandcttab.o
@@@ -676,51 -567,41 +678,51 @@@ OBJS-$(CONFIG_VC1_VDPAU_HWACCEL
  OBJS-$(CONFIG_ADTS_MUXER)              += mpeg4audio.o
  OBJS-$(CONFIG_CAF_DEMUXER)             += mpeg4audio.o mpegaudiodata.o  \
                                            ac3tab.o
 -OBJS-$(CONFIG_FLAC_DEMUXER)            += flac.o flacdata.o             \
 +OBJS-$(CONFIG_FLAC_DEMUXER)            += flac.o flacdata.o vorbis_data.o \
-                                           vorbis_parser.o xiph.o
+                                           xiph.o
 -OBJS-$(CONFIG_FLAC_MUXER)              += flac.o flacdata.o
 +OBJS-$(CONFIG_FLAC_MUXER)              += flac.o flacdata.o vorbis_data.o
  OBJS-$(CONFIG_FLV_DEMUXER)             += mpeg4audio.o
  OBJS-$(CONFIG_GXF_DEMUXER)             += mpeg12data.o
  OBJS-$(CONFIG_IFF_DEMUXER)             += iff.o
  OBJS-$(CONFIG_ISMV_MUXER)              += mpeg4audio.o mpegaudiodata.o
  OBJS-$(CONFIG_LATM_MUXER)              += mpeg4audio.o
 -OBJS-$(CONFIG_MATROSKA_AUDIO_MUXER)    += xiph.o mpeg4audio.o           \
 +OBJS-$(CONFIG_MATROSKA_AUDIO_MUXER)    += xiph.o mpeg4audio.o vorbis_data.o \
                                            flac.o flacdata.o
  OBJS-$(CONFIG_MATROSKA_DEMUXER)        += mpeg4audio.o mpegaudiodata.o  \
-                                           vorbis_parser.o xiph.o
+                                           xiph.o
  OBJS-$(CONFIG_MATROSKA_MUXER)          += mpeg4audio.o mpegaudiodata.o  \
 -                                          flac.o flacdata.o xiph.o
 +                                          flac.o flacdata.o vorbis_data.o xiph.o
  OBJS-$(CONFIG_MP2_MUXER)               += mpegaudiodata.o mpegaudiodecheader.o
  OBJS-$(CONFIG_MP3_MUXER)               += mpegaudiodata.o mpegaudiodecheader.o
  OBJS-$(CONFIG_MOV_DEMUXER)             += mpeg4audio.o mpegaudiodata.o ac3tab.o
  OBJS-$(CONFIG_MOV_MUXER)               += mpeg4audio.o mpegaudiodata.o
  OBJS-$(CONFIG_MPEGTS_MUXER)            += mpeg4audio.o
  OBJS-$(CONFIG_MPEGTS_DEMUXER)          += mpeg4audio.o mpegaudiodata.o
 +OBJS-$(CONFIG_MXF_MUXER)               += dnxhddata.o
  OBJS-$(CONFIG_NUT_MUXER)               += mpegaudiodata.o
 +OBJS-$(CONFIG_OGA_MUXER)               += xiph.o flac.o flacdata.o
  OBJS-$(CONFIG_OGG_DEMUXER)             += xiph.o flac.o flacdata.o     \
-                                           mpeg12data.o vorbis_parser.o \
+                                           mpeg12data.o \
 -                                          dirac.o
 -OBJS-$(CONFIG_OGG_MUXER)               += xiph.o flac.o flacdata.o
 +                                          dirac.o vorbis_data.o
 +OBJS-$(CONFIG_OGG_MUXER)               += xiph.o flac.o flacdata.o \
 +                                          vorbis_data.o
  OBJS-$(CONFIG_RTP_MUXER)               += mpeg4audio.o xiph.o
  OBJS-$(CONFIG_RTPDEC)                  += mjpeg.o
  OBJS-$(CONFIG_SPDIF_DEMUXER)           += aacadtsdec.o mpeg4audio.o
  OBJS-$(CONFIG_SPDIF_MUXER)             += dca.o
  OBJS-$(CONFIG_TAK_DEMUXER)             += tak.o
  OBJS-$(CONFIG_WEBM_MUXER)              += mpeg4audio.o mpegaudiodata.o  \
 -                                          xiph.o flac.o flacdata.o
 +                                          xiph.o flac.o flacdata.o \
 +                                          vorbis_data.o
- OBJS-$(CONFIG_WEBM_DASH_MANIFEST_DEMUXER) += vorbis_parser.o xiph.o
++OBJS-$(CONFIG_WEBM_DASH_MANIFEST_DEMUXER) += xiph.o
  OBJS-$(CONFIG_WTV_DEMUXER)             += mpeg4audio.o mpegaudiodata.o
  
 +# libavfilter dependencies
 +OBJS-$(CONFIG_ELBG_FILTER)             += elbg.o
 +
  # external codec libraries
 +OBJS-$(CONFIG_LIBAACPLUS_ENCODER)         += libaacplus.o
 +OBJS-$(CONFIG_LIBCELT_DECODER)            += libcelt_dec.o
  OBJS-$(CONFIG_LIBFAAC_ENCODER)            += libfaac.o
  OBJS-$(CONFIG_LIBFDK_AAC_DECODER)         += libfdk-aacdec.o
  OBJS-$(CONFIG_LIBFDK_AAC_ENCODER)         += libfdk-aacenc.o
@@@ -744,19 -625,14 +746,19 @@@ OBJS-$(CONFIG_LIBSCHROEDINGER_DECODER
                                               libschroedinger.o
  OBJS-$(CONFIG_LIBSCHROEDINGER_ENCODER)    += libschroedingerenc.o \
                                               libschroedinger.o
 +OBJS-$(CONFIG_LIBSHINE_ENCODER)           += libshine.o
  OBJS-$(CONFIG_LIBSPEEX_DECODER)           += libspeexdec.o
  OBJS-$(CONFIG_LIBSPEEX_ENCODER)           += libspeexenc.o
 +OBJS-$(CONFIG_LIBSTAGEFRIGHT_H264_DECODER)+= libstagefright.o
  OBJS-$(CONFIG_LIBTHEORA_ENCODER)          += libtheoraenc.o
  OBJS-$(CONFIG_LIBTWOLAME_ENCODER)         += libtwolame.o
 +OBJS-$(CONFIG_LIBUTVIDEO_DECODER)         += libutvideodec.o
 +OBJS-$(CONFIG_LIBUTVIDEO_ENCODER)         += libutvideoenc.o
  OBJS-$(CONFIG_LIBVO_AACENC_ENCODER)       += libvo-aacenc.o mpeg4audio.o
  OBJS-$(CONFIG_LIBVO_AMRWBENC_ENCODER)     += libvo-amrwbenc.o
 -OBJS-$(CONFIG_LIBVORBIS_ENCODER)          += libvorbis.o \
 -                                             vorbis_data.o
 +OBJS-$(CONFIG_LIBVORBIS_DECODER)          += libvorbisdec.o
 +OBJS-$(CONFIG_LIBVORBIS_ENCODER)          += libvorbisenc.o \
-                                              vorbis_data.o vorbis_parser.o xiph.o
++                                             vorbis_data.o xiph.o
  OBJS-$(CONFIG_LIBVPX_VP8_DECODER)         += libvpxdec.o
  OBJS-$(CONFIG_LIBVPX_VP8_ENCODER)         += libvpxenc.o
  OBJS-$(CONFIG_LIBVPX_VP9_DECODER)         += libvpxdec.o libvpx.o
@@@ -812,10 -683,9 +814,10 @@@ OBJS-$(CONFIG_TAK_PARSER)              
  OBJS-$(CONFIG_VC1_PARSER)              += vc1_parser.o vc1.o vc1data.o vc1dsp.o \
                                            msmpeg4.o msmpeg4data.o mpeg4video.o \
                                            h263.o
- OBJS-$(CONFIG_VORBIS_PARSER)           += vorbis_parser.o xiph.o
+ OBJS-$(CONFIG_VORBIS_PARSER)           += xiph.o
  OBJS-$(CONFIG_VP3_PARSER)              += vp3_parser.o
  OBJS-$(CONFIG_VP8_PARSER)              += vp8_parser.o
 +OBJS-$(CONFIG_VP9_PARSER)              += vp9_parser.o
  
  # bitstream filters
  OBJS-$(CONFIG_AAC_ADTSTOASC_BSF)          += aac_adtstoasc_bsf.o aacadtsdec.o \
  #include "libavutil/opt.h"
  #include "avcodec.h"
  #include "audio_frame_queue.h"
 -#include "bytestream.h"
  #include "internal.h"
  #include "vorbis.h"
- #include "vorbis_parser.h"
+ #include "vorbis_parser_internal.h"
  
 -#undef NDEBUG
 -#include <assert.h>
  
  /* Number of samples the user should send in each call.
   * This value is used because it is the LCD of all possible frame sizes, so
@@@ -29,8 -29,8 +29,8 @@@
  #include "libavutil/version.h"
  
  #define LIBAVCODEC_VERSION_MAJOR 56
- #define LIBAVCODEC_VERSION_MINOR  10
- #define LIBAVCODEC_VERSION_MICRO 102
 -#define LIBAVCODEC_VERSION_MINOR  6
 -#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, \
@@@ -258,18 -243,51 +259,57 @@@ bad_packet
      return duration;
  }
  
- int avpriv_vorbis_parse_frame(AVVorbisParseContext *s, const uint8_t *buf,
-                               int buf_size)
++int av_vorbis_parse_frame(AVVorbisParseContext *s, const uint8_t *buf,
++                          int buf_size)
 +{
 +    return avpriv_vorbis_parse_frame_flags(s, buf, buf_size, NULL);
 +}
 +
- void avpriv_vorbis_parse_reset(AVVorbisParseContext *s)
+ void av_vorbis_parse_reset(AVVorbisParseContext *s)
  {
      if (s->valid_extradata)
 -        s->previous_blocksize = s->mode_blocksize[0];
 +        s->previous_blocksize = s->blocksize[0];
  }
  
+ void av_vorbis_parse_free(AVVorbisParseContext **s)
+ {
+     av_freep(s);
+ }
+ AVVorbisParseContext *av_vorbis_parse_init(const uint8_t *extradata,
+                                            int extradata_size)
+ {
+     AVVorbisParseContext *s = av_mallocz(sizeof(*s));
+     int ret;
+     if (!s)
+         return NULL;
+     ret = vorbis_parse_init(s, extradata, extradata_size);
+     if (ret < 0) {
+         av_vorbis_parse_free(&s);
+         return NULL;
+     }
+     return s;
+ }
+ #if LIBAVCODEC_VERSION_MAJOR < 57
+ int avpriv_vorbis_parse_extradata(AVCodecContext *avctx, AVVorbisParseContext *s)
+ {
+     return vorbis_parse_init(s, avctx->extradata, avctx->extradata_size);
+ }
+ void avpriv_vorbis_parse_reset(AVVorbisParseContext *s)
+ {
+     av_vorbis_parse_reset(s);
+ }
+ int avpriv_vorbis_parse_frame(AVVorbisParseContext *s, const uint8_t *buf,
+                               int buf_size)
+ {
+     return av_vorbis_parse_frame(s, buf, buf_size);
+ }
+ #endif
  #if CONFIG_VORBIS_PARSER
  static int vorbis_parse(AVCodecParserContext *s1, AVCodecContext *avctx,
                          const uint8_t **poutbuf, int *poutbuf_size,
@@@ -1,9 -1,8 +1,8 @@@
  /*
-  * Copyright (c) 2012 Justin Ruggles
   *
 - * 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.
@@@ -48,26 -35,14 +35,32 @@@ typedef struct AVVorbisParseContext AVV
   * @param avctx codec context
   * @param s     Vorbis parser context
   */
- int avpriv_vorbis_parse_extradata(AVCodecContext *avctx, AVVorbisParseContext *s);
+ AVVorbisParseContext *av_vorbis_parse_init(const uint8_t *extradata,
+                                            int extradata_size);
+ /**
+  * Free the parser and everything associated with it.
+  */
+ void av_vorbis_parse_free(AVVorbisParseContext **s);
  
 +#define VORBIS_FLAG_HEADER  0x00000001
 +#define VORBIS_FLAG_COMMENT 0x00000002
 +
 +/**
 + * Get the duration for a Vorbis packet.
 + *
 + * avpriv_vorbis_parse_extradata() must have been successfully called prior to
 + * this in order for a correct duration to be returned. If @p flags is @c NULL,
 + * special frames are considered invalid.
 + *
 + * @param s        Vorbis parser context
 + * @param buf      buffer containing a Vorbis frame
 + * @param buf_size size of the buffer
 + * @param flags    flags for special frames
 + */
 +int avpriv_vorbis_parse_frame_flags(AVVorbisParseContext *s, const uint8_t *buf,
 +                                    int buf_size, int *flags);
 +
  /**
   * Get the duration for a Vorbis packet.
   *
index 0000000,8f76af7..885793f
mode 000000,100644..100644
--- /dev/null
@@@ -1,0 -1,71 +1,71 @@@
 - * This file is part of Libav.
+ /*
+  * Copyright (c) 2012 Justin Ruggles
+  *
 - * Libav is free software; you can redistribute it and/or
++ * This file is part of FFmpeg.
+  *
 - * Libav is distributed in the hope that it will be useful,
++ * FFmpeg is free software; you can redistribute it and/or
+  * modify it under the terms of the GNU Lesser General Public
+  * License as published by the Free Software Foundation; either
+  * version 2.1 of the License, or (at your option) any later version.
+  *
 - * License along with Libav; if not, write to the Free Software
++ * FFmpeg is distributed in the hope that it will be useful,
+  * but WITHOUT ANY WARRANTY; without even the implied warranty of
+  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+  * Lesser General Public License for more details.
+  *
+  * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
+  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+  */
+ /**
+  * @file
+  * Vorbis audio parser
+  *
+  * Determines the duration for each packet.
+  */
+ #ifndef AVCODEC_VORBIS_PARSER_H
+ #define AVCODEC_VORBIS_PARSER_H
+ #include "avcodec.h"
+ #include "vorbis_parser.h"
+ struct AVVorbisParseContext {
+     const AVClass *class;
+     int extradata_parsed;       ///< we have attempted to parse extradata
+     int valid_extradata;        ///< extradata is valid, so we can calculate duration
+     int blocksize[2];           ///< short and long window sizes
+     int previous_blocksize;     ///< previous window size
+     int mode_blocksize[64];     ///< window size mapping for each mode
+     int mode_count;             ///< number of modes
+     int mode_mask;              ///< bitmask used to get the mode in each packet
+     int prev_mask;              ///< bitmask used to get the previous mode flag in each packet
+ };
+ #if LIBAVCODEC_VERSION_MAJOR < 57
+ /**
+  * Initialize the Vorbis parser using headers in the extradata.
+  *
+  * @param avctx codec context
+  * @param s     Vorbis parser context
+  */
+ int avpriv_vorbis_parse_extradata(AVCodecContext *avctx, AVVorbisParseContext *s);
+ /**
+  * Get the duration for a Vorbis packet.
+  *
+  * avpriv_vorbis_parse_extradata() must have been successfully called prior to
+  * this in order for a correct duration to be returned.
+  *
+  * @param s        Vorbis parser context
+  * @param buf      buffer containing a Vorbis frame
+  * @param buf_size size of the buffer
+  */
+ int avpriv_vorbis_parse_frame(AVVorbisParseContext *s, const uint8_t *buf,
+                               int buf_size);
+ void avpriv_vorbis_parse_reset(AVVorbisParseContext *s);
+ #endif
+ #endif /* AVCODEC_VORBIS_PARSER_H */
Simple merge