summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFilipe Cabecinhas <me@filcab.net>2015-04-23 13:38:21 +0000
committerFilipe Cabecinhas <me@filcab.net>2015-04-23 13:38:21 +0000
commit6621cb7478f02fd146eb26d2b0a3adadbc09596e (patch)
tree2a5e0888048a88ececbe862f7a0f50ffbd200f82
parentee48feadfde407206eecce83ce460cccfeeffe10 (diff)
downloadbcm5719-llvm-6621cb7478f02fd146eb26d2b0a3adadbc09596e.tar.gz
bcm5719-llvm-6621cb7478f02fd146eb26d2b0a3adadbc09596e.zip
Be more strict about the operand for the array type in BitcodeReader
Summary: Bug found with AFL fuzz. Reviewers: rafael Subscribers: llvm-commits Differential Revision: http://reviews.llvm.org/D9016 llvm-svn: 235596
-rw-r--r--llvm/lib/Bitcode/Reader/BitstreamReader.cpp3
-rw-r--r--llvm/test/Bitcode/Inputs/invalid-array-type.bcbin0 -> 612 bytes
-rw-r--r--llvm/test/Bitcode/invalid.test5
3 files changed, 8 insertions, 0 deletions
diff --git a/llvm/lib/Bitcode/Reader/BitstreamReader.cpp b/llvm/lib/Bitcode/Reader/BitstreamReader.cpp
index ff37b8e4cfc..2f34532ae93 100644
--- a/llvm/lib/Bitcode/Reader/BitstreamReader.cpp
+++ b/llvm/lib/Bitcode/Reader/BitstreamReader.cpp
@@ -201,6 +201,9 @@ unsigned BitstreamCursor::readRecord(unsigned AbbrevID,
// Get the element encoding.
assert(i+2 == e && "array op not second to last?");
const BitCodeAbbrevOp &EltEnc = Abbv->getOperandInfo(++i);
+ if (EltEnc.getEncoding() == BitCodeAbbrevOp::Array ||
+ EltEnc.getEncoding() == BitCodeAbbrevOp::Blob)
+ report_fatal_error("Array element type can't be an Array or a Blob");
// Read all the elements.
for (; NumElts; --NumElts)
diff --git a/llvm/test/Bitcode/Inputs/invalid-array-type.bc b/llvm/test/Bitcode/Inputs/invalid-array-type.bc
new file mode 100644
index 00000000000..3a4b635dd0e
--- /dev/null
+++ b/llvm/test/Bitcode/Inputs/invalid-array-type.bc
Binary files differ
diff --git a/llvm/test/Bitcode/invalid.test b/llvm/test/Bitcode/invalid.test
index b6c2ed3e8d6..1d8e14230ff 100644
--- a/llvm/test/Bitcode/invalid.test
+++ b/llvm/test/Bitcode/invalid.test
@@ -73,3 +73,8 @@ RUN: not llvm-dis -disable-output %p/Inputs/invalid-abbrev-fixed-size-too-big.bc
RUN: FileCheck --check-prefix=HUGE-ABBREV-OP %s
HUGE-ABBREV-OP: Fixed or VBR abbrev record with size > MaxChunkData
+
+RUN: not llvm-dis -disable-output %p/Inputs/invalid-array-type.bc 2>&1 | \
+RUN: FileCheck --check-prefix=ARRAY-TYPE %s
+
+ARRAY-TYPE: Array element type can't be an Array or a Blob
OpenPOWER on IntegriCloud