Commit 50e7da47 authored by jbr's avatar jbr

fix and simplify frame size check and reencoding in verbatim mode

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@14811 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent a9955147
...@@ -1242,9 +1242,15 @@ static int flac_encode_frame(AVCodecContext *avctx, uint8_t *frame, ...@@ -1242,9 +1242,15 @@ static int flac_encode_frame(AVCodecContext *avctx, uint8_t *frame,
FlacEncodeContext *s; FlacEncodeContext *s;
int16_t *samples = data; int16_t *samples = data;
int out_bytes; int out_bytes;
int reencoded=0;
s = avctx->priv_data; s = avctx->priv_data;
if(buf_size < s->max_framesize*2) {
av_log(avctx, AV_LOG_ERROR, "output buffer too small\n");
return 0;
}
init_frame(s); init_frame(s);
copy_samples(s, samples); copy_samples(s, samples);
...@@ -1254,28 +1260,27 @@ static int flac_encode_frame(AVCodecContext *avctx, uint8_t *frame, ...@@ -1254,28 +1260,27 @@ static int flac_encode_frame(AVCodecContext *avctx, uint8_t *frame,
for(ch=0; ch<s->channels; ch++) { for(ch=0; ch<s->channels; ch++) {
encode_residual(s, ch); encode_residual(s, ch);
} }
init_put_bits(&s->pb, frame, buf_size);
output_frame_header(s);
output_subframes(s);
output_frame_footer(s);
out_bytes = put_bits_count(&s->pb) >> 3;
if(out_bytes > s->max_framesize || out_bytes >= buf_size) { write_frame:
/* frame too large. use verbatim mode */
for(ch=0; ch<s->channels; ch++) {
encode_residual_v(s, ch);
}
init_put_bits(&s->pb, frame, buf_size); init_put_bits(&s->pb, frame, buf_size);
output_frame_header(s); output_frame_header(s);
output_subframes(s); output_subframes(s);
output_frame_footer(s); output_frame_footer(s);
out_bytes = put_bits_count(&s->pb) >> 3; out_bytes = put_bits_count(&s->pb) >> 3;
if(out_bytes > s->max_framesize || out_bytes >= buf_size) { if(out_bytes > s->max_framesize) {
if(reencoded) {
/* still too large. must be an error. */ /* still too large. must be an error. */
av_log(avctx, AV_LOG_ERROR, "error encoding frame\n"); av_log(avctx, AV_LOG_ERROR, "error encoding frame\n");
return -1; return -1;
} }
/* frame too large. use verbatim mode */
for(ch=0; ch<s->channels; ch++) {
encode_residual_v(s, ch);
}
reencoded = 1;
goto write_frame;
} }
s->frame_count++; s->frame_count++;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment