mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-04 01:36:07 +00:00
Merge remote-tracking branch 'qatar/master'
* qatar/master: (47 commits) lavc: hide private symbols. lavc: deprecate img_get_alpha_info(). lavc: use avpriv_ prefix for ff_toupper4. lavc: use avpriv_ prefix for ff_copy_bits and align_put_bits. lavc: use avpriv_ prefix for ff_ac3_parse_header. lavc: use avpriv_ prefix for ff_frame_rate_tab. lavc: rename ff_find_start_code to avpriv_mpv_find_start_code lavc: use avpriv_ prefix for ff_split_xiph_headers. lavc: use avpriv_ prefix for ff_dirac_parse_sequence_header. lavc: use avpriv_ prefix for some dv symbols used in lavf. lavc: use avpriv_ prefix for some flac symbols used in lavf. lavc: use avpriv_ prefix for some mpeg4audio symbols used in lavf. lavc: use avpriv_ prefix for some mpegaudio symbols used in lavf. lavc: use avpriv_ prefix for ff_aac_parse_header(). lavf: hide private symbols. lavf: use avpriv_ prefix for some dv functions. lavf: use avpriv_ prefix for ff_new_chapter(). avcodec: add CODEC_CAP_DELAY note to avcodec_decode_audio3() documentation avcodec: clarify the CODEC_CAP_DELAY note in avcodec_decode_video2() avcodec: clarify documentation of CODEC_CAP_DELAY ... Conflicts: configure doc/general.texi libavcodec/Makefile libavcodec/aacdec.c libavcodec/allcodecs.c libavcodec/avcodec.h libavcodec/dv.c libavcodec/dvdata.c libavcodec/dvdata.h libavcodec/libspeexenc.c libavcodec/mpegvideo.c libavcodec/version.h libavformat/avidec.c libavformat/dv.c libavformat/dv.h libavformat/flvenc.c libavformat/mov.c libavformat/mp3enc.c libavformat/oggparsespeex.c Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
commit
dd8ffc1925
@ -66,6 +66,7 @@ easier to use. The changes are:
|
||||
- libutvideo wrapper (--enable-libutvideo)
|
||||
- aevalsrc audio source added
|
||||
- Ut Video decoder
|
||||
- Speex encoding via libspeex
|
||||
|
||||
|
||||
version 0.8:
|
||||
|
2
configure
vendored
2
configure
vendored
@ -182,7 +182,7 @@ External library support:
|
||||
--enable-libopenjpeg enable JPEG 2000 decoding via OpenJPEG [no]
|
||||
--enable-librtmp enable RTMP[E] support via librtmp [no]
|
||||
--enable-libschroedinger enable Dirac support via libschroedinger [no]
|
||||
--enable-libspeex enable Speex encoding and decoding via libspeex [no]
|
||||
--enable-libspeex enable Speex support via libspeex [no]
|
||||
--enable-libstagefright-h264 enable H.264 decoding via libstagefright [no]
|
||||
--enable-libtheora enable Theora encoding via libtheora [no]
|
||||
--enable-libutvideo enable Ut Video decoding via libutvideo [no]
|
||||
|
@ -702,6 +702,7 @@ SKIPHEADERS-$(CONFIG_LIBSCHROEDINGER) += libschroedinger.h
|
||||
SKIPHEADERS-$(CONFIG_VAAPI) += vaapi_internal.h
|
||||
SKIPHEADERS-$(CONFIG_VDPAU) += vdpau.h
|
||||
SKIPHEADERS-$(CONFIG_XVMC) += xvmc.h
|
||||
SKIPHEADERS-$(HAVE_W32THREADS) += w32pthreads.h
|
||||
|
||||
TESTPROGS = cabac dct fft fft-fixed h264 iirfilter rangecoder snow
|
||||
TESTPROGS-$(HAVE_MMX) += motion
|
||||
|
@ -55,7 +55,7 @@ static int aac_adtstoasc_filter(AVBitStreamFilterContext *bsfc,
|
||||
if (show_bits(&gb, 12) != 0xfff)
|
||||
return 0;
|
||||
|
||||
if (ff_aac_parse_header(&gb, &hdr) < 0) {
|
||||
if (avpriv_aac_parse_header(&gb, &hdr) < 0) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Error parsing ADTS frame header!\n");
|
||||
return -1;
|
||||
}
|
||||
@ -78,7 +78,7 @@ static int aac_adtstoasc_filter(AVBitStreamFilterContext *bsfc,
|
||||
return -1;
|
||||
}
|
||||
init_put_bits(&pb, pce_data, MAX_PCE_SIZE);
|
||||
pce_size = ff_copy_pce_data(&pb, &gb)/8;
|
||||
pce_size = avpriv_copy_pce_data(&pb, &gb)/8;
|
||||
flush_put_bits(&pb);
|
||||
buf_size -= get_bits_count(&gb)/8;
|
||||
buf += get_bits_count(&gb)/8;
|
||||
|
@ -40,7 +40,7 @@ static int aac_sync(uint64_t state, AACAC3ParseContext *hdr_info,
|
||||
tmp.u64 = av_be2ne64(state);
|
||||
init_get_bits(&bits, tmp.u8+8-AAC_ADTS_HEADER_SIZE, AAC_ADTS_HEADER_SIZE * 8);
|
||||
|
||||
if ((size = ff_aac_parse_header(&bits, &hdr)) < 0)
|
||||
if ((size = avpriv_aac_parse_header(&bits, &hdr)) < 0)
|
||||
return 0;
|
||||
*need_next_header = 0;
|
||||
*new_frame_start = 1;
|
||||
|
@ -26,7 +26,7 @@
|
||||
#include "get_bits.h"
|
||||
#include "mpeg4audio.h"
|
||||
|
||||
int ff_aac_parse_header(GetBitContext *gbc, AACADTSHeaderInfo *hdr)
|
||||
int avpriv_aac_parse_header(GetBitContext *gbc, AACADTSHeaderInfo *hdr)
|
||||
{
|
||||
int size, rdb, ch, sr;
|
||||
int aot, crc_abs;
|
||||
@ -39,7 +39,7 @@ int ff_aac_parse_header(GetBitContext *gbc, AACADTSHeaderInfo *hdr)
|
||||
crc_abs = get_bits1(gbc); /* protection_absent */
|
||||
aot = get_bits(gbc, 2); /* profile_objecttype */
|
||||
sr = get_bits(gbc, 4); /* sample_frequency_index */
|
||||
if(!ff_mpeg4audio_sample_rates[sr])
|
||||
if(!avpriv_mpeg4audio_sample_rates[sr])
|
||||
return AAC_AC3_PARSE_ERROR_SAMPLE_RATE;
|
||||
skip_bits1(gbc); /* private_bit */
|
||||
ch = get_bits(gbc, 3); /* channel_configuration */
|
||||
@ -62,7 +62,7 @@ int ff_aac_parse_header(GetBitContext *gbc, AACADTSHeaderInfo *hdr)
|
||||
hdr->crc_absent = crc_abs;
|
||||
hdr->num_aac_frames = rdb + 1;
|
||||
hdr->sampling_index = sr;
|
||||
hdr->sample_rate = ff_mpeg4audio_sample_rates[sr];
|
||||
hdr->sample_rate = avpriv_mpeg4audio_sample_rates[sr];
|
||||
hdr->samples = (rdb + 1) * 1024;
|
||||
hdr->bit_rate = size * 8 * hdr->sample_rate / hdr->samples;
|
||||
|
||||
|
@ -49,6 +49,6 @@ typedef struct {
|
||||
* -2 if the version element is invalid, -3 if the sample rate
|
||||
* element is invalid, or -4 if the bit rate element is invalid.
|
||||
*/
|
||||
int ff_aac_parse_header(GetBitContext *gbc, AACADTSHeaderInfo *hdr);
|
||||
int avpriv_aac_parse_header(GetBitContext *gbc, AACADTSHeaderInfo *hdr);
|
||||
|
||||
#endif /* AVCODEC_AACADTSDEC_H */
|
||||
|
@ -472,7 +472,7 @@ static int decode_audio_specific_config(AACContext *ac,
|
||||
|
||||
init_get_bits(&gb, data, data_size * 8);
|
||||
|
||||
if ((i = ff_mpeg4audio_get_config(m4ac, data, asclen/8)) < 0)
|
||||
if ((i = avpriv_mpeg4audio_get_config(m4ac, data, asclen/8)) < 0)
|
||||
return -1;
|
||||
if (m4ac->sampling_index > 12) {
|
||||
av_log(avctx, AV_LOG_ERROR, "invalid sampling rate index %d\n", m4ac->sampling_index);
|
||||
@ -2077,7 +2077,7 @@ static int parse_adts_frame_header(AACContext *ac, GetBitContext *gb)
|
||||
int size;
|
||||
AACADTSHeaderInfo hdr_info;
|
||||
|
||||
size = ff_aac_parse_header(gb, &hdr_info);
|
||||
size = avpriv_aac_parse_header(gb, &hdr_info);
|
||||
if (size > 0) {
|
||||
if (hdr_info.chan_config) {
|
||||
enum ChannelPosition new_che_pos[4][MAX_ELEM_ID];
|
||||
|
@ -180,7 +180,7 @@ static av_cold int aac_encode_init(AVCodecContext *avctx)
|
||||
avctx->frame_size = 1024;
|
||||
|
||||
for (i = 0; i < 16; i++)
|
||||
if (avctx->sample_rate == ff_mpeg4audio_sample_rates[i])
|
||||
if (avctx->sample_rate == avpriv_mpeg4audio_sample_rates[i])
|
||||
break;
|
||||
if (i == 16) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Unsupported sample rate %d\n", avctx->sample_rate);
|
||||
@ -491,7 +491,7 @@ static void put_bitstream_info(AVCodecContext *avctx, AACEncContext *s,
|
||||
put_bits(&s->pb, 8, namelen - 16);
|
||||
put_bits(&s->pb, 4, 0); //extension type - filler
|
||||
padbits = 8 - (put_bits_count(&s->pb) & 7);
|
||||
align_put_bits(&s->pb);
|
||||
avpriv_align_put_bits(&s->pb);
|
||||
for (i = 0; i < namelen - 2; i++)
|
||||
put_bits(&s->pb, 8, name[i]);
|
||||
put_bits(&s->pb, 12 - padbits, 0);
|
||||
|
@ -35,7 +35,7 @@ static const uint8_t eac3_blocks[4] = {
|
||||
};
|
||||
|
||||
|
||||
int ff_ac3_parse_header(GetBitContext *gbc, AC3HeaderInfo *hdr)
|
||||
int avpriv_ac3_parse_header(GetBitContext *gbc, AC3HeaderInfo *hdr)
|
||||
{
|
||||
int frame_size_code;
|
||||
|
||||
@ -141,7 +141,7 @@ static int ac3_sync(uint64_t state, AACAC3ParseContext *hdr_info,
|
||||
GetBitContext gbc;
|
||||
|
||||
init_get_bits(&gbc, tmp.u8+8-AC3_HEADER_SIZE, 54);
|
||||
err = ff_ac3_parse_header(&gbc, &hdr);
|
||||
err = avpriv_ac3_parse_header(&gbc, &hdr);
|
||||
|
||||
if(err < 0)
|
||||
return 0;
|
||||
|
@ -36,6 +36,6 @@
|
||||
* -2 if the bsid (version) element is invalid, -3 if the fscod (sample rate)
|
||||
* element is invalid, or -4 if the frmsizecod (bit rate) element is invalid.
|
||||
*/
|
||||
int ff_ac3_parse_header(GetBitContext *gbc, AC3HeaderInfo *hdr);
|
||||
int avpriv_ac3_parse_header(GetBitContext *gbc, AC3HeaderInfo *hdr);
|
||||
|
||||
#endif /* AVCODEC_AC3_PARSER_H */
|
||||
|
@ -261,7 +261,7 @@ static int parse_frame_header(AC3DecodeContext *s)
|
||||
AC3HeaderInfo hdr;
|
||||
int err;
|
||||
|
||||
err = ff_ac3_parse_header(&s->gbc, &hdr);
|
||||
err = avpriv_ac3_parse_header(&s->gbc, &hdr);
|
||||
if(err)
|
||||
return err;
|
||||
|
||||
|
@ -289,7 +289,7 @@ static av_cold int read_specific_config(ALSDecContext *ctx)
|
||||
|
||||
init_get_bits(&gb, avctx->extradata, avctx->extradata_size * 8);
|
||||
|
||||
config_offset = ff_mpeg4audio_get_config(&m4ac, avctx->extradata,
|
||||
config_offset = avpriv_mpeg4audio_get_config(&m4ac, avctx->extradata,
|
||||
avctx->extradata_size);
|
||||
|
||||
if (config_offset < 0)
|
||||
|
@ -497,7 +497,7 @@ static int encode_frame(AVCodecContext *avctx, unsigned char *buf, int buf_size,
|
||||
}
|
||||
emms_c();
|
||||
|
||||
align_put_bits(&a->pb);
|
||||
avpriv_align_put_bits(&a->pb);
|
||||
while(put_bits_count(&a->pb)&31)
|
||||
put_bits(&a->pb, 8, 0);
|
||||
|
||||
|
@ -210,8 +210,10 @@ enum CodecID {
|
||||
CODEC_ID_DFA,
|
||||
CODEC_ID_WMV3IMAGE,
|
||||
CODEC_ID_VC1IMAGE,
|
||||
#if LIBAVCODEC_VERSION_MAJOR == 53
|
||||
CODEC_ID_8SVX_RAW,
|
||||
CODEC_ID_G2M,
|
||||
#endif
|
||||
CODEC_ID_UTVIDEO_DEPRECATED,
|
||||
CODEC_ID_UTVIDEO = 0x800,
|
||||
|
||||
@ -676,8 +678,10 @@ typedef struct RcOverride{
|
||||
/* Codec can export data for HW decoding (XvMC). */
|
||||
#define CODEC_CAP_HWACCEL 0x0010
|
||||
/**
|
||||
* Codec has a nonzero delay and needs to be fed with NULL at the end to get the delayed data.
|
||||
* If this is not set, the codec is guaranteed to never be fed with NULL data.
|
||||
* Codec has a nonzero delay and needs to be fed with avpkt->data=NULL,
|
||||
* avpkt->size=0 at the end to get the delayed data until the decoder no longer
|
||||
* returns frames. If this is not set, the codec is guaranteed to never be fed
|
||||
* with NULL data.
|
||||
*/
|
||||
#define CODEC_CAP_DELAY 0x0020
|
||||
/**
|
||||
@ -3608,6 +3612,7 @@ enum PixelFormat avcodec_find_best_pix_fmt(int64_t pix_fmt_mask, enum PixelForma
|
||||
enum PixelFormat avcodec_find_best_pix_fmt2(enum PixelFormat dst_pix_fmt1, enum PixelFormat dst_pix_fmt2,
|
||||
enum PixelFormat src_pix_fmt, int has_alpha, int *loss_ptr);
|
||||
|
||||
#if FF_API_GET_ALPHA_INFO
|
||||
#define FF_ALPHA_TRANSP 0x0001 /* image has some totally transparent pixels */
|
||||
#define FF_ALPHA_SEMI_TRANSP 0x0002 /* image has some transparent pixels */
|
||||
|
||||
@ -3615,8 +3620,10 @@ enum PixelFormat avcodec_find_best_pix_fmt2(enum PixelFormat dst_pix_fmt1, enum
|
||||
* Tell if an image really has transparent alpha values.
|
||||
* @return ored mask of FF_ALPHA_xxx constants
|
||||
*/
|
||||
attribute_deprecated
|
||||
int img_get_alpha_info(const AVPicture *src,
|
||||
enum PixelFormat pix_fmt, int width, int height);
|
||||
#endif
|
||||
|
||||
/* deinterlace a picture */
|
||||
/* deinterlace - if not supported return -1 */
|
||||
@ -3940,6 +3947,10 @@ int avcodec_open2(AVCodecContext *avctx, AVCodec *codec, AVDictionary **options)
|
||||
* samples should be 16 byte aligned unless the CPU doesn't need it
|
||||
* (AltiVec and SSE do).
|
||||
*
|
||||
* @note Codecs which have the CODEC_CAP_DELAY capability set have a delay
|
||||
* between input and output, these need to be fed with avpkt->data=NULL,
|
||||
* avpkt->size=0 at the end to return the remaining frames.
|
||||
*
|
||||
* @param avctx the codec context
|
||||
* @param[out] samples the output buffer, sample type in avctx->sample_fmt
|
||||
* @param[in,out] frame_size_ptr the output buffer size in bytes
|
||||
@ -3973,8 +3984,9 @@ int avcodec_decode_audio3(AVCodecContext *avctx, int16_t *samples,
|
||||
*
|
||||
* In practice, avpkt->data should have 4 byte alignment at minimum.
|
||||
*
|
||||
* @note Some codecs have a delay between input and output, these need to be
|
||||
* fed with avpkt->data=NULL, avpkt->size=0 at the end to return the remaining frames.
|
||||
* @note Codecs which have the CODEC_CAP_DELAY capability set have a delay
|
||||
* between input and output, these need to be fed with avpkt->data=NULL,
|
||||
* avpkt->size=0 at the end to return the remaining frames.
|
||||
*
|
||||
* @param avctx the codec context
|
||||
* @param[out] picture The AVFrame in which the decoded video frame will be stored.
|
||||
|
@ -41,7 +41,7 @@ const uint8_t ff_log2_run[41]={
|
||||
24,
|
||||
};
|
||||
|
||||
void align_put_bits(PutBitContext *s)
|
||||
void avpriv_align_put_bits(PutBitContext *s)
|
||||
{
|
||||
put_bits(s,s->bit_left & 7,0);
|
||||
}
|
||||
@ -56,7 +56,7 @@ void ff_put_string(PutBitContext *pb, const char *string, int terminate_string)
|
||||
put_bits(pb, 8, 0);
|
||||
}
|
||||
|
||||
void ff_copy_bits(PutBitContext *pb, const uint8_t *src, int length)
|
||||
void avpriv_copy_bits(PutBitContext *pb, const uint8_t *src, int length)
|
||||
{
|
||||
int words= length>>4;
|
||||
int bits= length&15;
|
||||
|
@ -625,8 +625,8 @@ static int decode_seq_header(AVSContext *h) {
|
||||
s->low_delay = get_bits1(&s->gb);
|
||||
h->mb_width = (s->width + 15) >> 4;
|
||||
h->mb_height = (s->height + 15) >> 4;
|
||||
h->s.avctx->time_base.den = ff_frame_rate_tab[frame_rate_code].num;
|
||||
h->s.avctx->time_base.num = ff_frame_rate_tab[frame_rate_code].den;
|
||||
h->s.avctx->time_base.den = avpriv_frame_rate_tab[frame_rate_code].num;
|
||||
h->s.avctx->time_base.num = avpriv_frame_rate_tab[frame_rate_code].den;
|
||||
h->s.avctx->width = s->width;
|
||||
h->s.avctx->height = s->height;
|
||||
if(!h->top_qp)
|
||||
@ -664,7 +664,7 @@ static int cavs_decode_frame(AVCodecContext * avctx,void *data, int *data_size,
|
||||
buf_ptr = buf;
|
||||
buf_end = buf + buf_size;
|
||||
for(;;) {
|
||||
buf_ptr = ff_find_start_code(buf_ptr,buf_end, &stc);
|
||||
buf_ptr = avpriv_mpv_find_start_code(buf_ptr,buf_end, &stc);
|
||||
if((stc & 0xFFFFFE00) || buf_ptr == buf_end)
|
||||
return FFMAX(0, buf_ptr - buf - s->parse_context.last_index);
|
||||
input_size = (buf_end - buf_ptr)*8;
|
||||
|
@ -105,7 +105,7 @@ static int encode_frame(AVCodecContext *avctx, unsigned char *buf, int buf_size,
|
||||
|
||||
emms_c();
|
||||
|
||||
align_put_bits(&a->pb);
|
||||
avpriv_align_put_bits(&a->pb);
|
||||
while(get_bit_count(&a->pb)&31)
|
||||
put_bits(&a->pb, 8, 0);
|
||||
|
||||
|
@ -145,7 +145,7 @@ static int parse_source_parameters(AVCodecContext *avctx, GetBitContext *gb,
|
||||
}
|
||||
if (source->frame_rate_index > 0) {
|
||||
if (source->frame_rate_index <= 8)
|
||||
frame_rate = ff_frame_rate_tab[source->frame_rate_index];
|
||||
frame_rate = avpriv_frame_rate_tab[source->frame_rate_index];
|
||||
else
|
||||
frame_rate = dirac_frame_rate[source->frame_rate_index-9];
|
||||
}
|
||||
@ -242,7 +242,7 @@ static int parse_source_parameters(AVCodecContext *avctx, GetBitContext *gb,
|
||||
return 0;
|
||||
}
|
||||
|
||||
int ff_dirac_parse_sequence_header(AVCodecContext *avctx, GetBitContext *gb,
|
||||
int avpriv_dirac_parse_sequence_header(AVCodecContext *avctx, GetBitContext *gb,
|
||||
dirac_source_params *source)
|
||||
{
|
||||
unsigned version_major;
|
||||
|
@ -51,7 +51,7 @@ typedef struct {
|
||||
uint8_t color_spec_index; ///< index into dirac_color_spec_presets[]
|
||||
} dirac_source_params;
|
||||
|
||||
int ff_dirac_parse_sequence_header(AVCodecContext *avctx, GetBitContext *gb,
|
||||
dirac_source_params *source);
|
||||
int avpriv_dirac_parse_sequence_header(AVCodecContext *avctx, GetBitContext *gb,
|
||||
dirac_source_params *source);
|
||||
|
||||
#endif /* AVCODEC_DIRAC_H */
|
||||
|
@ -349,7 +349,7 @@ static av_cold int dvvideo_init(AVCodecContext *avctx)
|
||||
|
||||
static av_cold int dvvideo_init_encoder(AVCodecContext *avctx)
|
||||
{
|
||||
if (!ff_dv_codec_profile(avctx)) {
|
||||
if (!avpriv_dv_codec_profile(avctx)) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Found no DV profile for %ix%i %s video\n",
|
||||
avctx->width, avctx->height, av_get_pix_fmt_name(avctx->pix_fmt));
|
||||
return -1;
|
||||
@ -1072,7 +1072,7 @@ static int dvvideo_decode_frame(AVCodecContext *avctx,
|
||||
const uint8_t* vsc_pack;
|
||||
int apt, is16_9;
|
||||
|
||||
s->sys = ff_dv_frame_profile2(avctx, s->sys, buf, buf_size);
|
||||
s->sys = avpriv_dv_frame_profile2(avctx, s->sys, buf, buf_size);
|
||||
if (!s->sys || buf_size < s->sys->frame_size || dv_init_dynamic_tables(s->sys)) {
|
||||
av_log(avctx, AV_LOG_ERROR, "could not find dv frame profile\n");
|
||||
return -1; /* NOTE: we only accept several full frames */
|
||||
@ -1246,7 +1246,7 @@ static int dvvideo_encode_frame(AVCodecContext *c, uint8_t *buf, int buf_size,
|
||||
{
|
||||
DVVideoContext *s = c->priv_data;
|
||||
|
||||
s->sys = ff_dv_codec_profile(c);
|
||||
s->sys = avpriv_dv_codec_profile(c);
|
||||
if (!s->sys || buf_size < s->sys->frame_size || dv_init_dynamic_tables(s->sys))
|
||||
return -1;
|
||||
|
||||
|
@ -246,7 +246,7 @@ static const DVprofile dv_profiles[] = {
|
||||
}
|
||||
};
|
||||
|
||||
const DVprofile* ff_dv_frame_profile2(AVCodecContext* codec, const DVprofile *sys,
|
||||
const DVprofile* avpriv_dv_frame_profile2(AVCodecContext* codec, const DVprofile *sys,
|
||||
const uint8_t* frame, unsigned buf_size)
|
||||
{
|
||||
int i, dsf, stype;
|
||||
@ -276,13 +276,13 @@ const DVprofile* ff_dv_frame_profile2(AVCodecContext* codec, const DVprofile *sy
|
||||
return NULL;
|
||||
}
|
||||
|
||||
const DVprofile* ff_dv_frame_profile(const DVprofile *sys,
|
||||
const DVprofile* avpriv_dv_frame_profile(const DVprofile *sys,
|
||||
const uint8_t* frame, unsigned buf_size)
|
||||
{
|
||||
return ff_dv_frame_profile2(NULL, sys, frame, buf_size);
|
||||
return avpriv_dv_frame_profile2(NULL, sys, frame, buf_size);
|
||||
}
|
||||
|
||||
const DVprofile* ff_dv_codec_profile(AVCodecContext* codec)
|
||||
const DVprofile* avpriv_dv_codec_profile(AVCodecContext* codec)
|
||||
{
|
||||
int i;
|
||||
|
||||
|
@ -274,11 +274,11 @@ enum dv_pack_type {
|
||||
*/
|
||||
#define DV_MAX_BPM 8
|
||||
|
||||
const DVprofile* ff_dv_frame_profile(const DVprofile *sys,
|
||||
const DVprofile* avpriv_dv_frame_profile(const DVprofile *sys,
|
||||
const uint8_t* frame, unsigned buf_size);
|
||||
const DVprofile* ff_dv_frame_profile2(AVCodecContext* codec, const DVprofile *sys,
|
||||
const DVprofile* avpriv_dv_frame_profile2(AVCodecContext* codec, const DVprofile *sys,
|
||||
const uint8_t* frame, unsigned buf_size);
|
||||
const DVprofile* ff_dv_codec_profile(AVCodecContext* codec);
|
||||
const DVprofile* avpriv_dv_codec_profile(AVCodecContext* codec);
|
||||
|
||||
static inline int dv_write_dif_id(enum dv_section_type t, uint8_t chan_num,
|
||||
uint8_t seq_num, uint8_t dif_num,
|
||||
|
@ -95,8 +95,8 @@ typedef struct FLACFrameInfo {
|
||||
* @param[out] s where parsed information is stored
|
||||
* @param[in] buffer pointer to start of 34-byte streaminfo data
|
||||
*/
|
||||
void ff_flac_parse_streaminfo(AVCodecContext *avctx, struct FLACStreaminfo *s,
|
||||
const uint8_t *buffer);
|
||||
void avpriv_flac_parse_streaminfo(AVCodecContext *avctx, struct FLACStreaminfo *s,
|
||||
const uint8_t *buffer);
|
||||
|
||||
/**
|
||||
* Validate the FLAC extradata.
|
||||
@ -105,9 +105,9 @@ void ff_flac_parse_streaminfo(AVCodecContext *avctx, struct FLACStreaminfo *s,
|
||||
* @param[out] streaminfo_start pointer to start of 34-byte STREAMINFO data.
|
||||
* @return 1 if valid, 0 if not valid.
|
||||
*/
|
||||
int ff_flac_is_extradata_valid(AVCodecContext *avctx,
|
||||
enum FLACExtradataFormat *format,
|
||||
uint8_t **streaminfo_start);
|
||||
int avpriv_flac_is_extradata_valid(AVCodecContext *avctx,
|
||||
enum FLACExtradataFormat *format,
|
||||
uint8_t **streaminfo_start);
|
||||
|
||||
/**
|
||||
* Parse the metadata block parameters from the header.
|
||||
@ -116,8 +116,8 @@ int ff_flac_is_extradata_valid(AVCodecContext *avctx,
|
||||
* @param[out] type metadata block type
|
||||
* @param[out] size metadata block size
|
||||
*/
|
||||
void ff_flac_parse_block_header(const uint8_t *block_header,
|
||||
int *last, int *type, int *size);
|
||||
void avpriv_flac_parse_block_header(const uint8_t *block_header,
|
||||
int *last, int *type, int *size);
|
||||
|
||||
/**
|
||||
* Calculate an estimate for the maximum frame size based on verbatim mode.
|
||||
|
@ -63,7 +63,7 @@ typedef struct FLACContext {
|
||||
|
||||
static void allocate_buffers(FLACContext *s);
|
||||
|
||||
int ff_flac_is_extradata_valid(AVCodecContext *avctx,
|
||||
int avpriv_flac_is_extradata_valid(AVCodecContext *avctx,
|
||||
enum FLACExtradataFormat *format,
|
||||
uint8_t **streaminfo_start)
|
||||
{
|
||||
@ -104,11 +104,11 @@ static av_cold int flac_decode_init(AVCodecContext *avctx)
|
||||
if (!avctx->extradata)
|
||||
return 0;
|
||||
|
||||
if (!ff_flac_is_extradata_valid(avctx, &format, &streaminfo))
|
||||
if (!avpriv_flac_is_extradata_valid(avctx, &format, &streaminfo))
|
||||
return -1;
|
||||
|
||||
/* initialize based on the demuxer-supplied streamdata header */
|
||||
ff_flac_parse_streaminfo(avctx, (FLACStreaminfo *)s, streaminfo);
|
||||
avpriv_flac_parse_streaminfo(avctx, (FLACStreaminfo *)s, streaminfo);
|
||||
if (s->bps > 16)
|
||||
avctx->sample_fmt = AV_SAMPLE_FMT_S32;
|
||||
else
|
||||
@ -140,7 +140,7 @@ static void allocate_buffers(FLACContext *s)
|
||||
}
|
||||
}
|
||||
|
||||
void ff_flac_parse_streaminfo(AVCodecContext *avctx, struct FLACStreaminfo *s,
|
||||
void avpriv_flac_parse_streaminfo(AVCodecContext *avctx, struct FLACStreaminfo *s,
|
||||
const uint8_t *buffer)
|
||||
{
|
||||
GetBitContext gb;
|
||||
@ -174,7 +174,7 @@ void ff_flac_parse_streaminfo(AVCodecContext *avctx, struct FLACStreaminfo *s,
|
||||
dump_headers(avctx, s);
|
||||
}
|
||||
|
||||
void ff_flac_parse_block_header(const uint8_t *block_header,
|
||||
void avpriv_flac_parse_block_header(const uint8_t *block_header,
|
||||
int *last, int *type, int *size)
|
||||
{
|
||||
int tmp = bytestream_get_byte(&block_header);
|
||||
@ -201,12 +201,12 @@ static int parse_streaminfo(FLACContext *s, const uint8_t *buf, int buf_size)
|
||||
/* need more data */
|
||||
return 0;
|
||||
}
|
||||
ff_flac_parse_block_header(&buf[4], NULL, &metadata_type, &metadata_size);
|
||||
avpriv_flac_parse_block_header(&buf[4], NULL, &metadata_type, &metadata_size);
|
||||
if (metadata_type != FLAC_METADATA_TYPE_STREAMINFO ||
|
||||
metadata_size != FLAC_STREAMINFO_SIZE) {
|
||||
return AVERROR_INVALIDDATA;
|
||||
}
|
||||
ff_flac_parse_streaminfo(s->avctx, (FLACStreaminfo *)s, &buf[8]);
|
||||
avpriv_flac_parse_streaminfo(s->avctx, (FLACStreaminfo *)s, &buf[8]);
|
||||
allocate_buffers(s);
|
||||
s->got_streaminfo = 1;
|
||||
|
||||
@ -228,7 +228,7 @@ static int get_metadata_size(const uint8_t *buf, int buf_size)
|
||||
do {
|
||||
if (buf_end - buf < 4)
|
||||
return 0;
|
||||
ff_flac_parse_block_header(buf, &metadata_last, NULL, &metadata_size);
|
||||
avpriv_flac_parse_block_header(buf, &metadata_last, NULL, &metadata_size);
|
||||
buf += 4;
|
||||
if (buf_end - buf < metadata_size) {
|
||||
/* need more data in order to read the complete header */
|
||||
|
@ -25,7 +25,7 @@ void ff_flv_encode_picture_header(MpegEncContext * s, int picture_number)
|
||||
{
|
||||
int format;
|
||||
|
||||
align_put_bits(&s->pb);
|
||||
avpriv_align_put_bits(&s->pb);
|
||||
|
||||
put_bits(&s->pb, 17, 1);
|
||||
put_bits(&s->pb, 5, (s->h263_flv-1)); /* 0: h263 escape codes 1: 11-bit escape codes */
|
||||
|
@ -53,7 +53,7 @@ void ff_h261_encode_picture_header(MpegEncContext * s, int picture_number){
|
||||
H261Context * h = (H261Context *) s;
|
||||
int format, temp_ref;
|
||||
|
||||
align_put_bits(&s->pb);
|
||||
avpriv_align_put_bits(&s->pb);
|
||||
|
||||
/* Update the pointer to last GOB */
|
||||
s->ptr_lastgob = put_bits_ptr(&s->pb);
|
||||
|
@ -153,7 +153,7 @@ static inline int parse_nal_units(AVCodecParserContext *s,
|
||||
|
||||
for(;;) {
|
||||
int src_length, dst_length, consumed;
|
||||
buf = ff_find_start_code(buf, buf_end, &state);
|
||||
buf = avpriv_mpv_find_start_code(buf, buf_end, &state);
|
||||
if(buf >= buf_end)
|
||||
break;
|
||||
--buf;
|
||||
|
@ -747,6 +747,7 @@ int av_picture_pad(AVPicture *dst, const AVPicture *src, int height, int width,
|
||||
return 0;
|
||||
}
|
||||
|
||||
#if FF_API_GET_ALPHA_INFO
|
||||
/* NOTE: we scan all the pixels to have an exact information */
|
||||
static int get_alpha_info_pal8(const AVPicture *src, int width, int height)
|
||||
{
|
||||
@ -793,6 +794,7 @@ int img_get_alpha_info(const AVPicture *src,
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
#endif
|
||||
|
||||
#if !(HAVE_MMX && HAVE_YASM)
|
||||
/* filter parameters: [-1 4 2 4 -1] // 8 */
|
||||
|
@ -53,7 +53,7 @@ AVHWAccel *ff_find_hwaccel(enum CodecID codec_id, enum PixelFormat pix_fmt);
|
||||
*/
|
||||
int ff_match_2uint16(const uint16_t (*tab)[2], int size, int a, int b);
|
||||
|
||||
unsigned int ff_toupper4(unsigned int x);
|
||||
unsigned int avpriv_toupper4(unsigned int x);
|
||||
|
||||
/**
|
||||
* does needed setup of pkt_pts/pos and such for (re)get_buffer();
|
||||
|
@ -126,7 +126,7 @@ void h263_encode_picture_header(MpegEncContext * s, int picture_number)
|
||||
coded_frame_rate= 1800000;
|
||||
coded_frame_rate_base= (1000+best_clock_code)*best_divisor;
|
||||
|
||||
align_put_bits(&s->pb);
|
||||
avpriv_align_put_bits(&s->pb);
|
||||
|
||||
/* Update the pointer to last GOB */
|
||||
s->ptr_lastgob = put_bits_ptr(&s->pb);
|
||||
|
@ -357,7 +357,7 @@ static int encode_picture_ls(AVCodecContext *avctx, unsigned char *buf, int buf_
|
||||
put_bits(&pb, 8, v);
|
||||
}
|
||||
}
|
||||
align_put_bits(&pb);
|
||||
avpriv_align_put_bits(&pb);
|
||||
av_free(buf2);
|
||||
|
||||
/* End of image */
|
||||
|
@ -1,9 +1,8 @@
|
||||
LIBAVCODEC_$MAJOR {
|
||||
global: *;
|
||||
local:
|
||||
ff_*_bsf;
|
||||
ff_*_decoder;
|
||||
ff_*_encoder;
|
||||
ff_*_hwaccel;
|
||||
ff_*_parser;
|
||||
global: av*;
|
||||
audio_resample;
|
||||
audio_resample_close;
|
||||
#deprecated, remove after next bump
|
||||
img_get_alpha_info;
|
||||
local: *;
|
||||
};
|
||||
|
@ -1,5 +1,7 @@
|
||||
/*
|
||||
* Copyright (c) 2009 by Xuggle Incorporated. All rights reserved.
|
||||
* Copyright (C) 2009 Justin Ruggles
|
||||
* Copyright (c) 2009 Xuggle Incorporated
|
||||
*
|
||||
* This file is part of FFmpeg.
|
||||
*
|
||||
* FFmpeg is free software; you can redistribute it and/or
|
||||
@ -16,163 +18,307 @@
|
||||
* License along with FFmpeg; if not, write to the Free Software
|
||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
*/
|
||||
#include <libavcodec/avcodec.h>
|
||||
|
||||
/**
|
||||
* @file
|
||||
* libspeex Speex audio encoder
|
||||
*
|
||||
* Usage Guide
|
||||
* This explains the values that need to be set prior to initialization in
|
||||
* order to control various encoding parameters.
|
||||
*
|
||||
* Channels
|
||||
* Speex only supports mono or stereo, so avctx->channels must be set to
|
||||
* 1 or 2.
|
||||
*
|
||||
* Sample Rate / Encoding Mode
|
||||
* Speex has 3 modes, each of which uses a specific sample rate.
|
||||
* narrowband : 8 kHz
|
||||
* wideband : 16 kHz
|
||||
* ultra-wideband : 32 kHz
|
||||
* avctx->sample_rate must be set to one of these 3 values. This will be
|
||||
* used to set the encoding mode.
|
||||
*
|
||||
* Rate Control
|
||||
* VBR mode is turned on by setting CODEC_FLAG_QSCALE in avctx->flags.
|
||||
* avctx->global_quality is used to set the encoding quality.
|
||||
* For CBR mode, avctx->bit_rate can be used to set the constant bitrate.
|
||||
* Alternatively, the 'cbr_quality' option can be set from 0 to 10 to set
|
||||
* a constant bitrate based on quality.
|
||||
* For ABR mode, set avctx->bit_rate and set the 'abr' option to 1.
|
||||
* Approx. Bitrate Range:
|
||||
* narrowband : 2400 - 25600 bps
|
||||
* wideband : 4000 - 43200 bps
|
||||
* ultra-wideband : 4400 - 45200 bps
|
||||
*
|
||||
* Complexity
|
||||
* Encoding complexity is controlled by setting avctx->compression_level.
|
||||
* The valid range is 0 to 10. A higher setting gives generally better
|
||||
* quality at the expense of encoding speed. This does not affect the
|
||||
* bit rate.
|
||||
*
|
||||
* Frames-per-Packet
|
||||
* The encoder defaults to using 1 frame-per-packet. However, it is
|
||||
* sometimes desirable to use multiple frames-per-packet to reduce the
|
||||
* amount of container overhead. This can be done by setting the
|
||||
* 'frames_per_packet' option to a value 1 to 8.
|
||||
*/
|
||||
|
||||
#include <speex/speex.h>
|
||||
#include <speex/speex_header.h>
|
||||
#include <speex/speex_stereo.h>
|
||||
#include "libavutil/mathematics.h"
|
||||
#include "libavutil/opt.h"
|
||||
#include "avcodec.h"
|
||||
#include "internal.h"
|
||||
|
||||
typedef struct {
|
||||
SpeexBits bits;
|
||||
void *enc_state;
|
||||
SpeexHeader header;
|
||||
AVClass *class; ///< AVClass for private options
|
||||
SpeexBits bits; ///< libspeex bitwriter context
|
||||
SpeexHeader header; ///< libspeex header struct
|
||||
void *enc_state; ///< libspeex encoder state
|
||||
int frames_per_packet; ///< number of frames to encode in each packet
|
||||
float vbr_quality; ///< VBR quality 0.0 to 10.0
|
||||
int cbr_quality; ///< CBR quality 0 to 10
|
||||
int abr; ///< flag to enable ABR
|
||||
int pkt_frame_count; ///< frame count for the current packet
|
||||
int lookahead; ///< encoder delay
|
||||
int sample_count; ///< total sample count (used for pts)
|
||||
} LibSpeexEncContext;
|
||||
|
||||
|
||||
static av_cold int libspeex_encode_init(AVCodecContext *avctx)
|
||||
static av_cold void print_enc_params(AVCodecContext *avctx,
|
||||
LibSpeexEncContext *s)
|
||||
{
|
||||
LibSpeexEncContext *s = (LibSpeexEncContext*)avctx->priv_data;
|
||||
const SpeexMode *mode;
|
||||
const char *mode_str = "unknown";
|
||||
|
||||
if ((avctx->sample_fmt != SAMPLE_FMT_S16 && avctx->sample_fmt != SAMPLE_FMT_FLT) ||
|
||||
avctx->sample_rate <= 0 ||
|
||||
avctx->channels <= 0 ||
|
||||
avctx->channels > 2)
|
||||
{
|
||||
av_log(avctx, AV_LOG_ERROR, "Unsupported sample format, rate, or channels for speex");
|
||||
return -1;
|
||||
av_log(avctx, AV_LOG_DEBUG, "channels: %d\n", avctx->channels);
|
||||
switch (s->header.mode) {
|
||||
case SPEEX_MODEID_NB: mode_str = "narrowband"; break;
|
||||
case SPEEX_MODEID_WB: mode_str = "wideband"; break;
|
||||
case SPEEX_MODEID_UWB: mode_str = "ultra-wideband"; break;
|
||||
}
|
||||
|
||||
if (avctx->sample_rate <= 8000)
|
||||
mode = &speex_nb_mode;
|
||||
else if (avctx->sample_rate <= 16000)
|
||||
mode = &speex_wb_mode;
|
||||
else
|
||||
mode = &speex_uwb_mode;
|
||||
|
||||
speex_bits_init(&s->bits);
|
||||
s->enc_state = speex_encoder_init(mode);
|
||||
if (!s->enc_state)
|
||||
{
|
||||
av_log(avctx, AV_LOG_ERROR, "could not initialize speex encoder");
|
||||
return -1;
|
||||
}
|
||||
|
||||
// initialize the header
|
||||
speex_init_header(&s->header, avctx->sample_rate,
|
||||
avctx->channels, mode);
|
||||
|
||||
// TODO: It'd be nice to support VBR here, but
|
||||
// I'm uncertain what AVCodecContext options to use
|
||||
// to signal whether to turn it on.
|
||||
if (avctx->flags & CODEC_FLAG_QSCALE) {
|
||||
spx_int32_t quality = 0;
|
||||
// Map global_quality's mpeg 1/2/4 scale into Speex's 0-10 scale
|
||||
if (avctx->global_quality > FF_LAMBDA_MAX)
|
||||
quality = 0; // lowest possible quality
|
||||
else
|
||||
quality = (spx_int32_t)((FF_LAMBDA_MAX-avctx->global_quality)*10.0/FF_LAMBDA_MAX);
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_SET_QUALITY, &quality);
|
||||
av_log(avctx, AV_LOG_DEBUG, "mode: %s\n", mode_str);
|
||||
if (s->header.vbr) {
|
||||
av_log(avctx, AV_LOG_DEBUG, "rate control: VBR\n");
|
||||
av_log(avctx, AV_LOG_DEBUG, " quality: %f\n", s->vbr_quality);
|
||||
} else if (s->abr) {
|
||||
av_log(avctx, AV_LOG_DEBUG, "rate control: ABR\n");
|
||||
av_log(avctx, AV_LOG_DEBUG, " bitrate: %d bps\n", avctx->bit_rate);
|
||||
} else {
|
||||
// default to CBR
|
||||
if (avctx->bit_rate > 0)
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_SET_BITRATE, &avctx->bit_rate);
|
||||
// otherwise just take the default quality setting
|
||||
av_log(avctx, AV_LOG_DEBUG, "rate control: CBR\n");
|
||||
av_log(avctx, AV_LOG_DEBUG, " bitrate: %d bps\n", avctx->bit_rate);
|
||||
}
|
||||
// reset the bit-rate to the actual bit rate speex will use
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_GET_BITRATE, &s->header.bitrate);
|
||||
avctx->bit_rate = s->header.bitrate;
|
||||
av_log(avctx, AV_LOG_DEBUG, "complexity: %d\n",
|
||||
avctx->compression_level);
|
||||
av_log(avctx, AV_LOG_DEBUG, "frame size: %d samples\n",
|
||||
avctx->frame_size);
|
||||
av_log(avctx, AV_LOG_DEBUG, "frames per packet: %d\n",
|
||||
s->frames_per_packet);
|
||||
av_log(avctx, AV_LOG_DEBUG, "packet size: %d\n",
|
||||
avctx->frame_size * s->frames_per_packet);
|
||||
}
|
||||
|
||||
// get the actual sample rate
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_GET_SAMPLING_RATE, &s->header.rate);
|
||||
avctx->sample_rate = s->header.rate;
|
||||
static av_cold int encode_init(AVCodecContext *avctx)
|
||||
{
|
||||
LibSpeexEncContext *s = avctx->priv_data;
|
||||
const SpeexMode *mode;
|
||||
uint8_t *header_data;
|
||||
int header_size;
|
||||
int32_t complexity;
|
||||
|
||||
// get the frame-size. To align with FLV, we're going to put 2 frames
|
||||
// per packet. If someone can tell me how to make this configurable
|
||||
// from the avcodec contents, I'll mod this so it's not hard-coded.
|
||||
// but without this, FLV files with speex data won't play correctly
|
||||
// in flash player 10.
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_GET_FRAME_SIZE, &s->header.frame_size);
|
||||
s->header.frames_per_packet = 2; // Need for FLV container support
|
||||
avctx->frame_size = s->header.frame_size*s->header.frames_per_packet;
|
||||
/* channels */
|
||||
if (avctx->channels < 1 || avctx->channels > 2) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Invalid channels (%d). Only stereo and "
|
||||
"mono are supported\n", avctx->channels);
|
||||
return AVERROR(EINVAL);
|
||||
}
|
||||
|
||||
// and we'll put a speex header packet into extradata so that muxers
|
||||
// can use it.
|
||||
avctx->extradata = speex_header_to_packet(&s->header, &avctx->extradata_size);
|
||||
/* sample rate and encoding mode */
|
||||
switch (avctx->sample_rate) {
|
||||
case 8000: mode = &speex_nb_mode; break;
|
||||
case 16000: mode = &speex_wb_mode; break;
|
||||
case 32000: mode = &speex_uwb_mode; break;
|
||||
default:
|
||||
av_log(avctx, AV_LOG_ERROR, "Sample rate of %d Hz is not supported. "
|
||||
"Resample to 8, 16, or 32 kHz.\n", avctx->sample_rate);
|
||||
return AVERROR(EINVAL);
|
||||
}
|
||||
|
||||
/* initialize libspeex */
|
||||
s->enc_state = speex_encoder_init(mode);
|
||||
if (!s->enc_state) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Error initializing libspeex\n");
|
||||
return -1;
|
||||
}
|
||||
speex_init_header(&s->header, avctx->sample_rate, avctx->channels, mode);
|
||||
|
||||
/* rate control method and parameters */
|
||||
if (avctx->flags & CODEC_FLAG_QSCALE) {
|
||||
/* VBR */
|
||||
s->header.vbr = 1;
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_SET_VBR, &s->header.vbr);
|
||||
s->vbr_quality = av_clipf(avctx->global_quality / (float)FF_QP2LAMBDA,
|
||||
0.0f, 10.0f);
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_SET_VBR_QUALITY, &s->vbr_quality);
|
||||
} else {
|
||||
s->header.bitrate = avctx->bit_rate;
|
||||
if (avctx->bit_rate > 0) {
|
||||
/* CBR or ABR by bitrate */
|
||||
if (s->abr) {
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_SET_ABR,
|
||||
&s->header.bitrate);
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_GET_ABR,
|
||||
&s->header.bitrate);
|
||||
} else {
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_SET_BITRATE,
|
||||
&s->header.bitrate);
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_GET_BITRATE,
|
||||
&s->header.bitrate);
|
||||
}
|
||||
} else {
|
||||
/* CBR by quality */
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_SET_QUALITY,
|
||||
&s->cbr_quality);
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_GET_BITRATE,
|
||||
&s->header.bitrate);
|
||||
}
|
||||
/* stereo side information adds about 800 bps to the base bitrate */
|
||||
/* TODO: this should be calculated exactly */
|
||||
avctx->bit_rate = s->header.bitrate + (avctx->channels == 2 ? 800 : 0);
|
||||
}
|
||||
|
||||
/* set encoding complexity */
|
||||
if (avctx->compression_level > FF_COMPRESSION_DEFAULT) {
|
||||
complexity = av_clip(avctx->compression_level, 0, 10);
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_SET_COMPLEXITY, &complexity);
|
||||
}
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_GET_COMPLEXITY, &complexity);
|
||||
avctx->compression_level = complexity;
|
||||
|
||||
/* set packet size */
|
||||
avctx->frame_size = s->header.frame_size;
|
||||
s->header.frames_per_packet = s->frames_per_packet;
|
||||
|
||||
/* set encoding delay */
|
||||
speex_encoder_ctl(s->enc_state, SPEEX_GET_LOOKAHEAD, &s->lookahead);
|
||||
s->sample_count = -s->lookahead;
|
||||
|
||||
/* create header packet bytes from header struct */
|
||||
/* note: libspeex allocates the memory for header_data, which is freed
|
||||
below with speex_header_free() */
|
||||
header_data = speex_header_to_packet(&s->header, &header_size);
|
||||
|
||||
/* allocate extradata and coded_frame */
|
||||
avctx->extradata = av_malloc(header_size + FF_INPUT_BUFFER_PADDING_SIZE);
|
||||
avctx->coded_frame = avcodec_alloc_frame();
|
||||
if (!avctx->extradata || !avctx->coded_frame) {
|
||||
speex_header_free(header_data);
|
||||
speex_encoder_destroy(s->enc_state);
|
||||
av_log(avctx, AV_LOG_ERROR, "memory allocation error\n");
|
||||
return AVERROR(ENOMEM);
|
||||
}
|
||||
|
||||
/* copy header packet to extradata */
|
||||
memcpy(avctx->extradata, header_data, header_size);
|
||||
avctx->extradata_size = header_size;
|
||||
speex_header_free(header_data);
|
||||
|
||||
/* init libspeex bitwriter */
|
||||
speex_bits_init(&s->bits);
|
||||
|
||||
print_enc_params(avctx, s);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static av_cold int libspeex_encode_frame(
|
||||
AVCodecContext *avctx, uint8_t *frame,
|
||||
int buf_size, void *data)
|
||||
static int encode_frame(AVCodecContext *avctx, uint8_t *frame, int buf_size,
|
||||
void *data)
|
||||
{
|
||||
LibSpeexEncContext *s = (LibSpeexEncContext*)avctx->priv_data;
|
||||
int i = 0;
|
||||
LibSpeexEncContext *s = avctx->priv_data;
|
||||
int16_t *samples = data;
|
||||
int sample_count = s->sample_count;
|
||||
|
||||
if (!data)
|
||||
// nothing to flush
|
||||
return 0;
|
||||
|
||||
speex_bits_reset(&s->bits);
|
||||
for(i = 0; i < s->header.frames_per_packet; i++)
|
||||
{
|
||||
if (avctx->sample_fmt == SAMPLE_FMT_FLT)
|
||||
{
|
||||
if (avctx->channels == 2) {
|
||||
speex_encode_stereo(
|
||||
(float*)data+i*s->header.frame_size,
|
||||
s->header.frame_size,
|
||||
&s->bits);
|
||||
}
|
||||
speex_encode(s->enc_state,
|
||||
(float*)data+i*s->header.frame_size, &s->bits);
|
||||
} else {
|
||||
if (avctx->channels == 2) {
|
||||
speex_encode_stereo_int(
|
||||
(spx_int16_t*)data+i*s->header.frame_size,
|
||||
s->header.frame_size,
|
||||
&s->bits);
|
||||
}
|
||||
speex_encode_int(s->enc_state,
|
||||
(spx_int16_t*)data+i*s->header.frame_size, &s->bits);
|
||||
if (data) {
|
||||
/* encode Speex frame */
|
||||
if (avctx->channels == 2)
|
||||
speex_encode_stereo_int(samples, s->header.frame_size, &s->bits);
|
||||
speex_encode_int(s->enc_state, samples, &s->bits);
|
||||
s->pkt_frame_count++;
|
||||
s->sample_count += avctx->frame_size;
|
||||
} else {
|
||||
/* handle end-of-stream */
|
||||
if (!s->pkt_frame_count)
|
||||
return 0;
|
||||
/* add extra terminator codes for unused frames in last packet */
|
||||
while (s->pkt_frame_count < s->frames_per_packet) {
|
||||
speex_bits_pack(&s->bits, 15, 5);
|
||||
s->pkt_frame_count++;
|
||||
}
|
||||
}
|
||||
// put in a terminator so this will fit in a OGG or FLV packet
|
||||
speex_bits_insert_terminator(&s->bits);
|
||||
|
||||
if (buf_size >= speex_bits_nbytes(&s->bits)) {
|
||||
return speex_bits_write(&s->bits, frame, buf_size);
|
||||
} else {
|
||||
av_log(avctx, AV_LOG_ERROR, "output buffer too small");
|
||||
return -1;
|
||||
/* write output if all frames for the packet have been encoded */
|
||||
if (s->pkt_frame_count == s->frames_per_packet) {
|
||||
s->pkt_frame_count = 0;
|
||||
avctx->coded_frame->pts =
|
||||
av_rescale_q(sample_count, (AVRational){ 1, avctx->sample_rate },
|
||||
avctx->time_base);
|
||||
if (buf_size > speex_bits_nbytes(&s->bits)) {
|
||||
int ret = speex_bits_write(&s->bits, frame, buf_size);
|
||||
speex_bits_reset(&s->bits);
|
||||
return ret;
|
||||
} else {
|
||||
av_log(avctx, AV_LOG_ERROR, "output buffer too small");
|
||||
return AVERROR(EINVAL);
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static av_cold int libspeex_encode_close(AVCodecContext *avctx)
|
||||
static av_cold int encode_close(AVCodecContext *avctx)
|
||||
{
|
||||
LibSpeexEncContext *s = (LibSpeexEncContext*)avctx->priv_data;
|
||||
LibSpeexEncContext *s = avctx->priv_data;
|
||||
|
||||
speex_bits_destroy(&s->bits);
|
||||
speex_encoder_destroy(s->enc_state);
|
||||
s->enc_state = 0;
|
||||
if (avctx->extradata)
|
||||
speex_header_free(avctx->extradata);
|
||||
avctx->extradata = 0;
|
||||
avctx->extradata_size = 0;
|
||||
|
||||
av_freep(&avctx->coded_frame);
|
||||
av_freep(&avctx->extradata);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
AVCodec ff_libspeex_encoder = {
|
||||
"libspeex",
|
||||
AVMEDIA_TYPE_AUDIO,
|
||||
CODEC_ID_SPEEX,
|
||||
sizeof(LibSpeexEncContext),
|
||||
libspeex_encode_init,
|
||||
libspeex_encode_frame,
|
||||
libspeex_encode_close,
|
||||
0,
|
||||
.capabilities = CODEC_CAP_DELAY,
|
||||
.supported_samplerates = (const int[]){8000, 16000, 32000, 0},
|
||||
.sample_fmts = (enum SampleFormat[]){SAMPLE_FMT_S16,SAMPLE_FMT_FLT,SAMPLE_FMT_NONE},
|
||||
.long_name = NULL_IF_CONFIG_SMALL("libspeex Speex Encoder"),
|
||||
#define OFFSET(x) offsetof(LibSpeexEncContext, x)
|
||||
#define AE AV_OPT_FLAG_AUDIO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
|
||||
static const AVOption options[] = {
|
||||
{ "abr", "Use average bit rate", OFFSET(abr), AV_OPT_TYPE_INT, { 0 }, 0, 1, AE },
|
||||
{ "cbr_quality", "Set quality value (0 to 10) for CBR", OFFSET(cbr_quality), AV_OPT_TYPE_INT, { 8 }, 0, 10, AE },
|
||||
{ "frames_per_packet", "Number of frames to encode in each packet", OFFSET(frames_per_packet), AV_OPT_TYPE_INT, { 1 }, 1, 8, AE },
|
||||
{ NULL },
|
||||
};
|
||||
|
||||
static const AVClass class = {
|
||||
.class_name = "libspeex",
|
||||
.item_name = av_default_item_name,
|
||||
.option = options,
|
||||
.version = LIBAVUTIL_VERSION_INT,
|
||||
};
|
||||
|
||||
static const AVCodecDefault defaults[] = {
|
||||
{ "b", "0" },
|
||||
{ "compression_level", "3" },
|
||||
{ NULL },
|
||||
};
|
||||
|
||||
AVCodec ff_libspeex_encoder = {
|
||||
.name = "libspeex",
|
||||
.type = AVMEDIA_TYPE_AUDIO,
|
||||
.id = CODEC_ID_SPEEX,
|
||||
.priv_data_size = sizeof(LibSpeexEncContext),
|
||||
.init = encode_init,
|
||||
.encode = encode_frame,
|
||||
.close = encode_close,
|
||||
.capabilities = CODEC_CAP_DELAY,
|
||||
.sample_fmts = (const enum SampleFormat[]){ AV_SAMPLE_FMT_S16, AV_SAMPLE_FMT_NONE },
|
||||
.long_name = NULL_IF_CONFIG_SMALL("libspeex Speex"),
|
||||
.priv_class = &class,
|
||||
.defaults = defaults,
|
||||
};
|
||||
|
@ -63,7 +63,7 @@ static av_cold int aac_encode_init(AVCodecContext *avctx)
|
||||
}
|
||||
|
||||
for (index = 0; index < 16; index++)
|
||||
if (avctx->sample_rate == ff_mpeg4audio_sample_rates[index])
|
||||
if (avctx->sample_rate == avpriv_mpeg4audio_sample_rates[index])
|
||||
break;
|
||||
if (index == 16) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Unsupported sample rate %d\n",
|
||||
|
@ -50,10 +50,10 @@ static int mp3_header_decompress(AVBitStreamFilterContext *bsfc, AVCodecContext
|
||||
lsf = sample_rate < (24000+32000)/2;
|
||||
mpeg25 = sample_rate < (12000+16000)/2;
|
||||
sample_rate_index= (header>>10)&3;
|
||||
sample_rate= ff_mpa_freq_tab[sample_rate_index] >> (lsf + mpeg25); //in case sample rate is a little off
|
||||
sample_rate= avpriv_mpa_freq_tab[sample_rate_index] >> (lsf + mpeg25); //in case sample rate is a little off
|
||||
|
||||
for(bitrate_index=2; bitrate_index<30; bitrate_index++){
|
||||
frame_size = ff_mpa_bitrate_tab[lsf][2][bitrate_index>>1];
|
||||
frame_size = avpriv_mpa_bitrate_tab[lsf][2][bitrate_index>>1];
|
||||
frame_size = (frame_size * 144000) / (sample_rate << lsf) + (bitrate_index&1);
|
||||
if(frame_size == buf_size + 4)
|
||||
break;
|
||||
|
@ -1290,8 +1290,8 @@ static int mpeg_decode_postinit(AVCodecContext *avctx)
|
||||
assert((avctx->sub_id == 1) == (avctx->codec_id == CODEC_ID_MPEG1VIDEO));
|
||||
if (avctx->codec_id == CODEC_ID_MPEG1VIDEO) {
|
||||
//MPEG-1 fps
|
||||
avctx->time_base.den = ff_frame_rate_tab[s->frame_rate_index].num;
|
||||
avctx->time_base.num = ff_frame_rate_tab[s->frame_rate_index].den;
|
||||
avctx->time_base.den = avpriv_frame_rate_tab[s->frame_rate_index].num;
|
||||
avctx->time_base.num = avpriv_frame_rate_tab[s->frame_rate_index].den;
|
||||
//MPEG-1 aspect
|
||||
avctx->sample_aspect_ratio = av_d2q(1.0/ff_mpeg1_aspect[s->aspect_ratio_info], 255);
|
||||
avctx->ticks_per_frame=1;
|
||||
@ -1299,8 +1299,8 @@ static int mpeg_decode_postinit(AVCodecContext *avctx)
|
||||
//MPEG-2 fps
|
||||
av_reduce(&s->avctx->time_base.den,
|
||||
&s->avctx->time_base.num,
|
||||
ff_frame_rate_tab[s->frame_rate_index].num * s1->frame_rate_ext.num*2,
|
||||
ff_frame_rate_tab[s->frame_rate_index].den * s1->frame_rate_ext.den,
|
||||
avpriv_frame_rate_tab[s->frame_rate_index].num * s1->frame_rate_ext.num*2,
|
||||
avpriv_frame_rate_tab[s->frame_rate_index].den * s1->frame_rate_ext.den,
|
||||
1 << 30);
|
||||
avctx->ticks_per_frame = 2;
|
||||
//MPEG-2 aspect
|
||||
@ -1732,7 +1732,7 @@ static int mpeg_decode_slice(Mpeg1Context *s1, int mb_y,
|
||||
if (avctx->hwaccel) {
|
||||
const uint8_t *buf_end, *buf_start = *buf - 4; /* include start_code */
|
||||
int start_code = -1;
|
||||
buf_end = ff_find_start_code(buf_start + 2, *buf + buf_size, &start_code);
|
||||
buf_end = avpriv_mpv_find_start_code(buf_start + 2, *buf + buf_size, &start_code);
|
||||
if (buf_end < *buf + buf_size)
|
||||
buf_end -= 4;
|
||||
s->mb_y = mb_y;
|
||||
@ -1923,7 +1923,7 @@ static int slice_decode_thread(AVCodecContext *c, void *arg)
|
||||
return 0;
|
||||
|
||||
start_code = -1;
|
||||
buf = ff_find_start_code(buf, s->gb.buffer_end, &start_code);
|
||||
buf = avpriv_mpv_find_start_code(buf, s->gb.buffer_end, &start_code);
|
||||
mb_y= (start_code - SLICE_MIN_START_CODE) << field_pic;
|
||||
if (s->picture_structure == PICT_BOTTOM_FIELD)
|
||||
mb_y++;
|
||||
@ -2217,7 +2217,7 @@ int ff_mpeg1_find_frame_end(ParseContext *pc, const uint8_t *buf, int buf_size,
|
||||
}
|
||||
state++;
|
||||
} else {
|
||||
i = ff_find_start_code(buf + i, buf + buf_size, &state) - buf - 1;
|
||||
i = avpriv_mpv_find_start_code(buf + i, buf + buf_size, &state) - buf - 1;
|
||||
if (pc->frame_start_found == 0 && state >= SLICE_MIN_START_CODE && state <= SLICE_MAX_START_CODE) {
|
||||
i++;
|
||||
pc->frame_start_found = 4;
|
||||
@ -2308,7 +2308,7 @@ static int decode_chunks(AVCodecContext *avctx,
|
||||
for (;;) {
|
||||
/* find next start code */
|
||||
uint32_t start_code = -1;
|
||||
buf_ptr = ff_find_start_code(buf_ptr, buf_end, &start_code);
|
||||
buf_ptr = avpriv_mpv_find_start_code(buf_ptr, buf_end, &start_code);
|
||||
if (start_code > 0x1ff) {
|
||||
if (s2->pict_type != AV_PICTURE_TYPE_B || avctx->skip_frame <= AVDISCARD_DEFAULT) {
|
||||
if (HAVE_THREADS && (avctx->active_thread_type & FF_THREAD_SLICE)) {
|
||||
|
@ -305,7 +305,7 @@ const uint8_t ff_mpeg12_mbMotionVectorTable[17][2] = {
|
||||
{ 0xc, 10 },
|
||||
};
|
||||
|
||||
const AVRational ff_frame_rate_tab[] = {
|
||||
const AVRational avpriv_frame_rate_tab[] = {
|
||||
{ 0, 0},
|
||||
{24000, 1001},
|
||||
{ 24, 1},
|
||||
|
@ -48,7 +48,7 @@ extern const uint8_t ff_mpeg12_mbPatTable[64][2];
|
||||
|
||||
extern const uint8_t ff_mpeg12_mbMotionVectorTable[17][2];
|
||||
|
||||
extern const AVRational ff_frame_rate_tab[];
|
||||
extern const AVRational avpriv_frame_rate_tab[];
|
||||
|
||||
extern const float ff_mpeg1_aspect[16];
|
||||
extern const AVRational ff_mpeg2_aspect[16];
|
||||
|
@ -121,7 +121,7 @@ static int find_frame_rate_index(MpegEncContext *s){
|
||||
int64_t d;
|
||||
|
||||
for(i=1;i<14;i++) {
|
||||
int64_t n0= 1001LL/ff_frame_rate_tab[i].den*ff_frame_rate_tab[i].num*s->avctx->time_base.num;
|
||||
int64_t n0= 1001LL/avpriv_frame_rate_tab[i].den*avpriv_frame_rate_tab[i].num*s->avctx->time_base.num;
|
||||
int64_t n1= 1001LL*s->avctx->time_base.den;
|
||||
if(s->avctx->strict_std_compliance > FF_COMPLIANCE_UNOFFICIAL && i>=9) break;
|
||||
|
||||
@ -200,7 +200,7 @@ static av_cold int encode_init(AVCodecContext *avctx)
|
||||
|
||||
static void put_header(MpegEncContext *s, int header)
|
||||
{
|
||||
align_put_bits(&s->pb);
|
||||
avpriv_align_put_bits(&s->pb);
|
||||
put_bits(&s->pb, 16, header>>16);
|
||||
put_sbits(&s->pb, 16, header);
|
||||
}
|
||||
@ -219,7 +219,7 @@ static void mpeg1_encode_sequence_header(MpegEncContext *s)
|
||||
if(aspect_ratio==0.0) aspect_ratio= 1.0; //pixel aspect 1:1 (VGA)
|
||||
|
||||
if (s->current_picture.f.key_frame) {
|
||||
AVRational framerate= ff_frame_rate_tab[s->frame_rate_index];
|
||||
AVRational framerate= avpriv_frame_rate_tab[s->frame_rate_index];
|
||||
|
||||
/* mpeg1 header repeated every gop */
|
||||
put_header(s, SEQ_START_CODE);
|
||||
@ -978,7 +978,7 @@ AVCodec ff_mpeg1video_encoder = {
|
||||
.init = encode_init,
|
||||
.encode = MPV_encode_picture,
|
||||
.close = MPV_encode_end,
|
||||
.supported_framerates= ff_frame_rate_tab+1,
|
||||
.supported_framerates= avpriv_frame_rate_tab+1,
|
||||
.pix_fmts= (const enum PixelFormat[]){PIX_FMT_YUV420P, PIX_FMT_NONE},
|
||||
.capabilities= CODEC_CAP_DELAY | CODEC_CAP_SLICE_THREADS,
|
||||
.long_name= NULL_IF_CONFIG_SMALL("MPEG-1 video"),
|
||||
@ -993,7 +993,7 @@ AVCodec ff_mpeg2video_encoder = {
|
||||
.init = encode_init,
|
||||
.encode = MPV_encode_picture,
|
||||
.close = MPV_encode_end,
|
||||
.supported_framerates= ff_frame_rate_tab+1,
|
||||
.supported_framerates= avpriv_frame_rate_tab+1,
|
||||
.pix_fmts= (const enum PixelFormat[]){PIX_FMT_YUV420P, PIX_FMT_YUV422P, PIX_FMT_NONE},
|
||||
.capabilities= CODEC_CAP_DELAY | CODEC_CAP_SLICE_THREADS,
|
||||
.long_name= NULL_IF_CONFIG_SMALL("MPEG-2 video"),
|
||||
|
@ -52,7 +52,7 @@ static int parse_config_ALS(GetBitContext *gb, MPEG4AudioConfig *c)
|
||||
return 0;
|
||||
}
|
||||
|
||||
const int ff_mpeg4audio_sample_rates[16] = {
|
||||
const int avpriv_mpeg4audio_sample_rates[16] = {
|
||||
96000, 88200, 64000, 48000, 44100, 32000,
|
||||
24000, 22050, 16000, 12000, 11025, 8000, 7350
|
||||
};
|
||||
@ -73,10 +73,10 @@ static inline int get_sample_rate(GetBitContext *gb, int *index)
|
||||
{
|
||||
*index = get_bits(gb, 4);
|
||||
return *index == 0x0f ? get_bits(gb, 24) :
|
||||
ff_mpeg4audio_sample_rates[*index];
|
||||
avpriv_mpeg4audio_sample_rates[*index];
|
||||
}
|
||||
|
||||
int ff_mpeg4audio_get_config(MPEG4AudioConfig *c, const uint8_t *buf, int buf_size)
|
||||
int avpriv_mpeg4audio_get_config(MPEG4AudioConfig *c, const uint8_t *buf, int buf_size)
|
||||
{
|
||||
GetBitContext gb;
|
||||
int specific_config_bitindex;
|
||||
@ -151,7 +151,7 @@ static av_always_inline unsigned int copy_bits(PutBitContext *pb,
|
||||
return el;
|
||||
}
|
||||
|
||||
int ff_copy_pce_data(PutBitContext *pb, GetBitContext *gb)
|
||||
int avpriv_copy_pce_data(PutBitContext *pb, GetBitContext *gb)
|
||||
{
|
||||
int five_bit_ch, four_bit_ch, comment_size, bits;
|
||||
int offset = put_bits_count(pb);
|
||||
@ -173,7 +173,7 @@ int ff_copy_pce_data(PutBitContext *pb, GetBitContext *gb)
|
||||
copy_bits(pb, gb, 16);
|
||||
if (bits)
|
||||
copy_bits(pb, gb, bits);
|
||||
align_put_bits(pb);
|
||||
avpriv_align_put_bits(pb);
|
||||
align_get_bits(gb);
|
||||
comment_size = copy_bits(pb, gb, 8);
|
||||
for (; comment_size > 0; comment_size--)
|
||||
|
@ -40,7 +40,7 @@ typedef struct {
|
||||
int ps; ///< -1 implicit, 1 presence
|
||||
} MPEG4AudioConfig;
|
||||
|
||||
extern const int ff_mpeg4audio_sample_rates[16];
|
||||
extern const int avpriv_mpeg4audio_sample_rates[16];
|
||||
extern const uint8_t ff_mpeg4audio_channels[8];
|
||||
/**
|
||||
* Parse MPEG-4 systems extradata to retrieve audio configuration.
|
||||
@ -49,7 +49,7 @@ extern const uint8_t ff_mpeg4audio_channels[8];
|
||||
* @param[in] buf_size Extradata size.
|
||||
* @return On error -1 is returned, on success AudioSpecificConfig bit index in extradata.
|
||||
*/
|
||||
int ff_mpeg4audio_get_config(MPEG4AudioConfig *c, const uint8_t *buf, int buf_size);
|
||||
int avpriv_mpeg4audio_get_config(MPEG4AudioConfig *c, const uint8_t *buf, int buf_size);
|
||||
|
||||
enum AudioObjectType {
|
||||
AOT_NULL,
|
||||
@ -101,6 +101,6 @@ enum AudioObjectType {
|
||||
#define MAX_PCE_SIZE 304 ///<Maximum size of a PCE including the 3-bit ID_PCE
|
||||
///<marker and the comment
|
||||
|
||||
int ff_copy_pce_data(PutBitContext *pb, GetBitContext *gb);
|
||||
int avpriv_copy_pce_data(PutBitContext *pb, GetBitContext *gb);
|
||||
|
||||
#endif /* AVCODEC_MPEG4AUDIO_H */
|
||||
|
@ -1268,8 +1268,8 @@ void ff_mpeg4_merge_partitions(MpegEncContext *s)
|
||||
flush_put_bits(&s->tex_pb);
|
||||
|
||||
set_put_bits_buffer_size(&s->pb, s->pb2.buf_end - s->pb.buf);
|
||||
ff_copy_bits(&s->pb, s->pb2.buf , pb2_len);
|
||||
ff_copy_bits(&s->pb, s->tex_pb.buf, tex_pb_len);
|
||||
avpriv_copy_bits(&s->pb, s->pb2.buf , pb2_len);
|
||||
avpriv_copy_bits(&s->pb, s->tex_pb.buf, tex_pb_len);
|
||||
s->last_bits= put_bits_count(&s->pb);
|
||||
}
|
||||
|
||||
|
@ -64,7 +64,7 @@ static int mpegaudio_parse(AVCodecParserContext *s1,
|
||||
|
||||
state= (state<<8) + buf[i++];
|
||||
|
||||
ret = ff_mpa_decode_header(avctx, state, &sr, &channels, &frame_size, &bit_rate);
|
||||
ret = avpriv_mpa_decode_header(avctx, state, &sr, &channels, &frame_size, &bit_rate);
|
||||
if (ret < 4) {
|
||||
if(i > 4)
|
||||
s->header_count= -2;
|
||||
|
@ -27,7 +27,7 @@
|
||||
#include "mpegaudiodata.h"
|
||||
|
||||
|
||||
const uint16_t ff_mpa_bitrate_tab[2][3][15] = {
|
||||
const uint16_t avpriv_mpa_bitrate_tab[2][3][15] = {
|
||||
{ {0, 32, 64, 96, 128, 160, 192, 224, 256, 288, 320, 352, 384, 416, 448 },
|
||||
{0, 32, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384 },
|
||||
{0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320 } },
|
||||
@ -37,7 +37,7 @@ const uint16_t ff_mpa_bitrate_tab[2][3][15] = {
|
||||
}
|
||||
};
|
||||
|
||||
const uint16_t ff_mpa_freq_tab[3] = { 44100, 48000, 32000 };
|
||||
const uint16_t avpriv_mpa_freq_tab[3] = { 44100, 48000, 32000 };
|
||||
|
||||
/*******************************************************/
|
||||
/* half mpeg encoding window (full precision) */
|
||||
|
@ -32,8 +32,8 @@
|
||||
#define MODE_EXT_MS_STEREO 2
|
||||
#define MODE_EXT_I_STEREO 1
|
||||
|
||||
extern const uint16_t ff_mpa_bitrate_tab[2][3][15];
|
||||
extern const uint16_t ff_mpa_freq_tab[3];
|
||||
extern const uint16_t avpriv_mpa_bitrate_tab[2][3][15];
|
||||
extern const uint16_t avpriv_mpa_freq_tab[3];
|
||||
extern const int32_t ff_mpa_enwindow[257];
|
||||
extern const int ff_mpa_sblimit_table[5];
|
||||
extern const int ff_mpa_quant_steps[17];
|
||||
|
@ -1789,7 +1789,7 @@ static int decode_frame(AVCodecContext * avctx,
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (ff_mpegaudio_decode_header((MPADecodeHeader *)s, header) == 1) {
|
||||
if (avpriv_mpegaudio_decode_header((MPADecodeHeader *)s, header) == 1) {
|
||||
/* free format: prepare to compute frame size */
|
||||
s->frame_size = -1;
|
||||
return -1;
|
||||
@ -1862,7 +1862,7 @@ static int decode_frame_adu(AVCodecContext * avctx,
|
||||
return buf_size;
|
||||
}
|
||||
|
||||
ff_mpegaudio_decode_header((MPADecodeHeader *)s, header);
|
||||
avpriv_mpegaudio_decode_header((MPADecodeHeader *)s, header);
|
||||
/* update codec info */
|
||||
avctx->sample_rate = s->sample_rate;
|
||||
avctx->channels = s->nb_channels;
|
||||
@ -1923,7 +1923,7 @@ static int decode_init_mp3on4(AVCodecContext * avctx)
|
||||
return -1;
|
||||
}
|
||||
|
||||
ff_mpeg4audio_get_config(&cfg, avctx->extradata, avctx->extradata_size);
|
||||
avpriv_mpeg4audio_get_config(&cfg, avctx->extradata, avctx->extradata_size);
|
||||
if (!cfg.chan_config || cfg.chan_config > 7) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Invalid channel config number.\n");
|
||||
return -1;
|
||||
@ -2015,7 +2015,7 @@ static int decode_frame_mp3on4(AVCodecContext * avctx,
|
||||
if (ff_mpa_check_header(header) < 0) // Bad header, discard block
|
||||
break;
|
||||
|
||||
ff_mpegaudio_decode_header((MPADecodeHeader *)m, header);
|
||||
avpriv_mpegaudio_decode_header((MPADecodeHeader *)m, header);
|
||||
out_size += mp_decode_frame(m, outptr, buf, fsize);
|
||||
buf += fsize;
|
||||
len -= fsize;
|
||||
|
@ -31,7 +31,7 @@
|
||||
#include "mpegaudiodecheader.h"
|
||||
|
||||
|
||||
int ff_mpegaudio_decode_header(MPADecodeHeader *s, uint32_t header)
|
||||
int avpriv_mpegaudio_decode_header(MPADecodeHeader *s, uint32_t header)
|
||||
{
|
||||
int sample_rate, frame_size, mpeg25, padding;
|
||||
int sample_rate_index, bitrate_index;
|
||||
@ -46,7 +46,7 @@ int ff_mpegaudio_decode_header(MPADecodeHeader *s, uint32_t header)
|
||||
s->layer = 4 - ((header >> 17) & 3);
|
||||
/* extract frequency */
|
||||
sample_rate_index = (header >> 10) & 3;
|
||||
sample_rate = ff_mpa_freq_tab[sample_rate_index] >> (s->lsf + mpeg25);
|
||||
sample_rate = avpriv_mpa_freq_tab[sample_rate_index] >> (s->lsf + mpeg25);
|
||||
sample_rate_index += 3 * (s->lsf + mpeg25);
|
||||
s->sample_rate_index = sample_rate_index;
|
||||
s->error_protection = ((header >> 16) & 1) ^ 1;
|
||||
@ -67,7 +67,7 @@ int ff_mpegaudio_decode_header(MPADecodeHeader *s, uint32_t header)
|
||||
s->nb_channels = 2;
|
||||
|
||||
if (bitrate_index != 0) {
|
||||
frame_size = ff_mpa_bitrate_tab[s->lsf][s->layer - 1][bitrate_index];
|
||||
frame_size = avpriv_mpa_bitrate_tab[s->lsf][s->layer - 1][bitrate_index];
|
||||
s->bit_rate = frame_size * 1000;
|
||||
switch(s->layer) {
|
||||
case 1:
|
||||
@ -109,14 +109,14 @@ int ff_mpegaudio_decode_header(MPADecodeHeader *s, uint32_t header)
|
||||
return 0;
|
||||
}
|
||||
|
||||
int ff_mpa_decode_header(AVCodecContext *avctx, uint32_t head, int *sample_rate, int *channels, int *frame_size, int *bit_rate)
|
||||
int avpriv_mpa_decode_header(AVCodecContext *avctx, uint32_t head, int *sample_rate, int *channels, int *frame_size, int *bit_rate)
|
||||
{
|
||||
MPADecodeHeader s1, *s = &s1;
|
||||
|
||||
if (ff_mpa_check_header(head) != 0)
|
||||
return -1;
|
||||
|
||||
if (ff_mpegaudio_decode_header(s, head) != 0) {
|
||||
if (avpriv_mpegaudio_decode_header(s, head) != 0) {
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
@ -50,11 +50,11 @@ typedef struct MPADecodeHeader {
|
||||
/* header decoding. MUST check the header before because no
|
||||
consistency check is done there. Return 1 if free format found and
|
||||
that the frame size must be computed externally */
|
||||
int ff_mpegaudio_decode_header(MPADecodeHeader *s, uint32_t header);
|
||||
int avpriv_mpegaudio_decode_header(MPADecodeHeader *s, uint32_t header);
|
||||
|
||||
/* useful helper to get mpeg audio stream infos. Return -1 if error in
|
||||
header, otherwise the coded frame size in bytes */
|
||||
int ff_mpa_decode_header(AVCodecContext *avctx, uint32_t head, int *sample_rate, int *channels, int *frame_size, int *bitrate);
|
||||
int avpriv_mpa_decode_header(AVCodecContext *avctx, uint32_t head, int *sample_rate, int *channels, int *frame_size, int *bitrate);
|
||||
|
||||
/* fast header check for resync */
|
||||
static inline int ff_mpa_check_header(uint32_t header){
|
||||
|
@ -84,9 +84,9 @@ static av_cold int MPA_encode_init(AVCodecContext *avctx)
|
||||
/* encoding freq */
|
||||
s->lsf = 0;
|
||||
for(i=0;i<3;i++) {
|
||||
if (ff_mpa_freq_tab[i] == freq)
|
||||
if (avpriv_mpa_freq_tab[i] == freq)
|
||||
break;
|
||||
if ((ff_mpa_freq_tab[i] / 2) == freq) {
|
||||
if ((avpriv_mpa_freq_tab[i] / 2) == freq) {
|
||||
s->lsf = 1;
|
||||
break;
|
||||
}
|
||||
@ -99,7 +99,7 @@ static av_cold int MPA_encode_init(AVCodecContext *avctx)
|
||||
|
||||
/* encoding bitrate & frequency */
|
||||
for(i=0;i<15;i++) {
|
||||
if (ff_mpa_bitrate_tab[s->lsf][1][i] == bitrate)
|
||||
if (avpriv_mpa_bitrate_tab[s->lsf][1][i] == bitrate)
|
||||
break;
|
||||
}
|
||||
if (i == 15){
|
||||
|
@ -122,7 +122,7 @@ const enum PixelFormat ff_hwaccel_pixfmt_list_420[] = {
|
||||
PIX_FMT_NONE
|
||||
};
|
||||
|
||||
const uint8_t *ff_find_start_code(const uint8_t * restrict p, const uint8_t *end, uint32_t * restrict state){
|
||||
const uint8_t *avpriv_mpv_find_start_code(const uint8_t * restrict p, const uint8_t *end, uint32_t * restrict state){
|
||||
int i;
|
||||
|
||||
assert(p<=end);
|
||||
@ -645,9 +645,8 @@ av_cold int MPV_common_init(MpegEncContext *s)
|
||||
yc_size = y_size + 2 * c_size;
|
||||
|
||||
/* convert fourcc to upper case */
|
||||
s->codec_tag = ff_toupper4(s->avctx->codec_tag);
|
||||
|
||||
s->stream_codec_tag = ff_toupper4(s->avctx->stream_codec_tag);
|
||||
s->codec_tag = avpriv_toupper4(s->avctx->codec_tag);
|
||||
s->stream_codec_tag = avpriv_toupper4(s->avctx->stream_codec_tag);
|
||||
|
||||
s->avctx->coded_frame= (AVFrame*)&s->current_picture;
|
||||
|
||||
|
@ -725,7 +725,7 @@ void ff_update_duplicate_context(MpegEncContext *dst, MpegEncContext *src);
|
||||
int MPV_lowest_referenced_row(MpegEncContext *s, int dir);
|
||||
void MPV_report_decode_progress(MpegEncContext *s);
|
||||
int ff_mpeg_update_thread_context(AVCodecContext *dst, const AVCodecContext *src);
|
||||
const uint8_t *ff_find_start_code(const uint8_t *p, const uint8_t *end, uint32_t *state);
|
||||
const uint8_t *avpriv_mpv_find_start_code(const uint8_t *p, const uint8_t *end, uint32_t *state);
|
||||
void ff_set_qscale(MpegEncContext * s, int qscale);
|
||||
|
||||
void ff_er_frame_start(MpegEncContext *s);
|
||||
|
@ -2051,7 +2051,7 @@ static void write_slice_end(MpegEncContext *s){
|
||||
ff_mjpeg_encode_stuffing(&s->pb);
|
||||
}
|
||||
|
||||
align_put_bits(&s->pb);
|
||||
avpriv_align_put_bits(&s->pb);
|
||||
flush_put_bits(&s->pb);
|
||||
|
||||
if((s->flags&CODEC_FLAG_PASS1) && !s->partitioned_frame)
|
||||
@ -2492,18 +2492,18 @@ static int encode_thread(AVCodecContext *c, void *arg){
|
||||
|
||||
pb_bits_count= put_bits_count(&s->pb);
|
||||
flush_put_bits(&s->pb);
|
||||
ff_copy_bits(&backup_s.pb, bit_buf[next_block^1], pb_bits_count);
|
||||
avpriv_copy_bits(&backup_s.pb, bit_buf[next_block^1], pb_bits_count);
|
||||
s->pb= backup_s.pb;
|
||||
|
||||
if(s->data_partitioning){
|
||||
pb2_bits_count= put_bits_count(&s->pb2);
|
||||
flush_put_bits(&s->pb2);
|
||||
ff_copy_bits(&backup_s.pb2, bit_buf2[next_block^1], pb2_bits_count);
|
||||
avpriv_copy_bits(&backup_s.pb2, bit_buf2[next_block^1], pb2_bits_count);
|
||||
s->pb2= backup_s.pb2;
|
||||
|
||||
tex_pb_bits_count= put_bits_count(&s->tex_pb);
|
||||
flush_put_bits(&s->tex_pb);
|
||||
ff_copy_bits(&backup_s.tex_pb, bit_buf_tex[next_block^1], tex_pb_bits_count);
|
||||
avpriv_copy_bits(&backup_s.tex_pb, bit_buf_tex[next_block^1], tex_pb_bits_count);
|
||||
s->tex_pb= backup_s.tex_pb;
|
||||
}
|
||||
s->last_bits= put_bits_count(&s->pb);
|
||||
@ -2726,7 +2726,7 @@ static void merge_context_after_encode(MpegEncContext *dst, MpegEncContext *src)
|
||||
|
||||
assert(put_bits_count(&src->pb) % 8 ==0);
|
||||
assert(put_bits_count(&dst->pb) % 8 ==0);
|
||||
ff_copy_bits(&dst->pb, src->pb.buf, put_bits_count(&src->pb));
|
||||
avpriv_copy_bits(&dst->pb, src->pb.buf, put_bits_count(&src->pb));
|
||||
flush_put_bits(&dst->pb);
|
||||
}
|
||||
|
||||
|
@ -40,7 +40,7 @@ static void mpegvideo_extract_headers(AVCodecParserContext *s,
|
||||
|
||||
while (buf < buf_end) {
|
||||
start_code= -1;
|
||||
buf= ff_find_start_code(buf, buf_end, &start_code);
|
||||
buf= avpriv_mpv_find_start_code(buf, buf_end, &start_code);
|
||||
bytes_left = buf_end - buf;
|
||||
switch(start_code) {
|
||||
case PICTURE_START_CODE:
|
||||
@ -57,8 +57,8 @@ static void mpegvideo_extract_headers(AVCodecParserContext *s,
|
||||
did_set_size=1;
|
||||
}
|
||||
frame_rate_index = buf[3] & 0xf;
|
||||
pc->frame_rate.den = avctx->time_base.den = ff_frame_rate_tab[frame_rate_index].num;
|
||||
pc->frame_rate.num = avctx->time_base.num = ff_frame_rate_tab[frame_rate_index].den;
|
||||
pc->frame_rate.den = avctx->time_base.den = avpriv_frame_rate_tab[frame_rate_index].num;
|
||||
pc->frame_rate.num = avctx->time_base.num = avpriv_frame_rate_tab[frame_rate_index].den;
|
||||
avctx->bit_rate = ((buf[4]<<10) | (buf[5]<<2) | (buf[6]>>6))*400;
|
||||
avctx->codec_id = CODEC_ID_MPEG1VIDEO;
|
||||
avctx->sub_id = 1;
|
||||
|
@ -351,7 +351,7 @@ void msmpeg4_encode_picture_header(MpegEncContext * s, int picture_number)
|
||||
{
|
||||
find_best_tables(s);
|
||||
|
||||
align_put_bits(&s->pb);
|
||||
avpriv_align_put_bits(&s->pb);
|
||||
put_bits(&s->pb, 2, s->pict_type - 1);
|
||||
|
||||
put_bits(&s->pb, 5, s->qscale);
|
||||
|
@ -97,14 +97,14 @@ static inline void flush_put_bits(PutBitContext *s)
|
||||
}
|
||||
|
||||
#ifdef BITSTREAM_WRITER_LE
|
||||
#define align_put_bits align_put_bits_unsupported_here
|
||||
#define avpriv_align_put_bits align_put_bits_unsupported_here
|
||||
#define ff_put_string ff_put_string_unsupported_here
|
||||
#define ff_copy_bits ff_copy_bits_unsupported_here
|
||||
#define avpriv_copy_bits avpriv_copy_bits_unsupported_here
|
||||
#else
|
||||
/**
|
||||
* Pad the bitstream with zeros up to the next byte boundary.
|
||||
*/
|
||||
void align_put_bits(PutBitContext *s);
|
||||
void avpriv_align_put_bits(PutBitContext *s);
|
||||
|
||||
/**
|
||||
* Put the string string in the bitstream.
|
||||
@ -118,7 +118,7 @@ void ff_put_string(PutBitContext *pb, const char *string, int terminate_string);
|
||||
*
|
||||
* @param length the number of bits of src to copy
|
||||
*/
|
||||
void ff_copy_bits(PutBitContext *pb, const uint8_t *src, int length);
|
||||
void avpriv_copy_bits(PutBitContext *pb, const uint8_t *src, int length);
|
||||
#endif
|
||||
|
||||
/**
|
||||
|
@ -32,7 +32,7 @@ void rv10_encode_picture_header(MpegEncContext *s, int picture_number)
|
||||
{
|
||||
int full_frame= 0;
|
||||
|
||||
align_put_bits(&s->pb);
|
||||
avpriv_align_put_bits(&s->pb);
|
||||
|
||||
put_bits(&s->pb, 1, 1); /* marker */
|
||||
|
||||
|
@ -28,6 +28,7 @@
|
||||
|
||||
#include <limits.h>
|
||||
#include "avcodec.h"
|
||||
#include "bytestream.h"
|
||||
#include "get_bits.h"
|
||||
#include "golomb.h"
|
||||
|
||||
@ -69,6 +70,9 @@
|
||||
#define FN_ZERO 8
|
||||
#define FN_VERBATIM 9
|
||||
|
||||
/** indicates if the FN_* command is audio or non-audio */
|
||||
static const uint8_t is_audio_command[10] = { 1, 1, 1, 1, 0, 0, 0, 1, 1, 0 };
|
||||
|
||||
#define VERBATIM_CKSIZE_SIZE 5
|
||||
#define VERBATIM_BYTE_SIZE 8
|
||||
#define CANONICAL_HEADER_SIZE 44
|
||||
@ -98,6 +102,8 @@ typedef struct ShortenContext {
|
||||
int blocksize;
|
||||
int bitindex;
|
||||
int32_t lpcqoffset;
|
||||
int got_header;
|
||||
int got_quit_command;
|
||||
} ShortenContext;
|
||||
|
||||
static av_cold int shorten_decode_init(AVCodecContext * avctx)
|
||||
@ -113,6 +119,7 @@ static int allocate_buffers(ShortenContext *s)
|
||||
{
|
||||
int i, chan;
|
||||
int *coeffs;
|
||||
void *tmp_ptr;
|
||||
|
||||
for (chan=0; chan<s->channels; chan++) {
|
||||
if(FFMAX(1, s->nmean) >= UINT_MAX/sizeof(int32_t)){
|
||||
@ -124,9 +131,15 @@ static int allocate_buffers(ShortenContext *s)
|
||||
return -1;
|
||||
}
|
||||
|
||||
s->offset[chan] = av_realloc(s->offset[chan], sizeof(int32_t)*FFMAX(1, s->nmean));
|
||||
tmp_ptr = av_realloc(s->offset[chan], sizeof(int32_t)*FFMAX(1, s->nmean));
|
||||
if (!tmp_ptr)
|
||||
return AVERROR(ENOMEM);
|
||||
s->offset[chan] = tmp_ptr;
|
||||
|
||||
s->decoded[chan] = av_realloc(s->decoded[chan], sizeof(int32_t)*(s->blocksize + s->nwrap));
|
||||
tmp_ptr = av_realloc(s->decoded[chan], sizeof(int32_t)*(s->blocksize + s->nwrap));
|
||||
if (!tmp_ptr)
|
||||
return AVERROR(ENOMEM);
|
||||
s->decoded[chan] = tmp_ptr;
|
||||
for (i=0; i<s->nwrap; i++)
|
||||
s->decoded[chan][i] = 0;
|
||||
s->decoded[chan] += s->nwrap;
|
||||
@ -181,47 +194,37 @@ static void init_offset(ShortenContext *s)
|
||||
s->offset[chan][i] = mean;
|
||||
}
|
||||
|
||||
static inline int get_le32(GetBitContext *gb)
|
||||
static int decode_wave_header(AVCodecContext *avctx, const uint8_t *header,
|
||||
int header_size)
|
||||
{
|
||||
return av_bswap32(get_bits_long(gb, 32));
|
||||
}
|
||||
|
||||
static inline short get_le16(GetBitContext *gb)
|
||||
{
|
||||
return av_bswap16(get_bits_long(gb, 16));
|
||||
}
|
||||
|
||||
static int decode_wave_header(AVCodecContext *avctx, uint8_t *header, int header_size)
|
||||
{
|
||||
GetBitContext hb;
|
||||
int len;
|
||||
short wave_format;
|
||||
|
||||
init_get_bits(&hb, header, header_size*8);
|
||||
if (get_le32(&hb) != MKTAG('R','I','F','F')) {
|
||||
|
||||
if (bytestream_get_le32(&header) != MKTAG('R','I','F','F')) {
|
||||
av_log(avctx, AV_LOG_ERROR, "missing RIFF tag\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
skip_bits_long(&hb, 32); /* chunk_size */
|
||||
header += 4; /* chunk size */;
|
||||
|
||||
if (get_le32(&hb) != MKTAG('W','A','V','E')) {
|
||||
if (bytestream_get_le32(&header) != MKTAG('W','A','V','E')) {
|
||||
av_log(avctx, AV_LOG_ERROR, "missing WAVE tag\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
while (get_le32(&hb) != MKTAG('f','m','t',' ')) {
|
||||
len = get_le32(&hb);
|
||||
skip_bits(&hb, 8*len);
|
||||
while (bytestream_get_le32(&header) != MKTAG('f','m','t',' ')) {
|
||||
len = bytestream_get_le32(&header);
|
||||
header += len;
|
||||
}
|
||||
len = get_le32(&hb);
|
||||
len = bytestream_get_le32(&header);
|
||||
|
||||
if (len < 16) {
|
||||
av_log(avctx, AV_LOG_ERROR, "fmt chunk was too short\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
wave_format = get_le16(&hb);
|
||||
wave_format = bytestream_get_le16(&header);
|
||||
|
||||
switch (wave_format) {
|
||||
case WAVE_FORMAT_PCM:
|
||||
@ -231,11 +234,11 @@ static int decode_wave_header(AVCodecContext *avctx, uint8_t *header, int header
|
||||
return -1;
|
||||
}
|
||||
|
||||
avctx->channels = get_le16(&hb);
|
||||
avctx->sample_rate = get_le32(&hb);
|
||||
avctx->bit_rate = get_le32(&hb) * 8;
|
||||
avctx->block_align = get_le16(&hb);
|
||||
avctx->bits_per_coded_sample = get_le16(&hb);
|
||||
header += 2; // skip channels (already got from shorten header)
|
||||
avctx->sample_rate = bytestream_get_le32(&header);
|
||||
header += 4; // skip bit rate (represents original uncompressed bit rate)
|
||||
header += 2; // skip block align (not needed)
|
||||
avctx->bits_per_coded_sample = bytestream_get_le16(&header);
|
||||
|
||||
if (avctx->bits_per_coded_sample != 16) {
|
||||
av_log(avctx, AV_LOG_ERROR, "unsupported number of bits per sample\n");
|
||||
@ -253,26 +256,142 @@ static int16_t * interleave_buffer(int16_t *samples, int nchan, int blocksize, i
|
||||
int i, chan;
|
||||
for (i=0; i<blocksize; i++)
|
||||
for (chan=0; chan < nchan; chan++)
|
||||
*samples++ = FFMIN(buffer[chan][i], 32768);
|
||||
*samples++ = av_clip_int16(buffer[chan][i]);
|
||||
return samples;
|
||||
}
|
||||
|
||||
static void decode_subframe_lpc(ShortenContext *s, int channel, int residual_size, int pred_order)
|
||||
static const int fixed_coeffs[3][3] = {
|
||||
{ 1, 0, 0 },
|
||||
{ 2, -1, 0 },
|
||||
{ 3, -3, 1 }
|
||||
};
|
||||
|
||||
static int decode_subframe_lpc(ShortenContext *s, int command, int channel,
|
||||
int residual_size, int32_t coffset)
|
||||
{
|
||||
int sum, i, j;
|
||||
int *coeffs = s->coeffs;
|
||||
int pred_order, sum, qshift, init_sum, i, j;
|
||||
const int *coeffs;
|
||||
|
||||
for (i=0; i<pred_order; i++)
|
||||
coeffs[i] = get_sr_golomb_shorten(&s->gb, LPCQUANT);
|
||||
if (command == FN_QLPC) {
|
||||
/* read/validate prediction order */
|
||||
pred_order = get_ur_golomb_shorten(&s->gb, LPCQSIZE);
|
||||
if (pred_order > s->nwrap) {
|
||||
av_log(s->avctx, AV_LOG_ERROR, "invalid pred_order %d\n", pred_order);
|
||||
return AVERROR(EINVAL);
|
||||
}
|
||||
/* read LPC coefficients */
|
||||
for (i=0; i<pred_order; i++)
|
||||
s->coeffs[i] = get_sr_golomb_shorten(&s->gb, LPCQUANT);
|
||||
coeffs = s->coeffs;
|
||||
|
||||
qshift = LPCQUANT;
|
||||
} else {
|
||||
/* fixed LPC coeffs */
|
||||
pred_order = command;
|
||||
coeffs = fixed_coeffs[pred_order-1];
|
||||
qshift = 0;
|
||||
}
|
||||
|
||||
/* subtract offset from previous samples to use in prediction */
|
||||
if (command == FN_QLPC && coffset)
|
||||
for (i = -pred_order; i < 0; i++)
|
||||
s->decoded[channel][i] -= coffset;
|
||||
|
||||
/* decode residual and do LPC prediction */
|
||||
init_sum = pred_order ? (command == FN_QLPC ? s->lpcqoffset : 0) : coffset;
|
||||
for (i=0; i < s->blocksize; i++) {
|
||||
sum = s->lpcqoffset;
|
||||
sum = init_sum;
|
||||
for (j=0; j<pred_order; j++)
|
||||
sum += coeffs[j] * s->decoded[channel][i-j-1];
|
||||
s->decoded[channel][i] = get_sr_golomb_shorten(&s->gb, residual_size) + (sum >> LPCQUANT);
|
||||
s->decoded[channel][i] = get_sr_golomb_shorten(&s->gb, residual_size) + (sum >> qshift);
|
||||
}
|
||||
|
||||
/* add offset to current samples */
|
||||
if (command == FN_QLPC && coffset)
|
||||
for (i = 0; i < s->blocksize; i++)
|
||||
s->decoded[channel][i] += coffset;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int read_header(ShortenContext *s)
|
||||
{
|
||||
int i, ret;
|
||||
int maxnlpc = 0;
|
||||
/* shorten signature */
|
||||
if (get_bits_long(&s->gb, 32) != AV_RB32("ajkg")) {
|
||||
av_log(s->avctx, AV_LOG_ERROR, "missing shorten magic 'ajkg'\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
s->lpcqoffset = 0;
|
||||
s->blocksize = DEFAULT_BLOCK_SIZE;
|
||||
s->channels = 1;
|
||||
s->nmean = -1;
|
||||
s->version = get_bits(&s->gb, 8);
|
||||
s->internal_ftype = get_uint(s, TYPESIZE);
|
||||
|
||||
s->channels = get_uint(s, CHANSIZE);
|
||||
if (s->channels > MAX_CHANNELS) {
|
||||
av_log(s->avctx, AV_LOG_ERROR, "too many channels: %d\n", s->channels);
|
||||
return -1;
|
||||
}
|
||||
s->avctx->channels = s->channels;
|
||||
|
||||
/* get blocksize if version > 0 */
|
||||
if (s->version > 0) {
|
||||
int skip_bytes, blocksize;
|
||||
|
||||
blocksize = get_uint(s, av_log2(DEFAULT_BLOCK_SIZE));
|
||||
if (!blocksize || blocksize > MAX_BLOCKSIZE) {
|
||||
av_log(s->avctx, AV_LOG_ERROR, "invalid or unsupported block size: %d\n",
|
||||
blocksize);
|
||||
return AVERROR(EINVAL);
|
||||
}
|
||||
s->blocksize = blocksize;
|
||||
|
||||
maxnlpc = get_uint(s, LPCQSIZE);
|
||||
s->nmean = get_uint(s, 0);
|
||||
|
||||
skip_bytes = get_uint(s, NSKIPSIZE);
|
||||
for (i=0; i<skip_bytes; i++) {
|
||||
skip_bits(&s->gb, 8);
|
||||
}
|
||||
}
|
||||
s->nwrap = FFMAX(NWRAP, maxnlpc);
|
||||
|
||||
if ((ret = allocate_buffers(s)) < 0)
|
||||
return ret;
|
||||
|
||||
init_offset(s);
|
||||
|
||||
if (s->version > 1)
|
||||
s->lpcqoffset = V2LPCQOFFSET;
|
||||
|
||||
if (get_ur_golomb_shorten(&s->gb, FNSIZE) != FN_VERBATIM) {
|
||||
av_log(s->avctx, AV_LOG_ERROR, "missing verbatim section at beginning of stream\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
s->header_size = get_ur_golomb_shorten(&s->gb, VERBATIM_CKSIZE_SIZE);
|
||||
if (s->header_size >= OUT_BUFFER_SIZE || s->header_size < CANONICAL_HEADER_SIZE) {
|
||||
av_log(s->avctx, AV_LOG_ERROR, "header is wrong size: %d\n", s->header_size);
|
||||
return -1;
|
||||
}
|
||||
|
||||
for (i=0; i<s->header_size; i++)
|
||||
s->header[i] = (char)get_ur_golomb_shorten(&s->gb, VERBATIM_BYTE_SIZE);
|
||||
|
||||
if (decode_wave_header(s->avctx, s->header, s->header_size) < 0)
|
||||
return -1;
|
||||
|
||||
s->cur_chan = 0;
|
||||
s->bitshift = 0;
|
||||
|
||||
s->got_header = 1;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int shorten_decode_frame(AVCodecContext *avctx,
|
||||
void *data, int *data_size,
|
||||
@ -283,226 +402,189 @@ static int shorten_decode_frame(AVCodecContext *avctx,
|
||||
ShortenContext *s = avctx->priv_data;
|
||||
int i, input_buf_size = 0;
|
||||
int16_t *samples = data;
|
||||
int ret;
|
||||
|
||||
/* allocate internal bitstream buffer */
|
||||
if(s->max_framesize == 0){
|
||||
void *tmp_ptr;
|
||||
s->max_framesize= 1024; // should hopefully be enough for the first header
|
||||
s->bitstream= av_fast_realloc(s->bitstream, &s->allocated_bitstream_size, s->max_framesize);
|
||||
tmp_ptr = av_fast_realloc(s->bitstream, &s->allocated_bitstream_size,
|
||||
s->max_framesize);
|
||||
if (!tmp_ptr) {
|
||||
av_log(avctx, AV_LOG_ERROR, "error allocating bitstream buffer\n");
|
||||
return AVERROR(ENOMEM);
|
||||
}
|
||||
s->bitstream = tmp_ptr;
|
||||
}
|
||||
|
||||
/* append current packet data to bitstream buffer */
|
||||
if(1 && s->max_framesize){//FIXME truncated
|
||||
buf_size= FFMIN(buf_size, s->max_framesize - s->bitstream_size);
|
||||
input_buf_size= buf_size;
|
||||
|
||||
if(s->bitstream_index + s->bitstream_size + buf_size > s->allocated_bitstream_size){
|
||||
// printf("memmove\n");
|
||||
memmove(s->bitstream, &s->bitstream[s->bitstream_index], s->bitstream_size);
|
||||
s->bitstream_index=0;
|
||||
}
|
||||
memcpy(&s->bitstream[s->bitstream_index + s->bitstream_size], buf, buf_size);
|
||||
if (buf)
|
||||
memcpy(&s->bitstream[s->bitstream_index + s->bitstream_size], buf, buf_size);
|
||||
buf= &s->bitstream[s->bitstream_index];
|
||||
buf_size += s->bitstream_size;
|
||||
s->bitstream_size= buf_size;
|
||||
|
||||
if(buf_size < s->max_framesize){
|
||||
/* do not decode until buffer has at least max_framesize bytes or
|
||||
the end of the file has been reached */
|
||||
if (buf_size < s->max_framesize && avpkt->data) {
|
||||
*data_size = 0;
|
||||
return input_buf_size;
|
||||
}
|
||||
}
|
||||
/* init and position bitstream reader */
|
||||
init_get_bits(&s->gb, buf, buf_size*8);
|
||||
skip_bits(&s->gb, s->bitindex);
|
||||
if (!s->blocksize)
|
||||
{
|
||||
int maxnlpc = 0;
|
||||
/* shorten signature */
|
||||
if (get_bits_long(&s->gb, 32) != AV_RB32("ajkg")) {
|
||||
av_log(s->avctx, AV_LOG_ERROR, "missing shorten magic 'ajkg'\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
s->lpcqoffset = 0;
|
||||
s->blocksize = DEFAULT_BLOCK_SIZE;
|
||||
s->channels = 1;
|
||||
s->nmean = -1;
|
||||
s->version = get_bits(&s->gb, 8);
|
||||
s->internal_ftype = get_uint(s, TYPESIZE);
|
||||
|
||||
s->channels = get_uint(s, CHANSIZE);
|
||||
if (s->channels > MAX_CHANNELS) {
|
||||
av_log(s->avctx, AV_LOG_ERROR, "too many channels: %d\n", s->channels);
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* get blocksize if version > 0 */
|
||||
if (s->version > 0) {
|
||||
int skip_bytes;
|
||||
s->blocksize = get_uint(s, av_log2(DEFAULT_BLOCK_SIZE));
|
||||
maxnlpc = get_uint(s, LPCQSIZE);
|
||||
s->nmean = get_uint(s, 0);
|
||||
|
||||
skip_bytes = get_uint(s, NSKIPSIZE);
|
||||
for (i=0; i<skip_bytes; i++) {
|
||||
skip_bits(&s->gb, 8);
|
||||
}
|
||||
}
|
||||
s->nwrap = FFMAX(NWRAP, maxnlpc);
|
||||
|
||||
if (allocate_buffers(s))
|
||||
return -1;
|
||||
|
||||
init_offset(s);
|
||||
|
||||
if (s->version > 1)
|
||||
s->lpcqoffset = V2LPCQOFFSET;
|
||||
|
||||
if (get_ur_golomb_shorten(&s->gb, FNSIZE) != FN_VERBATIM) {
|
||||
av_log(s->avctx, AV_LOG_ERROR, "missing verbatim section at beginning of stream\n");
|
||||
return -1;
|
||||
}
|
||||
|
||||
s->header_size = get_ur_golomb_shorten(&s->gb, VERBATIM_CKSIZE_SIZE);
|
||||
if (s->header_size >= OUT_BUFFER_SIZE || s->header_size < CANONICAL_HEADER_SIZE) {
|
||||
av_log(s->avctx, AV_LOG_ERROR, "header is wrong size: %d\n", s->header_size);
|
||||
return -1;
|
||||
}
|
||||
|
||||
for (i=0; i<s->header_size; i++)
|
||||
s->header[i] = (char)get_ur_golomb_shorten(&s->gb, VERBATIM_BYTE_SIZE);
|
||||
|
||||
if (decode_wave_header(avctx, s->header, s->header_size) < 0)
|
||||
return -1;
|
||||
|
||||
s->cur_chan = 0;
|
||||
s->bitshift = 0;
|
||||
/* process header or next subblock */
|
||||
if (!s->got_header) {
|
||||
if ((ret = read_header(s)) < 0)
|
||||
return ret;
|
||||
*data_size = 0;
|
||||
goto finish_frame;
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
/* if quit command was read previously, don't decode anything */
|
||||
if (s->got_quit_command) {
|
||||
*data_size = 0;
|
||||
return avpkt->size;
|
||||
}
|
||||
|
||||
s->cur_chan = 0;
|
||||
while (s->cur_chan < s->channels) {
|
||||
int cmd;
|
||||
int len;
|
||||
|
||||
if (get_bits_left(&s->gb) < 3+FNSIZE) {
|
||||
*data_size = 0;
|
||||
break;
|
||||
}
|
||||
|
||||
cmd = get_ur_golomb_shorten(&s->gb, FNSIZE);
|
||||
switch (cmd) {
|
||||
case FN_ZERO:
|
||||
case FN_DIFF0:
|
||||
case FN_DIFF1:
|
||||
case FN_DIFF2:
|
||||
case FN_DIFF3:
|
||||
case FN_QLPC:
|
||||
{
|
||||
int residual_size = 0;
|
||||
int channel = s->cur_chan;
|
||||
int32_t coffset;
|
||||
if (cmd != FN_ZERO) {
|
||||
residual_size = get_ur_golomb_shorten(&s->gb, ENERGYSIZE);
|
||||
/* this is a hack as version 0 differed in defintion of get_sr_golomb_shorten */
|
||||
if (s->version == 0)
|
||||
residual_size--;
|
||||
}
|
||||
|
||||
if (s->nmean == 0)
|
||||
coffset = s->offset[channel][0];
|
||||
else {
|
||||
int32_t sum = (s->version < 2) ? 0 : s->nmean / 2;
|
||||
for (i=0; i<s->nmean; i++)
|
||||
sum += s->offset[channel][i];
|
||||
coffset = sum / s->nmean;
|
||||
if (s->version >= 2)
|
||||
coffset >>= FFMIN(1, s->bitshift);
|
||||
}
|
||||
switch (cmd) {
|
||||
case FN_ZERO:
|
||||
for (i=0; i<s->blocksize; i++)
|
||||
s->decoded[channel][i] = 0;
|
||||
break;
|
||||
case FN_DIFF0:
|
||||
for (i=0; i<s->blocksize; i++)
|
||||
s->decoded[channel][i] = get_sr_golomb_shorten(&s->gb, residual_size) + coffset;
|
||||
break;
|
||||
case FN_DIFF1:
|
||||
for (i=0; i<s->blocksize; i++)
|
||||
s->decoded[channel][i] = get_sr_golomb_shorten(&s->gb, residual_size) + s->decoded[channel][i - 1];
|
||||
break;
|
||||
case FN_DIFF2:
|
||||
for (i=0; i<s->blocksize; i++)
|
||||
s->decoded[channel][i] = get_sr_golomb_shorten(&s->gb, residual_size) + 2*s->decoded[channel][i-1]
|
||||
- s->decoded[channel][i-2];
|
||||
break;
|
||||
case FN_DIFF3:
|
||||
for (i=0; i<s->blocksize; i++)
|
||||
s->decoded[channel][i] = get_sr_golomb_shorten(&s->gb, residual_size) + 3*s->decoded[channel][i-1]
|
||||
- 3*s->decoded[channel][i-2]
|
||||
+ s->decoded[channel][i-3];
|
||||
break;
|
||||
case FN_QLPC:
|
||||
{
|
||||
int pred_order = get_ur_golomb_shorten(&s->gb, LPCQSIZE);
|
||||
if (pred_order > s->nwrap) {
|
||||
av_log(avctx, AV_LOG_ERROR,
|
||||
"invalid pred_order %d\n",
|
||||
pred_order);
|
||||
return -1;
|
||||
}
|
||||
for (i=0; i<pred_order; i++)
|
||||
s->decoded[channel][i - pred_order] -= coffset;
|
||||
decode_subframe_lpc(s, channel, residual_size, pred_order);
|
||||
if (coffset != 0)
|
||||
for (i=0; i < s->blocksize; i++)
|
||||
s->decoded[channel][i] += coffset;
|
||||
}
|
||||
}
|
||||
if (s->nmean > 0) {
|
||||
int32_t sum = (s->version < 2) ? 0 : s->blocksize / 2;
|
||||
for (i=0; i<s->blocksize; i++)
|
||||
sum += s->decoded[channel][i];
|
||||
if (cmd > FN_VERBATIM) {
|
||||
av_log(avctx, AV_LOG_ERROR, "unknown shorten function %d\n", cmd);
|
||||
*data_size = 0;
|
||||
break;
|
||||
}
|
||||
|
||||
for (i=1; i<s->nmean; i++)
|
||||
s->offset[channel][i-1] = s->offset[channel][i];
|
||||
|
||||
if (s->version < 2)
|
||||
s->offset[channel][s->nmean - 1] = sum / s->blocksize;
|
||||
else
|
||||
s->offset[channel][s->nmean - 1] = (sum / s->blocksize) << s->bitshift;
|
||||
if (!is_audio_command[cmd]) {
|
||||
/* process non-audio command */
|
||||
switch (cmd) {
|
||||
case FN_VERBATIM:
|
||||
len = get_ur_golomb_shorten(&s->gb, VERBATIM_CKSIZE_SIZE);
|
||||
while (len--) {
|
||||
get_ur_golomb_shorten(&s->gb, VERBATIM_BYTE_SIZE);
|
||||
}
|
||||
for (i=-s->nwrap; i<0; i++)
|
||||
s->decoded[channel][i] = s->decoded[channel][i + s->blocksize];
|
||||
|
||||
fix_bitshift(s, s->decoded[channel]);
|
||||
|
||||
s->cur_chan++;
|
||||
if (s->cur_chan == s->channels) {
|
||||
samples = interleave_buffer(samples, s->channels, s->blocksize, s->decoded);
|
||||
s->cur_chan = 0;
|
||||
goto frame_done;
|
||||
break;
|
||||
case FN_BITSHIFT:
|
||||
s->bitshift = get_ur_golomb_shorten(&s->gb, BITSHIFTSIZE);
|
||||
break;
|
||||
case FN_BLOCKSIZE: {
|
||||
int blocksize = get_uint(s, av_log2(s->blocksize));
|
||||
if (blocksize > s->blocksize) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Increasing block size is not supported\n");
|
||||
return AVERROR_PATCHWELCOME;
|
||||
}
|
||||
if (!blocksize || blocksize > MAX_BLOCKSIZE) {
|
||||
av_log(avctx, AV_LOG_ERROR, "invalid or unsupported "
|
||||
"block size: %d\n", blocksize);
|
||||
return AVERROR(EINVAL);
|
||||
}
|
||||
s->blocksize = blocksize;
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case FN_VERBATIM:
|
||||
len = get_ur_golomb_shorten(&s->gb, VERBATIM_CKSIZE_SIZE);
|
||||
while (len--) {
|
||||
get_ur_golomb_shorten(&s->gb, VERBATIM_BYTE_SIZE);
|
||||
}
|
||||
break;
|
||||
case FN_BITSHIFT:
|
||||
s->bitshift = get_ur_golomb_shorten(&s->gb, BITSHIFTSIZE);
|
||||
break;
|
||||
case FN_BLOCKSIZE: {
|
||||
int blocksize = get_uint(s, av_log2(s->blocksize));
|
||||
if (blocksize > s->blocksize) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Increasing block size is not supported\n");
|
||||
return AVERROR_PATCHWELCOME;
|
||||
}
|
||||
s->blocksize = blocksize;
|
||||
case FN_QUIT:
|
||||
s->got_quit_command = 1;
|
||||
break;
|
||||
}
|
||||
if (cmd == FN_BLOCKSIZE || cmd == FN_QUIT) {
|
||||
*data_size = 0;
|
||||
break;
|
||||
}
|
||||
case FN_QUIT:
|
||||
*data_size = 0;
|
||||
return buf_size;
|
||||
default:
|
||||
av_log(avctx, AV_LOG_ERROR, "unknown shorten function %d\n", cmd);
|
||||
return -1;
|
||||
} else {
|
||||
/* process audio command */
|
||||
int residual_size = 0;
|
||||
int channel = s->cur_chan;
|
||||
int32_t coffset;
|
||||
|
||||
/* get Rice code for residual decoding */
|
||||
if (cmd != FN_ZERO) {
|
||||
residual_size = get_ur_golomb_shorten(&s->gb, ENERGYSIZE);
|
||||
/* this is a hack as version 0 differed in defintion of get_sr_golomb_shorten */
|
||||
if (s->version == 0)
|
||||
residual_size--;
|
||||
}
|
||||
|
||||
/* calculate sample offset using means from previous blocks */
|
||||
if (s->nmean == 0)
|
||||
coffset = s->offset[channel][0];
|
||||
else {
|
||||
int32_t sum = (s->version < 2) ? 0 : s->nmean / 2;
|
||||
for (i=0; i<s->nmean; i++)
|
||||
sum += s->offset[channel][i];
|
||||
coffset = sum / s->nmean;
|
||||
if (s->version >= 2)
|
||||
coffset >>= FFMIN(1, s->bitshift);
|
||||
}
|
||||
|
||||
/* decode samples for this channel */
|
||||
if (cmd == FN_ZERO) {
|
||||
for (i=0; i<s->blocksize; i++)
|
||||
s->decoded[channel][i] = 0;
|
||||
} else {
|
||||
if ((ret = decode_subframe_lpc(s, cmd, channel, residual_size, coffset)) < 0)
|
||||
return ret;
|
||||
}
|
||||
|
||||
/* update means with info from the current block */
|
||||
if (s->nmean > 0) {
|
||||
int32_t sum = (s->version < 2) ? 0 : s->blocksize / 2;
|
||||
for (i=0; i<s->blocksize; i++)
|
||||
sum += s->decoded[channel][i];
|
||||
|
||||
for (i=1; i<s->nmean; i++)
|
||||
s->offset[channel][i-1] = s->offset[channel][i];
|
||||
|
||||
if (s->version < 2)
|
||||
s->offset[channel][s->nmean - 1] = sum / s->blocksize;
|
||||
else
|
||||
s->offset[channel][s->nmean - 1] = (sum / s->blocksize) << s->bitshift;
|
||||
}
|
||||
|
||||
/* copy wrap samples for use with next block */
|
||||
for (i=-s->nwrap; i<0; i++)
|
||||
s->decoded[channel][i] = s->decoded[channel][i + s->blocksize];
|
||||
|
||||
/* shift samples to add in unused zero bits which were removed
|
||||
during encoding */
|
||||
fix_bitshift(s, s->decoded[channel]);
|
||||
|
||||
/* if this is the last channel in the block, output the samples */
|
||||
s->cur_chan++;
|
||||
if (s->cur_chan == s->channels) {
|
||||
int out_size = s->blocksize * s->channels *
|
||||
av_get_bytes_per_sample(avctx->sample_fmt);
|
||||
if (*data_size < out_size) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Output buffer is too small\n");
|
||||
return AVERROR(EINVAL);
|
||||
}
|
||||
samples = interleave_buffer(samples, s->channels, s->blocksize, s->decoded);
|
||||
*data_size = out_size;
|
||||
}
|
||||
}
|
||||
}
|
||||
frame_done:
|
||||
*data_size = (int8_t *)samples - (int8_t *)data;
|
||||
if (s->cur_chan < s->channels)
|
||||
*data_size = 0;
|
||||
|
||||
// s->last_blocksize = s->blocksize;
|
||||
finish_frame:
|
||||
s->bitindex = get_bits_count(&s->gb) - 8*((get_bits_count(&s->gb))/8);
|
||||
i= (get_bits_count(&s->gb))/8;
|
||||
if (i > buf_size) {
|
||||
@ -542,5 +624,6 @@ AVCodec ff_shorten_decoder = {
|
||||
.init = shorten_decode_init,
|
||||
.close = shorten_decode_close,
|
||||
.decode = shorten_decode_frame,
|
||||
.capabilities = CODEC_CAP_DELAY,
|
||||
.long_name= NULL_IF_CONFIG_SMALL("Shorten"),
|
||||
};
|
||||
|
@ -461,7 +461,7 @@ static int svq1_encode_plane(SVQ1Context *s, int plane, unsigned char *src_plane
|
||||
s->rd_total += score[best];
|
||||
|
||||
for(i=5; i>=0; i--){
|
||||
ff_copy_bits(&s->pb, reorder_buffer[best][i], count[best][i]);
|
||||
avpriv_copy_bits(&s->pb, reorder_buffer[best][i], count[best][i]);
|
||||
}
|
||||
if(best==0){
|
||||
s->dsp.put_pixels_tab[0][0](decoded, temp, stride, 16);
|
||||
@ -540,7 +540,7 @@ static int svq1_encode_frame(AVCodecContext *avctx, unsigned char *buf,
|
||||
return -1;
|
||||
}
|
||||
|
||||
// align_put_bits(&s->pb);
|
||||
// avpriv_align_put_bits(&s->pb);
|
||||
while(put_bits_count(&s->pb) & 31)
|
||||
put_bits(&s->pb, 1, 0);
|
||||
|
||||
|
@ -1363,7 +1363,7 @@ int av_lockmgr_register(int (*cb)(void **mutex, enum AVLockOp op))
|
||||
return 0;
|
||||
}
|
||||
|
||||
unsigned int ff_toupper4(unsigned int x)
|
||||
unsigned int avpriv_toupper4(unsigned int x)
|
||||
{
|
||||
return toupper( x &0xFF)
|
||||
+ (toupper((x>>8 )&0xFF)<<8 )
|
||||
|
@ -132,7 +132,7 @@ static int encode_frame(AVCodecContext *avctx, unsigned char *buf, int buf_size,
|
||||
|
||||
emms_c();
|
||||
|
||||
align_put_bits(&a->pb);
|
||||
avpriv_align_put_bits(&a->pb);
|
||||
while(get_bit_count(&a->pb)&31)
|
||||
put_bits(&a->pb, 8, 0);
|
||||
|
||||
|
@ -21,7 +21,7 @@
|
||||
#define AVCODEC_VERSION_H
|
||||
|
||||
#define LIBAVCODEC_VERSION_MAJOR 53
|
||||
#define LIBAVCODEC_VERSION_MINOR 22
|
||||
#define LIBAVCODEC_VERSION_MINOR 23
|
||||
#define LIBAVCODEC_VERSION_MICRO 0
|
||||
|
||||
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
|
||||
@ -98,5 +98,8 @@
|
||||
#ifndef FF_API_MJPEG_GLOBAL_OPTS
|
||||
#define FF_API_MJPEG_GLOBAL_OPTS (LIBAVCODEC_VERSION_MAJOR < 54)
|
||||
#endif
|
||||
#ifndef FF_API_GET_ALPHA_INFO
|
||||
#define FF_API_GET_ALPHA_INFO (LIBAVCODEC_VERSION_MAJOR < 54)
|
||||
#endif
|
||||
|
||||
#endif /* AVCODEC_VERSION_H */
|
||||
|
@ -991,7 +991,7 @@ static av_cold int vorbis_decode_init(AVCodecContext *avccontext)
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (ff_split_xiph_headers(headers, headers_len, 30, header_start, header_len) < 0) {
|
||||
if (avpriv_split_xiph_headers(headers, headers_len, 30, header_start, header_len) < 0) {
|
||||
av_log(avccontext, AV_LOG_ERROR, "Extradata corrupt.\n");
|
||||
return -1;
|
||||
}
|
||||
|
@ -2276,7 +2276,7 @@ static av_cold int theora_decode_init(AVCodecContext *avctx)
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (ff_split_xiph_headers(avctx->extradata, avctx->extradata_size,
|
||||
if (avpriv_split_xiph_headers(avctx->extradata, avctx->extradata_size,
|
||||
42, header_start, header_len) < 0) {
|
||||
av_log(avctx, AV_LOG_ERROR, "Corrupt extradata\n");
|
||||
return -1;
|
||||
|
@ -311,7 +311,7 @@ static int encode_block(WMACodecContext *s, float (*src_coefs)[BLOCK_MAX_SIZE],
|
||||
put_bits(&s->pb, s->coef_vlcs[tindex]->huffbits[1], s->coef_vlcs[tindex]->huffcodes[1]);
|
||||
}
|
||||
if (s->version == 1 && s->nb_channels >= 2) {
|
||||
align_put_bits(&s->pb);
|
||||
avpriv_align_put_bits(&s->pb);
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
@ -327,7 +327,7 @@ static int encode_frame(WMACodecContext *s, float (*src_coefs)[BLOCK_MAX_SIZE],
|
||||
return INT_MAX;
|
||||
}
|
||||
|
||||
align_put_bits(&s->pb);
|
||||
avpriv_align_put_bits(&s->pb);
|
||||
|
||||
return put_bits_count(&s->pb)/8 - s->block_align;
|
||||
}
|
||||
|
@ -1446,14 +1446,14 @@ static void save_bits(WMAProDecodeCtx *s, GetBitContext* gb, int len,
|
||||
|
||||
s->num_saved_bits += len;
|
||||
if (!append) {
|
||||
ff_copy_bits(&s->pb, gb->buffer + (get_bits_count(gb) >> 3),
|
||||
avpriv_copy_bits(&s->pb, gb->buffer + (get_bits_count(gb) >> 3),
|
||||
s->num_saved_bits);
|
||||
} else {
|
||||
int align = 8 - (get_bits_count(gb) & 7);
|
||||
align = FFMIN(align, len);
|
||||
put_bits(&s->pb, align, get_bits(gb, align));
|
||||
len -= align;
|
||||
ff_copy_bits(&s->pb, gb->buffer + (get_bits_count(gb) >> 3), len);
|
||||
avpriv_copy_bits(&s->pb, gb->buffer + (get_bits_count(gb) >> 3), len);
|
||||
}
|
||||
skip_bits_long(gb, len);
|
||||
|
||||
|
@ -1872,7 +1872,7 @@ static int parse_packet_header(WMAVoiceContext *s)
|
||||
* @param size size of the source data, in bytes
|
||||
* @param gb bit I/O context specifying the current position in the source.
|
||||
* data. This function might use this to align the bit position to
|
||||
* a whole-byte boundary before calling #ff_copy_bits() on aligned
|
||||
* a whole-byte boundary before calling #avpriv_copy_bits() on aligned
|
||||
* source data
|
||||
* @param nbits the amount of bits to copy from source to target
|
||||
*
|
||||
@ -1893,7 +1893,7 @@ static void copy_bits(PutBitContext *pb,
|
||||
rmn_bits &= 7; rmn_bytes >>= 3;
|
||||
if ((rmn_bits = FFMIN(rmn_bits, nbits)) > 0)
|
||||
put_bits(pb, rmn_bits, get_bits(gb, rmn_bits));
|
||||
ff_copy_bits(pb, data + size - rmn_bytes,
|
||||
avpriv_copy_bits(pb, data + size - rmn_bytes,
|
||||
FFMIN(nbits - rmn_bits, rmn_bytes << 3));
|
||||
}
|
||||
|
||||
|
@ -50,9 +50,9 @@ extern void ff_ac3_extract_exponents_ssse3(uint8_t *exp, int32_t *coef, int nb_c
|
||||
|
||||
av_cold void ff_ac3dsp_init_x86(AC3DSPContext *c, int bit_exact)
|
||||
{
|
||||
#if HAVE_YASM
|
||||
int mm_flags = av_get_cpu_flags();
|
||||
|
||||
#if HAVE_YASM
|
||||
if (mm_flags & AV_CPU_FLAG_MMX) {
|
||||
c->ac3_exponent_min = ff_ac3_exponent_min_mmx;
|
||||
c->ac3_max_msb_abs_int16 = ff_ac3_max_msb_abs_int16_mmx;
|
||||
|
@ -169,9 +169,9 @@ void ff_pred4x4_vertical_vp8_mmxext(uint8_t *src, const uint8_t *topright, int s
|
||||
|
||||
void ff_h264_pred_init_x86(H264PredContext *h, int codec_id, const int bit_depth, const int chroma_format_idc)
|
||||
{
|
||||
#if HAVE_YASM
|
||||
int mm_flags = av_get_cpu_flags();
|
||||
|
||||
#if HAVE_YASM
|
||||
if (bit_depth == 8) {
|
||||
if (mm_flags & AV_CPU_FLAG_MMX) {
|
||||
h->pred16x16[VERT_PRED8x8 ] = ff_pred16x16_vertical_mmx;
|
||||
|
@ -52,6 +52,6 @@ void ff_proresdsp_x86_init(ProresDSPContext *dsp, AVCodecContext *avctx)
|
||||
dsp->idct_permutation_type = FF_TRANSPOSE_IDCT_PERM;
|
||||
dsp->idct_put = ff_prores_idct_put_10_avx;
|
||||
}
|
||||
#endif
|
||||
#endif
|
||||
#endif /* HAVE_AVX */
|
||||
#endif /* ARCH_X86_64 && HAVE_YASM */
|
||||
}
|
||||
|
@ -283,9 +283,9 @@ DECLARE_LOOP_FILTER(sse4)
|
||||
|
||||
av_cold void ff_vp8dsp_init_x86(VP8DSPContext* c)
|
||||
{
|
||||
#if HAVE_YASM
|
||||
int mm_flags = av_get_cpu_flags();
|
||||
|
||||
#if HAVE_YASM
|
||||
if (mm_flags & AV_CPU_FLAG_MMX) {
|
||||
c->vp8_idct_dc_add = ff_vp8_idct_dc_add_mmx;
|
||||
c->vp8_idct_dc_add4y = ff_vp8_idct_dc_add4y_mmx;
|
||||
|
@ -21,7 +21,7 @@
|
||||
#include "libavutil/intreadwrite.h"
|
||||
#include "xiph.h"
|
||||
|
||||
int ff_split_xiph_headers(uint8_t *extradata, int extradata_size,
|
||||
int avpriv_split_xiph_headers(uint8_t *extradata, int extradata_size,
|
||||
int first_header_size, uint8_t *header_start[3],
|
||||
int header_len[3])
|
||||
{
|
||||
|
@ -36,8 +36,8 @@
|
||||
* @param[out] header_len The sizes of each of the three headers.
|
||||
* @return On error a negative value is returned, on success zero.
|
||||
*/
|
||||
int ff_split_xiph_headers(uint8_t *extradata, int extradata_size,
|
||||
int first_header_size, uint8_t *header_start[3],
|
||||
int header_len[3]);
|
||||
int avpriv_split_xiph_headers(uint8_t *extradata, int extradata_size,
|
||||
int first_header_size, uint8_t *header_start[3],
|
||||
int header_len[3]);
|
||||
|
||||
#endif /* AVCODEC_XIPH_H */
|
||||
|
@ -90,7 +90,7 @@ static int xsub_encode_rle(PutBitContext *pb, const uint8_t *bitmap,
|
||||
if (color != PADDING_COLOR && (PADDING + (w&1)))
|
||||
put_xsub_rle(pb, PADDING + (w&1), PADDING_COLOR);
|
||||
|
||||
align_put_bits(pb);
|
||||
avpriv_align_put_bits(pb);
|
||||
|
||||
bitmap += linesize;
|
||||
}
|
||||
@ -194,7 +194,7 @@ static int xsub_encode(AVCodecContext *avctx, unsigned char *buf,
|
||||
// Enforce total height to be be multiple of 2
|
||||
if (h->rects[0]->h & 1) {
|
||||
put_xsub_rle(&pb, h->rects[0]->w, PADDING_COLOR);
|
||||
align_put_bits(&pb);
|
||||
avpriv_align_put_bits(&pb);
|
||||
}
|
||||
|
||||
flush_put_bits(&pb);
|
||||
|
@ -86,7 +86,7 @@ static int dv1394_read_header(AVFormatContext * context, AVFormatParameters * ap
|
||||
{
|
||||
struct dv1394_data *dv = context->priv_data;
|
||||
|
||||
dv->dv_demux = dv_init_demux(context);
|
||||
dv->dv_demux = avpriv_dv_init_demux(context);
|
||||
if (!dv->dv_demux)
|
||||
goto failed;
|
||||
|
||||
@ -124,7 +124,7 @@ static int dv1394_read_packet(AVFormatContext *context, AVPacket *pkt)
|
||||
struct dv1394_data *dv = context->priv_data;
|
||||
int size;
|
||||
|
||||
size = dv_get_packet(dv->dv_demux, pkt);
|
||||
size = avpriv_dv_get_packet(dv->dv_demux, pkt);
|
||||
if (size > 0)
|
||||
return size;
|
||||
|
||||
@ -186,7 +186,7 @@ restart_poll:
|
||||
av_dlog(context, "index %d, avail %d, done %d\n", dv->index, dv->avail,
|
||||
dv->done);
|
||||
|
||||
size = dv_produce_packet(dv->dv_demux, pkt,
|
||||
size = avpriv_dv_produce_packet(dv->dv_demux, pkt,
|
||||
dv->ring + (dv->index * DV1394_PAL_FRAME_SIZE),
|
||||
DV1394_PAL_FRAME_SIZE, -1);
|
||||
dv->index = (dv->index + 1) % DV1394_RING_FRAMES;
|
||||
|
@ -98,7 +98,7 @@ static av_cold int read_header(AVFormatContext *ctx, AVFormatParameters *ap)
|
||||
for (i = 0; i < s->drive->tracks; i++) {
|
||||
char title[16];
|
||||
snprintf(title, sizeof(title), "track %02d", s->drive->disc_toc[i].bTrack);
|
||||
ff_new_chapter(ctx, i, st->time_base, s->drive->disc_toc[i].dwStartSector,
|
||||
avpriv_new_chapter(ctx, i, st->time_base, s->drive->disc_toc[i].dwStartSector,
|
||||
s->drive->disc_toc[i+1].dwStartSector, title);
|
||||
}
|
||||
|
||||
|
@ -41,7 +41,7 @@ static int ac3_eac3_probe(AVProbeData *p, enum CodecID expected_codec_id)
|
||||
|
||||
for(frames = 0; buf2 < end; frames++) {
|
||||
init_get_bits(&gbc, buf2, 54);
|
||||
if(ff_ac3_parse_header(&gbc, &hdr) < 0)
|
||||
if(avpriv_ac3_parse_header(&gbc, &hdr) < 0)
|
||||
break;
|
||||
if(buf2 + hdr.frame_size > end ||
|
||||
av_crc(av_crc_get_table(AV_CRC_16_ANSI), 0, buf2 + 2, hdr.frame_size - 2))
|
||||
|
@ -35,7 +35,7 @@ int ff_adts_decode_extradata(AVFormatContext *s, ADTSContext *adts, uint8_t *buf
|
||||
int off;
|
||||
|
||||
init_get_bits(&gb, buf, size * 8);
|
||||
off = ff_mpeg4audio_get_config(&m4ac, buf, size);
|
||||
off = avpriv_mpeg4audio_get_config(&m4ac, buf, size);
|
||||
if (off < 0)
|
||||
return off;
|
||||
skip_bits_long(&gb, off);
|
||||
@ -67,7 +67,7 @@ int ff_adts_decode_extradata(AVFormatContext *s, ADTSContext *adts, uint8_t *buf
|
||||
init_put_bits(&pb, adts->pce_data, MAX_PCE_SIZE);
|
||||
|
||||
put_bits(&pb, 3, 5); //ID_PCE
|
||||
adts->pce_size = (ff_copy_pce_data(&pb, &gb) + 3) / 8;
|
||||
adts->pce_size = (avpriv_copy_pce_data(&pb, &gb) + 3) / 8;
|
||||
flush_put_bits(&pb);
|
||||
}
|
||||
|
||||
|
@ -569,7 +569,7 @@ static int asf_read_marker(AVFormatContext *s, int64_t size)
|
||||
name_len = avio_rl32(pb); // name length
|
||||
if ((ret = avio_get_str16le(pb, name_len * 2, name, sizeof(name))) < name_len)
|
||||
avio_skip(pb, name_len - ret);
|
||||
ff_new_chapter(s, i, (AVRational){1, 10000000}, pres_time, AV_NOPTS_VALUE, name );
|
||||
avpriv_new_chapter(s, i, (AVRational){1, 10000000}, pres_time, AV_NOPTS_VALUE, name );
|
||||
}
|
||||
|
||||
return 0;
|
||||
|
@ -490,7 +490,7 @@ static int avi_read_header(AVFormatContext *s, AVFormatParameters *ap)
|
||||
av_freep(&s->streams[0]);
|
||||
s->nb_streams = 0;
|
||||
if (CONFIG_DV_DEMUXER) {
|
||||
avi->dv_demux = dv_init_demux(s);
|
||||
avi->dv_demux = avpriv_dv_init_demux(s);
|
||||
if (!avi->dv_demux)
|
||||
goto fail;
|
||||
}
|
||||
@ -1012,7 +1012,7 @@ static int avi_read_packet(AVFormatContext *s, AVPacket *pkt)
|
||||
void* dstr;
|
||||
|
||||
if (CONFIG_DV_DEMUXER && avi->dv_demux) {
|
||||
int size = dv_get_packet(avi->dv_demux, pkt);
|
||||
int size = avpriv_dv_get_packet(avi->dv_demux, pkt);
|
||||
if (size >= 0)
|
||||
return size;
|
||||
}
|
||||
@ -1115,7 +1115,7 @@ resync:
|
||||
|
||||
if (CONFIG_DV_DEMUXER && avi->dv_demux) {
|
||||
dstr = pkt->destruct;
|
||||
size = dv_produce_packet(avi->dv_demux, pkt,
|
||||
size = avpriv_dv_produce_packet(avi->dv_demux, pkt,
|
||||
pkt->data, pkt->size, pkt->pos);
|
||||
pkt->destruct = dstr;
|
||||
pkt->flags |= AV_PKT_FLAG_KEY;
|
||||
|
@ -270,7 +270,7 @@ static int dv_extract_video_info(DVDemuxContext *c, uint8_t* frame)
|
||||
* The following 3 functions constitute our interface to the world
|
||||
*/
|
||||
|
||||
DVDemuxContext* dv_init_demux(AVFormatContext *s)
|
||||
DVDemuxContext* avpriv_dv_init_demux(AVFormatContext *s)
|
||||
{
|
||||
DVDemuxContext *c;
|
||||
|
||||
@ -299,7 +299,7 @@ DVDemuxContext* dv_init_demux(AVFormatContext *s)
|
||||
return c;
|
||||
}
|
||||
|
||||
int dv_get_packet(DVDemuxContext *c, AVPacket *pkt)
|
||||
int avpriv_dv_get_packet(DVDemuxContext *c, AVPacket *pkt)
|
||||
{
|
||||
int size = -1;
|
||||
int i;
|
||||
@ -316,14 +316,14 @@ int dv_get_packet(DVDemuxContext *c, AVPacket *pkt)
|
||||
return size;
|
||||
}
|
||||
|
||||
int dv_produce_packet(DVDemuxContext *c, AVPacket *pkt,
|
||||
int avpriv_dv_produce_packet(DVDemuxContext *c, AVPacket *pkt,
|
||||
uint8_t* buf, int buf_size, int64_t pos)
|
||||
{
|
||||
int size, i;
|
||||
uint8_t *ppcm[4] = {0};
|
||||
|
||||
if (buf_size < DV_PROFILE_BYTES ||
|
||||
!(c->sys = ff_dv_frame_profile(c->sys, buf, buf_size)) ||
|
||||
!(c->sys = avpriv_dv_frame_profile(c->sys, buf, buf_size)) ||
|
||||
buf_size < c->sys->frame_size) {
|
||||
return -1; /* Broken frame, or not enough data */
|
||||
}
|
||||
@ -371,7 +371,7 @@ static int64_t dv_frame_offset(AVFormatContext *s, DVDemuxContext *c,
|
||||
int64_t timestamp, int flags)
|
||||
{
|
||||
// FIXME: sys may be wrong if last dv_read_packet() failed (buffer is junk)
|
||||
const DVprofile* sys = ff_dv_codec_profile(c->vst->codec);
|
||||
const DVprofile* sys = avpriv_dv_codec_profile(c->vst->codec);
|
||||
int64_t offset;
|
||||
int64_t size = avio_size(s->pb) - s->data_offset;
|
||||
int64_t max_offset = ((size-1) / sys->frame_size) * sys->frame_size;
|
||||
@ -409,7 +409,7 @@ static int dv_read_header(AVFormatContext *s,
|
||||
unsigned state, marker_pos = 0;
|
||||
RawDVContext *c = s->priv_data;
|
||||
|
||||
c->dv_demux = dv_init_demux(s);
|
||||
c->dv_demux = avpriv_dv_init_demux(s);
|
||||
if (!c->dv_demux)
|
||||
return -1;
|
||||
|
||||
@ -434,7 +434,7 @@ static int dv_read_header(AVFormatContext *s,
|
||||
avio_seek(s->pb, -DV_PROFILE_BYTES, SEEK_CUR) < 0)
|
||||
return AVERROR(EIO);
|
||||
|
||||
c->dv_demux->sys = ff_dv_frame_profile(c->dv_demux->sys, c->buf, DV_PROFILE_BYTES);
|
||||
c->dv_demux->sys = avpriv_dv_frame_profile(c->dv_demux->sys, c->buf, DV_PROFILE_BYTES);
|
||||
if (!c->dv_demux->sys) {
|
||||
av_log(s, AV_LOG_ERROR, "Can't determine profile of DV input stream.\n");
|
||||
return -1;
|
||||
@ -452,7 +452,7 @@ static int dv_read_packet(AVFormatContext *s, AVPacket *pkt)
|
||||
int size;
|
||||
RawDVContext *c = s->priv_data;
|
||||
|
||||
size = dv_get_packet(c->dv_demux, pkt);
|
||||
size = avpriv_dv_get_packet(c->dv_demux, pkt);
|
||||
|
||||
if (size < 0) {
|
||||
int64_t pos = avio_tell(s->pb);
|
||||
@ -462,7 +462,7 @@ static int dv_read_packet(AVFormatContext *s, AVPacket *pkt)
|
||||
if (avio_read(s->pb, c->buf, size) <= 0)
|
||||
return AVERROR(EIO);
|
||||
|
||||
size = dv_produce_packet(c->dv_demux, pkt, c->buf, size, pos);
|
||||
size = avpriv_dv_produce_packet(c->dv_demux, pkt, c->buf, size, pos);
|
||||
}
|
||||
|
||||
return size;
|
||||
|
@ -31,9 +31,9 @@
|
||||
#include "avformat.h"
|
||||
|
||||
typedef struct DVDemuxContext DVDemuxContext;
|
||||
DVDemuxContext* dv_init_demux(AVFormatContext* s);
|
||||
int dv_get_packet(DVDemuxContext*, AVPacket *);
|
||||
int dv_produce_packet(DVDemuxContext*, AVPacket*, uint8_t*, int, int64_t);
|
||||
DVDemuxContext* avpriv_dv_init_demux(AVFormatContext* s);
|
||||
int avpriv_dv_get_packet(DVDemuxContext*, AVPacket *);
|
||||
int avpriv_dv_produce_packet(DVDemuxContext*, AVPacket*, uint8_t*, int, int64_t);
|
||||
void dv_offset_reset(DVDemuxContext *c, int64_t frame_offset);
|
||||
|
||||
typedef struct DVMuxContext DVMuxContext;
|
||||
|
@ -320,7 +320,7 @@ static DVMuxContext* dv_init_mux(AVFormatContext* s)
|
||||
c->ast[i]->codec->channels != 2))
|
||||
goto bail_out;
|
||||
}
|
||||
c->sys = ff_dv_codec_profile(vst->codec);
|
||||
c->sys = avpriv_dv_codec_profile(vst->codec);
|
||||
if (!c->sys)
|
||||
goto bail_out;
|
||||
|
||||
|
@ -75,7 +75,7 @@ static AVChapter *read_chapter(AVFormatContext *s)
|
||||
end = AV_NOPTS_VALUE;
|
||||
}
|
||||
|
||||
return ff_new_chapter(s, s->nb_chapters, tb, start, end, NULL);
|
||||
return avpriv_new_chapter(s, s->nb_chapters, tb, start, end, NULL);
|
||||
}
|
||||
|
||||
static uint8_t *unescape(uint8_t *buf, int size)
|
||||
|
@ -48,7 +48,7 @@ static int flac_read_header(AVFormatContext *s,
|
||||
/* process metadata blocks */
|
||||
while (!url_feof(s->pb) && !metadata_last) {
|
||||
avio_read(s->pb, header, 4);
|
||||
ff_flac_parse_block_header(header, &metadata_last, &metadata_type,
|
||||
avpriv_flac_parse_block_header(header, &metadata_last, &metadata_type,
|
||||
&metadata_size);
|
||||
switch (metadata_type) {
|
||||
/* allocate and read metadata block for supported types */
|
||||
@ -87,7 +87,7 @@ static int flac_read_header(AVFormatContext *s,
|
||||
buffer = NULL;
|
||||
|
||||
/* get codec params from STREAMINFO header */
|
||||
ff_flac_parse_streaminfo(st->codec, &si, st->codec->extradata);
|
||||
avpriv_flac_parse_streaminfo(st->codec, &si, st->codec->extradata);
|
||||
|
||||
/* set time base and duration */
|
||||
if (si.samplerate > 0) {
|
||||
|
@ -94,7 +94,7 @@ static int flac_write_trailer(struct AVFormatContext *s)
|
||||
enum FLACExtradataFormat format;
|
||||
int64_t file_size;
|
||||
|
||||
if (!ff_flac_is_extradata_valid(s->streams[0]->codec, &format, &streaminfo))
|
||||
if (!avpriv_flac_is_extradata_valid(s->streams[0]->codec, &format, &streaminfo))
|
||||
return -1;
|
||||
|
||||
if (pb->seekable) {
|
||||
|
@ -34,7 +34,7 @@ int ff_flac_write_header(AVIOContext *pb, AVCodecContext *codec,
|
||||
enum FLACExtradataFormat format;
|
||||
|
||||
header[4] = last_block ? 0x80 : 0x00;
|
||||
if (!ff_flac_is_extradata_valid(codec, &format, &streaminfo))
|
||||
if (!avpriv_flac_is_extradata_valid(codec, &format, &streaminfo))
|
||||
return -1;
|
||||
|
||||
/* write "fLaC" stream marker and first metadata block header if needed */
|
||||
|
@ -542,7 +542,7 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt)
|
||||
return ret;
|
||||
if (st->codec->codec_id == CODEC_ID_AAC) {
|
||||
MPEG4AudioConfig cfg;
|
||||
ff_mpeg4audio_get_config(&cfg, st->codec->extradata,
|
||||
avpriv_mpeg4audio_get_config(&cfg, st->codec->extradata,
|
||||
st->codec->extradata_size);
|
||||
st->codec->channels = cfg.channels;
|
||||
if (cfg.ext_sample_rate)
|
||||
|
@ -61,7 +61,7 @@ typedef struct FLVContext {
|
||||
int64_t filesize_offset;
|
||||
int64_t duration;
|
||||
int delay; ///< first dts delay for AVC
|
||||
int64_t last_video_ts;
|
||||
int64_t last_ts;
|
||||
} FLVContext;
|
||||
|
||||
static int get_audio_flags(AVCodecContext *enc){
|
||||
@ -78,11 +78,6 @@ static int get_audio_flags(AVCodecContext *enc){
|
||||
av_log(enc, AV_LOG_ERROR, "flv only supports mono Speex audio\n");
|
||||
return -1;
|
||||
}
|
||||
if (enc->frame_size / 320 > 8) {
|
||||
av_log(enc, AV_LOG_WARNING, "Warning: Speex stream has more than "
|
||||
"8 frames per packet. Adobe Flash "
|
||||
"Player cannot handle this!\n");
|
||||
}
|
||||
return FLV_CODECID_SPEEX | FLV_SAMPLERATE_11025HZ | FLV_SAMPLESSIZE_16BIT;
|
||||
} else {
|
||||
switch (enc->sample_rate) {
|
||||
@ -223,7 +218,7 @@ static int flv_write_header(AVFormatContext *s)
|
||||
}
|
||||
}
|
||||
|
||||
flv->last_video_ts = -1;
|
||||
flv->last_ts = -1;
|
||||
|
||||
/* write meta_tag */
|
||||
avio_w8(pb, 18); // tag type META
|
||||
@ -368,7 +363,7 @@ static int flv_write_trailer(AVFormatContext *s)
|
||||
AVCodecContext *enc = s->streams[i]->codec;
|
||||
if (enc->codec_type == AVMEDIA_TYPE_VIDEO &&
|
||||
(enc->codec_id == CODEC_ID_H264 || enc->codec_id == CODEC_ID_MPEG4)) {
|
||||
put_avc_eos_tag(pb, flv->last_video_ts);
|
||||
put_avc_eos_tag(pb, flv->last_ts);
|
||||
}
|
||||
}
|
||||
|
||||
@ -434,19 +429,26 @@ static int flv_write_packet(AVFormatContext *s, AVPacket *pkt)
|
||||
if (ff_avc_parse_nal_units_buf(pkt->data, &data, &size) < 0)
|
||||
return -1;
|
||||
}
|
||||
if (!flv->delay && pkt->dts < 0)
|
||||
flv->delay = -pkt->dts;
|
||||
} else if (enc->codec_id == CODEC_ID_AAC && pkt->size > 2 &&
|
||||
(AV_RB16(pkt->data) & 0xfff0) == 0xfff0) {
|
||||
av_log(s, AV_LOG_ERROR, "malformated aac bitstream, use -absf aac_adtstoasc\n");
|
||||
return -1;
|
||||
}
|
||||
if (!flv->delay && pkt->dts < 0)
|
||||
flv->delay = -pkt->dts;
|
||||
|
||||
ts = pkt->dts + flv->delay; // add delay to force positive dts
|
||||
if (enc->codec_type == AVMEDIA_TYPE_VIDEO) {
|
||||
if (flv->last_video_ts < ts)
|
||||
flv->last_video_ts = ts;
|
||||
|
||||
/* check Speex packet duration */
|
||||
if (enc->codec_id == CODEC_ID_SPEEX && ts - flv->last_ts > 160) {
|
||||
av_log(s, AV_LOG_WARNING, "Warning: Speex stream has more than "
|
||||
"8 frames per packet. Adobe Flash "
|
||||
"Player cannot handle this!\n");
|
||||
}
|
||||
|
||||
if (flv->last_ts < ts)
|
||||
flv->last_ts = ts;
|
||||
|
||||
avio_wb24(pb,size + flags_size);
|
||||
avio_wb24(pb,ts);
|
||||
avio_w8(pb,(ts >> 24) & 0x7F); // timestamps are 32bits _signed_
|
||||
|
@ -185,9 +185,9 @@ static void gxf_material_tags(AVIOContext *pb, int *len, struct gxf_stream_info
|
||||
* @return fps as AVRational, or 0 / 0 if unknown
|
||||
*/
|
||||
static AVRational fps_tag2avr(int32_t fps) {
|
||||
extern const AVRational ff_frame_rate_tab[];
|
||||
extern const AVRational avpriv_frame_rate_tab[];
|
||||
if (fps < 1 || fps > 9) fps = 9;
|
||||
return ff_frame_rate_tab[9 - fps]; // values have opposite order
|
||||
return avpriv_frame_rate_tab[9 - fps]; // values have opposite order
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -223,8 +223,8 @@ int ff_add_index_entry(AVIndexEntry **index_entries,
|
||||
*
|
||||
* @return AVChapter or NULL on error
|
||||
*/
|
||||
AVChapter *ff_new_chapter(AVFormatContext *s, int id, AVRational time_base,
|
||||
int64_t start, int64_t end, const char *title);
|
||||
AVChapter *avpriv_new_chapter(AVFormatContext *s, int id, AVRational time_base,
|
||||
int64_t start, int64_t end, const char *title);
|
||||
|
||||
/**
|
||||
* Ensure the index uses less memory than the maximum specified in
|
||||
|
@ -433,11 +433,11 @@ int ff_mp4_read_dec_config_descr(AVFormatContext *fc, AVStream *st, AVIOContext
|
||||
st->codec->extradata_size = len;
|
||||
if (st->codec->codec_id == CODEC_ID_AAC) {
|
||||
MPEG4AudioConfig cfg;
|
||||
ff_mpeg4audio_get_config(&cfg, st->codec->extradata,
|
||||
avpriv_mpeg4audio_get_config(&cfg, st->codec->extradata,
|
||||
st->codec->extradata_size);
|
||||
st->codec->channels = cfg.channels;
|
||||
if (cfg.object_type == 29 && cfg.sampling_index < 3) // old mp3on4
|
||||
st->codec->sample_rate = ff_mpa_freq_tab[cfg.sampling_index];
|
||||
st->codec->sample_rate = avpriv_mpa_freq_tab[cfg.sampling_index];
|
||||
else if (cfg.ext_sample_rate)
|
||||
st->codec->sample_rate = cfg.ext_sample_rate;
|
||||
else
|
||||
|
@ -55,7 +55,7 @@ static int latm_decode_extradata(LATMContext *ctx, uint8_t *buf, int size)
|
||||
MPEG4AudioConfig m4ac;
|
||||
|
||||
init_get_bits(&gb, buf, size * 8);
|
||||
ctx->off = ff_mpeg4audio_get_config(&m4ac, buf, size);
|
||||
ctx->off = avpriv_mpeg4audio_get_config(&m4ac, buf, size);
|
||||
if (ctx->off < 0)
|
||||
return ctx->off;
|
||||
skip_bits_long(&gb, ctx->off);
|
||||
@ -110,12 +110,12 @@ static int latm_write_frame_header(AVFormatContext *s, PutBitContext *bs)
|
||||
/* AudioSpecificConfig */
|
||||
if (ctx->object_type == AOT_ALS) {
|
||||
header_size = avctx->extradata_size-(ctx->off + 7) >> 3;
|
||||
ff_copy_bits(bs, &avctx->extradata[ctx->off], header_size);
|
||||
avpriv_copy_bits(bs, &avctx->extradata[ctx->off], header_size);
|
||||
} else {
|
||||
ff_copy_bits(bs, avctx->extradata, ctx->off + 3);
|
||||
avpriv_copy_bits(bs, avctx->extradata, ctx->off + 3);
|
||||
|
||||
if (!ctx->channel_conf) {
|
||||
ff_copy_pce_data(bs, &gb);
|
||||
avpriv_copy_pce_data(bs, &gb);
|
||||
}
|
||||
}
|
||||
|
||||
@ -168,7 +168,7 @@ static int latm_write_packet(AVFormatContext *s, AVPacket *pkt)
|
||||
for (i = 0; i < pkt->size; i++)
|
||||
put_bits(&bs, 8, pkt->data[i]);
|
||||
|
||||
align_put_bits(&bs);
|
||||
avpriv_align_put_bits(&bs);
|
||||
flush_put_bits(&bs);
|
||||
|
||||
len = put_bits_count(&bs) >> 3;
|
||||
|
@ -1,7 +1,23 @@
|
||||
LIBAVFORMAT_$MAJOR {
|
||||
global: *;
|
||||
local:
|
||||
ff_*_demuxer;
|
||||
ff_*_muxer;
|
||||
ff_*_protocol;
|
||||
global: av*;
|
||||
#FIXME those are for avserver
|
||||
ff_inet_aton;
|
||||
ff_socket_nonblock;
|
||||
ffm_set_write_index;
|
||||
ffm_read_write_index;
|
||||
ffm_write_write_index;
|
||||
ff_rtsp_parse_line;
|
||||
ff_rtp_get_local_rtp_port;
|
||||
ff_rtp_get_local_rtcp_port;
|
||||
ffio_open_dyn_packet_buf;
|
||||
url_open;
|
||||
url_close;
|
||||
url_write;
|
||||
url_get_max_packet_size;
|
||||
#those are deprecated, remove on next bump
|
||||
find_info_tag;
|
||||
parse_date;
|
||||
dump_format;
|
||||
url_*;
|
||||
local: *;
|
||||
};
|
||||
|
@ -1303,8 +1303,8 @@ static int matroska_aac_sri(int samplerate)
|
||||
{
|
||||
int sri;
|
||||
|
||||
for (sri=0; sri<FF_ARRAY_ELEMS(ff_mpeg4audio_sample_rates); sri++)
|
||||
if (ff_mpeg4audio_sample_rates[sri] == samplerate)
|
||||
for (sri=0; sri<FF_ARRAY_ELEMS(avpriv_mpeg4audio_sample_rates); sri++)
|
||||
if (avpriv_mpeg4audio_sample_rates[sri] == samplerate)
|
||||
break;
|
||||
return sri;
|
||||
}
|
||||
@ -1668,7 +1668,7 @@ static int matroska_read_header(AVFormatContext *s, AVFormatParameters *ap)
|
||||
if (chapters[i].start != AV_NOPTS_VALUE && chapters[i].uid
|
||||
&& (max_start==0 || chapters[i].start > max_start)) {
|
||||
chapters[i].chapter =
|
||||
ff_new_chapter(s, chapters[i].uid, (AVRational){1, 1000000000},
|
||||
avpriv_new_chapter(s, chapters[i].uid, (AVRational){1, 1000000000},
|
||||
chapters[i].start, chapters[i].end,
|
||||
chapters[i].title);
|
||||
av_dict_set(&chapters[i].chapter->metadata,
|
||||
|
@ -423,7 +423,7 @@ static int put_xiph_codecpriv(AVFormatContext *s, AVIOContext *pb, AVCodecContex
|
||||
else
|
||||
first_header_size = 42;
|
||||
|
||||
if (ff_split_xiph_headers(codec->extradata, codec->extradata_size,
|
||||
if (avpriv_split_xiph_headers(codec->extradata, codec->extradata_size,
|
||||
first_header_size, header_start, header_len) < 0) {
|
||||
av_log(s, AV_LOG_ERROR, "Extradata corrupt.\n");
|
||||
return -1;
|
||||
@ -443,7 +443,7 @@ static void get_aac_sample_rates(AVFormatContext *s, AVCodecContext *codec, int
|
||||
{
|
||||
MPEG4AudioConfig mp4ac;
|
||||
|
||||
if (ff_mpeg4audio_get_config(&mp4ac, codec->extradata, codec->extradata_size) < 0) {
|
||||
if (avpriv_mpeg4audio_get_config(&mp4ac, codec->extradata, codec->extradata_size) < 0) {
|
||||
av_log(s, AV_LOG_WARNING, "Error parsing AAC extradata, unable to determine samplerate.\n");
|
||||
return;
|
||||
}
|
||||
|
@ -289,7 +289,7 @@ static int mov_read_chpl(MOVContext *c, AVIOContext *pb, MOVAtom atom)
|
||||
|
||||
avio_read(pb, str, str_len);
|
||||
str[str_len] = 0;
|
||||
ff_new_chapter(c->fc, i, (AVRational){1,10000000}, start, AV_NOPTS_VALUE, str);
|
||||
avpriv_new_chapter(c->fc, i, (AVRational){1,10000000}, start, AV_NOPTS_VALUE, str);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
@ -1291,7 +1291,7 @@ int ff_mov_read_stsd_entries(MOVContext *c, AVIOContext *pb, int entries)
|
||||
#if CONFIG_DV_DEMUXER
|
||||
case CODEC_ID_DVAUDIO:
|
||||
c->dv_fctx = avformat_alloc_context();
|
||||
c->dv_demux = dv_init_demux(c->dv_fctx);
|
||||
c->dv_demux = avpriv_dv_init_demux(c->dv_fctx);
|
||||
if (!c->dv_demux) {
|
||||
av_log(c->fc, AV_LOG_ERROR, "dv demux context init error\n");
|
||||
return -1;
|
||||
@ -2484,7 +2484,7 @@ static void mov_read_chapters(AVFormatContext *s)
|
||||
}
|
||||
}
|
||||
|
||||
ff_new_chapter(s, i, st->time_base, sample->timestamp, end, title);
|
||||
avpriv_new_chapter(s, i, st->time_base, sample->timestamp, end, title);
|
||||
av_freep(&title);
|
||||
}
|
||||
finish:
|
||||
@ -2592,10 +2592,10 @@ static int mov_read_packet(AVFormatContext *s, AVPacket *pkt)
|
||||
}
|
||||
#if CONFIG_DV_DEMUXER
|
||||
if (mov->dv_demux && sc->dv_audio_container) {
|
||||
dv_produce_packet(mov->dv_demux, pkt, pkt->data, pkt->size, pkt->pos);
|
||||
avpriv_dv_produce_packet(mov->dv_demux, pkt, pkt->data, pkt->size, pkt->pos);
|
||||
av_free(pkt->data);
|
||||
pkt->size = 0;
|
||||
ret = dv_get_packet(mov->dv_demux, pkt);
|
||||
ret = avpriv_dv_get_packet(mov->dv_demux, pkt);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
}
|
||||
|
@ -51,7 +51,7 @@ static int mp3_read_probe(AVProbeData *p)
|
||||
|
||||
for(frames = 0; buf2 < end; frames++) {
|
||||
header = AV_RB32(buf2);
|
||||
fsize = ff_mpa_decode_header(&avctx, header, &sample_rate, &sample_rate, &sample_rate, &sample_rate);
|
||||
fsize = avpriv_mpa_decode_header(&avctx, header, &sample_rate, &sample_rate, &sample_rate, &sample_rate);
|
||||
if(fsize < 0)
|
||||
break;
|
||||
buf2 += fsize;
|
||||
@ -86,7 +86,7 @@ static int mp3_parse_vbr_tags(AVFormatContext *s, AVStream *st, int64_t base)
|
||||
if(ff_mpa_check_header(v) < 0)
|
||||
return -1;
|
||||
|
||||
if (ff_mpegaudio_decode_header(&c, v) == 0)
|
||||
if (avpriv_mpegaudio_decode_header(&c, v) == 0)
|
||||
vbrtag_size = c.frame_size;
|
||||
if(c.layer != 3)
|
||||
return -1;
|
||||
|
@ -235,12 +235,12 @@ static int mp3_write_xing(AVFormatContext *s)
|
||||
int srate_idx, i, channels;
|
||||
int needed;
|
||||
|
||||
for (i = 0; i < FF_ARRAY_ELEMS(ff_mpa_freq_tab); i++)
|
||||
if (ff_mpa_freq_tab[i] == codec->sample_rate) {
|
||||
for (i = 0; i < FF_ARRAY_ELEMS(avpriv_mpa_freq_tab); i++)
|
||||
if (avpriv_mpa_freq_tab[i] == codec->sample_rate) {
|
||||
srate_idx = i;
|
||||
break;
|
||||
}
|
||||
if (i == FF_ARRAY_ELEMS(ff_mpa_freq_tab)) {
|
||||
if (i == FF_ARRAY_ELEMS(avpriv_mpa_freq_tab)) {
|
||||
av_log(s, AV_LOG_ERROR, "Unsupported sample rate.\n");
|
||||
return -1;
|
||||
}
|
||||
@ -263,7 +263,7 @@ static int mp3_write_xing(AVFormatContext *s)
|
||||
|
||||
mask = (bitrate_idx << 4) << 8;
|
||||
header |= mask;
|
||||
ff_mpegaudio_decode_header(&c, header);
|
||||
avpriv_mpegaudio_decode_header(&c, header);
|
||||
xing_offset=xing_offtbl[c.lsf == 1][c.nb_channels == 1];
|
||||
needed = 4 // header
|
||||
+ xing_offset
|
||||
|
@ -979,7 +979,7 @@ static int mpegts_write_packet(AVFormatContext *s, AVPacket *pkt)
|
||||
}
|
||||
|
||||
do {
|
||||
p = ff_find_start_code(p, buf_end, &state);
|
||||
p = avpriv_mpv_find_start_code(p, buf_end, &state);
|
||||
//av_log(s, AV_LOG_INFO, "nal %d\n", state & 0x1f);
|
||||
} while (p < buf_end && (state & 0x1f) != 9 &&
|
||||
(state & 0x1f) != 5 && (state & 0x1f) != 1);
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user