aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michael@niedermayer.cc>2016-01-13 02:31:59 +0100
committerMichael Niedermayer <michael@niedermayer.cc>2016-01-13 03:09:08 +0100
commit115fb6d03ef6310732b42258d8c3cd1839cfb74b (patch)
tree0e1a710796e9ca898602e90874fb26f954f48e14
parent1a876cc581e70990aaa9c6482bb8e6ea5b21071b (diff)
downloadffmpeg-115fb6d03ef6310732b42258d8c3cd1839cfb74b.tar.gz
avformat/aviobuf: Fix end check in put_str16()
Fixes out of array read Fixes: 03c406ec9530e594a074ce2979f8a1f0/asan_heap-oob_7dec26_4664_37c52495b2870a2eaac65f53958e76c1.flac Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
-rw-r--r--libavformat/aviobuf.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/libavformat/aviobuf.c b/libavformat/aviobuf.c
index 57cbf8311d..b56d113e02 100644
--- a/libavformat/aviobuf.c
+++ b/libavformat/aviobuf.c
@@ -361,6 +361,8 @@ static inline int put_str16(AVIOContext *s, const char *str, const int be)
invalid:
av_log(s, AV_LOG_ERROR, "Invaid UTF8 sequence in avio_put_str16%s\n", be ? "be" : "le");
err = AVERROR(EINVAL);
+ if (!*(q-1))
+ break;
}
if (be)
avio_wb16(s, 0);