Browse Source

We were not writing bitcode for function-local metadata whose operands have been erased (making it not have any more function-local operands)

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@94842 91177308-0d34-0410-b5e6-96231b3b80d8
Victor Hernandez 15 years ago
parent
commit
2c482f4895
1 changed files with 2 additions and 2 deletions
  1. 2 2
      lib/Bitcode/Writer/BitcodeWriter.cpp

+ 2 - 2
lib/Bitcode/Writer/BitcodeWriter.cpp

@@ -498,7 +498,7 @@ static void WriteModuleMetadata(const ValueEnumerator &VE,
   for (unsigned i = 0, e = Vals.size(); i != e; ++i) {
   for (unsigned i = 0, e = Vals.size(); i != e; ++i) {
 
 
     if (const MDNode *N = dyn_cast<MDNode>(Vals[i].first)) {
     if (const MDNode *N = dyn_cast<MDNode>(Vals[i].first)) {
-      if (!N->isFunctionLocal()) {
+      if (!N->isFunctionLocal() || !N->getFunction()) {
         if (!StartedMetadataBlock) {
         if (!StartedMetadataBlock) {
           Stream.EnterSubblock(bitc::METADATA_BLOCK_ID, 3);
           Stream.EnterSubblock(bitc::METADATA_BLOCK_ID, 3);
           StartedMetadataBlock = true;
           StartedMetadataBlock = true;
@@ -562,7 +562,7 @@ static void WriteFunctionLocalMetadata(const Function &F,
   
   
   for (unsigned i = 0, e = Vals.size(); i != e; ++i)
   for (unsigned i = 0, e = Vals.size(); i != e; ++i)
     if (const MDNode *N = dyn_cast<MDNode>(Vals[i].first))
     if (const MDNode *N = dyn_cast<MDNode>(Vals[i].first))
-      if (N->getFunction() == &F) {
+      if (N->isFunctionLocal() && N->getFunction() == &F) {
         if (!StartedMetadataBlock) {
         if (!StartedMetadataBlock) {
           Stream.EnterSubblock(bitc::METADATA_BLOCK_ID, 3);
           Stream.EnterSubblock(bitc::METADATA_BLOCK_ID, 3);
           StartedMetadataBlock = true;
           StartedMetadataBlock = true;