summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Bitcode
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2010-01-05 21:47:32 +0000
committerDevang Patel <dpatel@apple.com>2010-01-05 21:47:32 +0000
commit6edcd3994c501fb4ecdfc5bce1ee284c3b4c424b (patch)
tree6bde329213db03acd550379a75187e1a1b413eaf /llvm/lib/Bitcode
parentf312cfa2501b3d8ddbd8393fa3dcefae0987ded0 (diff)
downloadbcm5719-llvm-6edcd3994c501fb4ecdfc5bce1ee284c3b4c424b.tar.gz
bcm5719-llvm-6edcd3994c501fb4ecdfc5bce1ee284c3b4c424b.zip
Allow null to be an element of NamedMDNode. e.g. !llvm.stuff = !{!0, !1, null}
llvm-svn: 92783
Diffstat (limited to 'llvm/lib/Bitcode')
-rw-r--r--llvm/lib/Bitcode/Reader/BitcodeReader.cpp10
-rw-r--r--llvm/lib/Bitcode/Writer/BitcodeWriter.cpp2
-rw-r--r--llvm/lib/Bitcode/Writer/ValueEnumerator.cpp3
3 files changed, 10 insertions, 5 deletions
diff --git a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp b/llvm/lib/Bitcode/Reader/BitcodeReader.cpp
index c8097a09996..33da5e4d611 100644
--- a/llvm/lib/Bitcode/Reader/BitcodeReader.cpp
+++ b/llvm/lib/Bitcode/Reader/BitcodeReader.cpp
@@ -789,9 +789,13 @@ bool BitcodeReader::ParseMetadata() {
unsigned Size = Record.size();
SmallVector<MDNode *, 8> Elts;
for (unsigned i = 0; i != Size; ++i) {
- Value *MD = MDValueList.getValueFwdRef(Record[i]);
- if (MDNode *B = dyn_cast_or_null<MDNode>(MD))
- Elts.push_back(B);
+ if (Record[i] == ~0U)
+ Elts.push_back(NULL);
+ else {
+ Value *MD = MDValueList.getValueFwdRef(Record[i]);
+ if (MDNode *B = dyn_cast_or_null<MDNode>(MD))
+ Elts.push_back(B);
+ }
}
Value *V = NamedMDNode::Create(Context, Name.str(), Elts.data(),
Elts.size(), TheModule);
diff --git a/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp b/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp
index c78a30e8690..ce9036bd06e 100644
--- a/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp
+++ b/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp
@@ -540,7 +540,7 @@ static void WriteModuleMetadata(const ValueEnumerator &VE,
if (NMD->getOperand(i))
Record.push_back(VE.getValueID(NMD->getOperand(i)));
else
- Record.push_back(0);
+ Record.push_back(~0U);
}
Stream.EmitRecord(bitc::METADATA_NAMED_NODE, Record, 0);
Record.clear();
diff --git a/llvm/lib/Bitcode/Writer/ValueEnumerator.cpp b/llvm/lib/Bitcode/Writer/ValueEnumerator.cpp
index 861de84e34b..c409c2066d1 100644
--- a/llvm/lib/Bitcode/Writer/ValueEnumerator.cpp
+++ b/llvm/lib/Bitcode/Writer/ValueEnumerator.cpp
@@ -223,7 +223,8 @@ void ValueEnumerator::EnumerateMetadata(const MetadataBase *MD) {
if (const NamedMDNode *N = dyn_cast<NamedMDNode>(MD)) {
for (unsigned i = 0, e = N->getNumOperands(); i != e; ++i)
- EnumerateValue(N->getOperand(i));
+ if (MDNode *E = N->getOperand(i))
+ EnumerateValue(E);
MDValues.push_back(std::make_pair(MD, 1U));
MDValueMap[MD] = Values.size();
return;
OpenPOWER on IntegriCloud