From 32af5421945d3a6739048a679604176a9b860a6e Mon Sep 17 00:00:00 2001 From: Filipe Cabecinhas Date: Tue, 19 May 2015 01:21:06 +0000 Subject: [BitcodeReader] Error out if we read an invalid function argument type Bug found with AFL fuzz. llvm-svn: 237650 --- llvm/lib/Bitcode/Reader/BitcodeReader.cpp | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'llvm/lib/Bitcode/Reader/BitcodeReader.cpp') diff --git a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp b/llvm/lib/Bitcode/Reader/BitcodeReader.cpp index 70b6810..bba2917 100644 --- a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp +++ b/llvm/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; } -- cgit v1.1