From: Filipe Cabecinhas Date: Tue, 19 May 2015 01:21:06 +0000 (+0000) Subject: [BitcodeReader] Error out if we read an invalid function argument type X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=bf27e11e02798832e4d55ff0e3e0368b06ae8895;p=oota-llvm.git [BitcodeReader] Error out if we read an invalid function argument type Bug found with AFL fuzz. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@237650 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Bitcode/Reader/BitcodeReader.cpp b/lib/Bitcode/Reader/BitcodeReader.cpp index 70b681000a7..bba29172a28 100644 --- a/lib/Bitcode/Reader/BitcodeReader.cpp +++ b/lib/Bitcode/Reader/BitcodeReader.cpp @@ -1402,8 +1402,11 @@ std::error_code BitcodeReader::ParseTypeTableBody() { return Error("Invalid record"); SmallVector ArgTys; for (unsigned i = 2, e = Record.size(); i != e; ++i) { - if (Type *T = getTypeByID(Record[i])) + if (Type *T = getTypeByID(Record[i])) { + if (!FunctionType::isValidArgumentType(T)) + return Error("Invalid function argument type"); ArgTys.push_back(T); + } else break; } diff --git a/test/Bitcode/Inputs/invalid-function-argument-type.bc b/test/Bitcode/Inputs/invalid-function-argument-type.bc new file mode 100644 index 00000000000..b00fb03cd31 Binary files /dev/null and b/test/Bitcode/Inputs/invalid-function-argument-type.bc differ diff --git a/test/Bitcode/invalid.test b/test/Bitcode/invalid.test index c4c635e08d3..7a2dbdcc1b3 100644 --- a/test/Bitcode/invalid.test +++ b/test/Bitcode/invalid.test @@ -152,3 +152,8 @@ RUN: not llvm-dis -disable-output %p/Inputs/invalid-code-len-width.bc 2>&1 | \ RUN: FileCheck --check-prefix=INVALID-CODELENWIDTH %s INVALID-CODELENWIDTH: Malformed block + +RUN: not llvm-dis -disable-output %p/Inputs/invalid-function-argument-type.bc 2>&1 | \ +RUN: FileCheck --check-prefix=INVALID-ARGUMENT-TYPE %s + +INVALID-ARGUMENT-TYPE: Invalid function argument type