summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorVedant Kumar <vsk@apple.com>2018-09-20 18:59:33 +0000
committerVedant Kumar <vsk@apple.com>2018-09-20 18:59:33 +0000
commit386ad01c7b6d83beb95267116af295471e36d426 (patch)
tree8f3bbf44fccf2a9aa4fe9e3591834c69aeedd77e /llvm
parentcc06a782baa9fcabc5e10b42e23e06d6018cc429 (diff)
downloadbcm5719-llvm-386ad01c7b6d83beb95267116af295471e36d426.tar.gz
bcm5719-llvm-386ad01c7b6d83beb95267116af295471e36d426.zip
[Bitcode] Address backwards compat bug in r342631
r342631 expanded bitc::METADATA_LOCATION by one element. The bitcode metadata loader was changed in a backwards-incompatible way, leading to crashes when disassembling old bitcode: assertion: empty() && "PlaceholderQueue hasn't been flushed before being destroyed" Assertion failed: (empty() && "PlaceholderQueue hasn't been flushed before being destroyed") This commit teaches the metadata loader to assume that the newly-added IsImplicitCode bit is 'false' when not present in old bitcode. I've added a bitcode compat regression test. rdar://44645820 llvm-svn: 342678
Diffstat (limited to 'llvm')
-rw-r--r--llvm/lib/Bitcode/Reader/MetadataLoader.cpp4
-rw-r--r--llvm/test/Bitcode/Inputs/apple-clang-700-O3-g-1.bcbin0 -> 8096 bytes
-rw-r--r--llvm/test/Bitcode/apple-clang-700-compat.test8
3 files changed, 10 insertions, 2 deletions
diff --git a/llvm/lib/Bitcode/Reader/MetadataLoader.cpp b/llvm/lib/Bitcode/Reader/MetadataLoader.cpp
index 1af17f485e1..3fe7d220563 100644
--- a/llvm/lib/Bitcode/Reader/MetadataLoader.cpp
+++ b/llvm/lib/Bitcode/Reader/MetadataLoader.cpp
@@ -1139,7 +1139,7 @@ Error MetadataLoader::MetadataLoaderImpl::parseOneMetadata(
break;
}
case bitc::METADATA_LOCATION: {
- if (Record.size() != 6)
+ if (Record.size() != 5 && Record.size() != 6)
return error("Invalid record");
IsDistinct = Record[0];
@@ -1147,7 +1147,7 @@ Error MetadataLoader::MetadataLoaderImpl::parseOneMetadata(
unsigned Column = Record[2];
Metadata *Scope = getMD(Record[3]);
Metadata *InlinedAt = getMDOrNull(Record[4]);
- bool ImplicitCode = Record[5];
+ bool ImplicitCode = Record.size() == 6 && Record[5];
MetadataList.assignValue(
GET_OR_DISTINCT(DILocation, (Context, Line, Column, Scope, InlinedAt,
ImplicitCode)),
diff --git a/llvm/test/Bitcode/Inputs/apple-clang-700-O3-g-1.bc b/llvm/test/Bitcode/Inputs/apple-clang-700-O3-g-1.bc
new file mode 100644
index 00000000000..01f221d575c
--- /dev/null
+++ b/llvm/test/Bitcode/Inputs/apple-clang-700-O3-g-1.bc
Binary files differ
diff --git a/llvm/test/Bitcode/apple-clang-700-compat.test b/llvm/test/Bitcode/apple-clang-700-compat.test
new file mode 100644
index 00000000000..c7ab2f49687
--- /dev/null
+++ b/llvm/test/Bitcode/apple-clang-700-compat.test
@@ -0,0 +1,8 @@
+; AppleClang-700 uses a debug info version that isn't recognized by llvm.org
+; compilers. However, it does produce valid bitcode which should parse without
+; crashing the metadata loader.
+
+RUN: llvm-dis < %S/Inputs/apple-clang-700-O3-g-1.bc 2>&1 \
+RUN: | FileCheck %s -check-prefix INVALID-VERSION
+
+INVALID-VERSION: warning: ignoring debug info with an invalid version (700000003)
OpenPOWER on IntegriCloud