[FFmpeg-cvslog] avformat/dashdec: Avoid double free on error
Andreas Rheinhardt
git at videolan.org
Mon Sep 21 05:59:49 EEST 2020
ffmpeg | branch: master | Andreas Rheinhardt <andreas.rheinhardt at gmail.com> | Mon Sep 7 18:41:51 2020 +0200| [e09e2c6442924bfa1fb5efc419bc27fc6ef8a532] | committer: Andreas Rheinhardt
avformat/dashdec: Avoid double free on error
When using one of the AV_DICT_DONT_STRDUP_KEY/VAL flags, av_dict_set()
already frees the key/value on error, so that freeing it again would
lead to a double free.
Reviewed-by: Steven Liu <lq at chinaffmpeg.org>
Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt at gmail.com>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=e09e2c6442924bfa1fb5efc419bc27fc6ef8a532
---
libavformat/dashdec.c | 4 +---
1 file changed, 1 insertion(+), 3 deletions(-)
diff --git a/libavformat/dashdec.c b/libavformat/dashdec.c
index 1e9985f32c..4048323c7d 100644
--- a/libavformat/dashdec.c
+++ b/libavformat/dashdec.c
@@ -1869,10 +1869,8 @@ static int save_avio_options(AVFormatContext *s)
if (av_opt_get(s->pb, *opt, AV_OPT_SEARCH_CHILDREN, &buf) >= 0) {
if (buf[0] != '\0') {
ret = av_dict_set(&c->avio_opts, *opt, buf, AV_DICT_DONT_STRDUP_VAL);
- if (ret < 0) {
- av_freep(&buf);
+ if (ret < 0)
return ret;
- }
} else {
av_freep(&buf);
}
More information about the ffmpeg-cvslog
mailing list