diff options
author | Marco Nelissen <marcone@google.com> | 2017-05-12 21:34:44 +0000 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2017-05-12 21:34:44 +0000 |
commit | cd0a4ac6098051db644c19da430871463c3a79ef (patch) | |
tree | e7c01392eb748209420cdc448208aade16275911 | |
parent | 7eaccb36d5e27392a862f9c2dfd0db2d24d5b726 (diff) | |
parent | e090def747c0e3cf0ac2137e2f4084f677743c73 (diff) | |
download | sonivox-cd0a4ac6098051db644c19da430871463c3a79ef.tar.gz |
Merge "Fix infinite recursion" into klp-dev am: 45712137ea am: e49d1304e7 am: 6483a95ccf am: bb6bfa8f5a
am: e090def747
Change-Id: I03a6503445865464b0452cc94955720ded61b36f
-rw-r--r-- | arm-wt-22k/lib_src/eas_xmf.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/arm-wt-22k/lib_src/eas_xmf.c b/arm-wt-22k/lib_src/eas_xmf.c index 830b6e5..169eb7e 100644 --- a/arm-wt-22k/lib_src/eas_xmf.c +++ b/arm-wt-22k/lib_src/eas_xmf.c @@ -27,6 +27,8 @@ *---------------------------------------------------------------------------- */ +#include <log/log.h> + #include "eas_data.h" #include "eas_miditypes.h" #include "eas_parser.h" @@ -649,6 +651,11 @@ static EAS_RESULT XMF_ReadNode (EAS_HW_DATA_HANDLE hwInstData, S_XMF_DATA *pXMFD for ( ; numItems > 0; numItems--) { /* process this item */ + if (offset <= nodeOffset) { + ALOGE("b/36725407: parser did not advance"); + return EAS_ERROR_FILE_FORMAT; + } + if ((result = XMF_ReadNode(hwInstData, pXMFData, offset, &length)) != EAS_SUCCESS) return result; |