summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWei Jia <wjia@google.com>2014-12-04 15:26:54 +0000
committerAndroid Git Automerger <android-git-automerger@android.com>2014-12-04 15:26:54 +0000
commit848b4c676c3295508b74f85947fc5243ce9466f4 (patch)
tree050dac9b8386db6b656f2153b328c663195caf42
parent94d9177849bb68434d3839a9b0886e09489de7f2 (diff)
parent814cbb4e33396fce559475270d6f6c0bd7c43fc5 (diff)
downloadframeworks_av-848b4c676c3295508b74f85947fc5243ce9466f4.zip
frameworks_av-848b4c676c3295508b74f85947fc5243ce9466f4.tar.gz
frameworks_av-848b4c676c3295508b74f85947fc5243ce9466f4.tar.bz2
am 814cbb4e: Merge "ESQueue: add frame length checking in validation of ADTS header." into lmp-mr1-dev
* commit '814cbb4e33396fce559475270d6f6c0bd7c43fc5': ESQueue: add frame length checking in validation of ADTS header.
-rw-r--r--media/libstagefright/mpeg2ts/ESQueue.cpp23
1 files changed, 19 insertions, 4 deletions
diff --git a/media/libstagefright/mpeg2ts/ESQueue.cpp b/media/libstagefright/mpeg2ts/ESQueue.cpp
index ef1cd3d..db5d23e 100644
--- a/media/libstagefright/mpeg2ts/ESQueue.cpp
+++ b/media/libstagefright/mpeg2ts/ESQueue.cpp
@@ -173,8 +173,9 @@ static bool IsSeeminglyValidAC3Header(const uint8_t *ptr, size_t size) {
return parseAC3SyncFrame(ptr, size, NULL) > 0;
}
-static bool IsSeeminglyValidADTSHeader(const uint8_t *ptr, size_t size) {
- if (size < 3) {
+static bool IsSeeminglyValidADTSHeader(
+ const uint8_t *ptr, size_t size, size_t *frameLength) {
+ if (size < 7) {
// Not enough data to verify header.
return false;
}
@@ -197,6 +198,13 @@ static bool IsSeeminglyValidADTSHeader(const uint8_t *ptr, size_t size) {
return false;
}
+ size_t frameLengthInHeader =
+ ((ptr[3] & 3) << 11) + (ptr[4] << 3) + ((ptr[5] >> 5) & 7);
+ if (frameLengthInHeader > size) {
+ return false;
+ }
+
+ *frameLength = frameLengthInHeader;
return true;
}
@@ -318,8 +326,10 @@ status_t ElementaryStreamQueue::appendData(
}
#else
ssize_t startOffset = -1;
+ size_t frameLength;
for (size_t i = 0; i < size; ++i) {
- if (IsSeeminglyValidADTSHeader(&ptr[i], size - i)) {
+ if (IsSeeminglyValidADTSHeader(
+ &ptr[i], size - i, &frameLength)) {
startOffset = i;
break;
}
@@ -335,8 +345,13 @@ status_t ElementaryStreamQueue::appendData(
startOffset);
}
+ if (frameLength != size - startOffset) {
+ ALOGW("got ADTS AAC frame length %zd instead of %zd",
+ frameLength, size - startOffset);
+ }
+
data = &ptr[startOffset];
- size -= startOffset;
+ size = frameLength;
#endif
break;
}