mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 04:30:23 +00:00
Don't overflow GCTable
Summary: Bug found with AFL fuzz. Reviewers: rafael, dexonsmith Subscribers: llvm-commits Differential Revision: http://reviews.llvm.org/D9361 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@236200 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
36a398fe70
commit
deedba2a36
@ -2992,7 +2992,7 @@ std::error_code BitcodeReader::ParseModule(bool Resume,
|
||||
// FIXME: Change to an error if non-default in 4.0.
|
||||
Func->setVisibility(GetDecodedVisibility(Record[7]));
|
||||
if (Record.size() > 8 && Record[8]) {
|
||||
if (Record[8]-1 > GCTable.size())
|
||||
if (Record[8]-1 >= GCTable.size())
|
||||
return Error("Invalid ID");
|
||||
Func->setGC(GCTable[Record[8]-1].c_str());
|
||||
}
|
||||
|
BIN
test/Bitcode/Inputs/invalid-GCTable-overflow.bc
Normal file
BIN
test/Bitcode/Inputs/invalid-GCTable-overflow.bc
Normal file
Binary file not shown.
@ -122,3 +122,8 @@ RUN: not llvm-dis -disable-output %p/Inputs/invalid-load-pointer-type.bc 2>&1 |
|
||||
RUN: FileCheck --check-prefix=LOAD-BAD-TYPE %s
|
||||
|
||||
LOAD-BAD-TYPE: Load operand is not a pointer type
|
||||
|
||||
RUN: not llvm-dis -disable-output %p/Inputs/invalid-GCTable-overflow.bc 2>&1 | \
|
||||
RUN: FileCheck --check-prefix=GCTABLE-OFLOW %s
|
||||
|
||||
GCTABLE-OFLOW: Invalid ID
|
||||
|
Loading…
Reference in New Issue
Block a user