diff options
author | Filipe Cabecinhas <me@filcab.net> | 2015-05-26 23:00:56 +0000 |
---|---|---|
committer | Filipe Cabecinhas <me@filcab.net> | 2015-05-26 23:00:56 +0000 |
commit | 0eb8a59a679567334fd160d11ae4d6173ecbac0f (patch) | |
tree | 490fa143f0112019c2a714a901b19377fae53c37 /llvm/lib/Bitcode | |
parent | ee8f99407749fb63dcf4f16bd9572ecca5de9a26 (diff) | |
download | bcm5719-llvm-0eb8a59a679567334fd160d11ae4d6173ecbac0f.tar.gz bcm5719-llvm-0eb8a59a679567334fd160d11ae4d6173ecbac0f.zip |
[BitcodeReader] Sanity check on Comdat ID
Shouldn't be an assert, since user input can trigger it.
Bug found with AFL fuzz.
llvm-svn: 238261
Diffstat (limited to 'llvm/lib/Bitcode')
-rw-r--r-- | llvm/lib/Bitcode/Reader/BitcodeReader.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp b/llvm/lib/Bitcode/Reader/BitcodeReader.cpp index 6eef594eaf1..3f21bb9fbac 100644 --- a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp +++ b/llvm/lib/Bitcode/Reader/BitcodeReader.cpp @@ -2956,7 +2956,8 @@ std::error_code BitcodeReader::ParseModule(bool Resume, if (Record.size() > 11) { if (unsigned ComdatID = Record[11]) { - assert(ComdatID <= ComdatList.size()); + if (ComdatID > ComdatList.size()) + return Error("Invalid global variable comdat ID"); NewGV->setComdat(ComdatList[ComdatID - 1]); } } else if (hasImplicitComdat(RawLinkage)) { @@ -3020,7 +3021,8 @@ std::error_code BitcodeReader::ParseModule(bool Resume, if (Record.size() > 12) { if (unsigned ComdatID = Record[12]) { - assert(ComdatID <= ComdatList.size()); + if (ComdatID > ComdatList.size()) + return Error("Invalid function comdat ID"); Func->setComdat(ComdatList[ComdatID - 1]); } } else if (hasImplicitComdat(RawLinkage)) { |