summaryrefslogtreecommitdiffstats
path: root/media/libstagefright/MPEG4Extractor.cpp
diff options
context:
space:
mode:
authorSteve Kondik <shade@chemlab.org>2016-02-29 17:32:19 -0800
committerKeith Mok <kmok@cyngn.com>2016-03-01 09:11:15 -0800
commit808632f7bf0a897fb55cc38170ad6c1b2fd86ba2 (patch)
treef40a0fdab15259e17b769aa59788ec5fdccec0ce /media/libstagefright/MPEG4Extractor.cpp
parentc5fa90a809c9e7a98e32373a4dea6b3e46a0e92c (diff)
downloadframeworks_av-808632f7bf0a897fb55cc38170ad6c1b2fd86ba2.zip
frameworks_av-808632f7bf0a897fb55cc38170ad6c1b2fd86ba2.tar.gz
frameworks_av-808632f7bf0a897fb55cc38170ad6c1b2fd86ba2.tar.bz2
stagefright: Don't crash on invalid / null AVCC atoms in MKV
* Seen in the wild. If a file contains an invalid track, skip it. * Also correct AVCC atom size check in Matroska extractor. REF: CYNGNOS-2168 Change-Id: I589aadbd689c9a00e1dca613e61fcec5b06ed69a
Diffstat (limited to 'media/libstagefright/MPEG4Extractor.cpp')
-rwxr-xr-xmedia/libstagefright/MPEG4Extractor.cpp12
1 files changed, 7 insertions, 5 deletions
diff --git a/media/libstagefright/MPEG4Extractor.cpp b/media/libstagefright/MPEG4Extractor.cpp
index c928495..3baf6b6 100755
--- a/media/libstagefright/MPEG4Extractor.cpp
+++ b/media/libstagefright/MPEG4Extractor.cpp
@@ -3325,11 +3325,13 @@ MPEG4Source::MPEG4Source(
const uint8_t *ptr = (const uint8_t *)data;
- CHECK(size >= 7);
- CHECK_EQ((unsigned)ptr[0], 1u); // configurationVersion == 1
-
- // The number of bytes used to encode the length of a NAL unit.
- mNALLengthSize = 1 + (ptr[4] & 3);
+ if (size < 7 || ptr[0] != 1) {
+ ALOGE("Invalid AVCC atom, size %zu, configurationVersion: %d",
+ size, ptr[0]);
+ } else {
+ // The number of bytes used to encode the length of a NAL unit.
+ mNALLengthSize = 1 + (ptr[4] & 3);
+ }
} else if (mIsHEVC) {
uint32_t type;
const void *data;