Merge "Fix DynamicRefTable::load security bug" into oc-mr1-dev am: 2b6805fedc

am: 5ae85666ac

Change-Id: I64521a290482adb5ade95b641ce9c0c27031a814
This commit is contained in:
Ryan Mitchell
2018-06-06 16:09:35 -07:00
committed by android-build-merger

View File

@@ -6824,8 +6824,16 @@ status_t ResTable::parsePackage(const ResTable_package* const pkg,
}
} else if (ctype == RES_TABLE_LIBRARY_TYPE) {
if (group->dynamicRefTable.entries().size() == 0) {
status_t err = group->dynamicRefTable.load((const ResTable_lib_header*) chunk);
const ResTable_lib_header* lib = (const ResTable_lib_header*) chunk;
status_t err = validate_chunk(&lib->header, sizeof(*lib),
endPos, "ResTable_lib_header");
if (err != NO_ERROR) {
return (mError=err);
}
err = group->dynamicRefTable.load(lib);
if (err != NO_ERROR) {
return (mError=err);
}