[FFmpeg-devel] [PATCH 02/17] avcodec/microdvddec: add some memory checks
Clément Bœsch
u at pkh.me
Sat Sep 20 22:27:42 CEST 2014
---
libavcodec/microdvddec.c | 18 ++++++++++--------
1 file changed, 10 insertions(+), 8 deletions(-)
diff --git a/libavcodec/microdvddec.c b/libavcodec/microdvddec.c
index 7df3e48..9db44e0 100644
--- a/libavcodec/microdvddec.c
+++ b/libavcodec/microdvddec.c
@@ -261,7 +261,6 @@ static int microdvd_decode_frame(AVCodecContext *avctx,
AVSubtitle *sub = data;
AVBPrint new_line;
char c;
- char *decoded_sub;
char *line = avpkt->data;
char *end = avpkt->data + avpkt->size;
struct microdvd_tag tags[sizeof(MICRODVD_TAGS) - 1] = {{0}};
@@ -301,18 +300,21 @@ static int microdvd_decode_frame(AVCodecContext *avctx,
}
}
if (new_line.len) {
- av_bprintf(&new_line, "\r\n");
-
- av_bprint_finalize(&new_line, &decoded_sub);
- if (*decoded_sub) {
+ int ret;
int64_t start = avpkt->pts;
int64_t duration = avpkt->duration;
int ts_start = av_rescale_q(start, avctx->time_base, (AVRational){1,100});
int ts_duration = duration != -1 ?
av_rescale_q(duration, avctx->time_base, (AVRational){1,100}) : -1;
- ff_ass_add_rect(sub, decoded_sub, ts_start, ts_duration, 0);
- }
- av_free(decoded_sub);
+
+ av_bprintf(&new_line, "\r\n");
+ if (!av_bprint_is_complete(&new_line))
+ ret = AVERROR(ENOMEM);
+ else
+ ret = ff_ass_add_rect(sub, new_line.str, ts_start, ts_duration, 0);
+ av_bprint_finalize(&new_line, NULL);
+ if (ret < 0)
+ return ret;
}
*got_sub_ptr = sub->num_rects > 0;
--
2.1.0
More information about the ffmpeg-devel
mailing list