From c55427f8c8348af12b77b9601479769d701d8c99 Mon Sep 17 00:00:00 2001 From: Mark Hills Date: Sat, 21 Dec 2002 15:54:21 +0000 Subject: fixes crash patch by (Mark Hills ) Originally committed as revision 1355 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavcodec/oggvorbis.c | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) (limited to 'libavcodec/oggvorbis.c') diff --git a/libavcodec/oggvorbis.c b/libavcodec/oggvorbis.c index e327e2fd3e..6e661926c6 100644 --- a/libavcodec/oggvorbis.c +++ b/libavcodec/oggvorbis.c @@ -24,12 +24,20 @@ typedef struct OggVorbisContext { int oggvorbis_init_encoder(vorbis_info *vi, AVCodecContext *avccontext) { - if(avccontext->coded_frame->quality) /* VBR requested */ - return vorbis_encode_init_vbr(vi, avccontext->channels, - avccontext->sample_rate, (float)avccontext->coded_frame->quality / 1000) ; + +#ifdef OGGVORBIS_VBR_BY_ESTIMATE + /* variable bitrate by estimate */ + + return (vorbis_encode_setup_managed(vi, avccontext->channels, + avccontext->sample_rate, -1, avccontext->bit_rate, -1) || + vorbis_encode_ctl(vi, OV_ECTL_RATEMANAGE_AVG, NULL) || + vorbis_encode_setup_init(vi)) ; +#else + /* constant bitrate */ return vorbis_encode_init(vi, avccontext->channels, avccontext->sample_rate, -1, avccontext->bit_rate, -1) ; +#endif } -- cgit v1.2.3