mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-24 08:33:39 +00:00
Using Inst->setMetadata(..., NULL) should be safe to remove metadata even when
there is non of that type to remove. This fixes a crasher in the particular case where the instruction has metadata but no metadata storage in the context (this is only possible if the instruction has !dbg but no other metadata info). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@147285 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
125ef76934
commit
da32cc6176
@ -470,9 +470,11 @@ void Instruction::setMetadata(unsigned KindID, MDNode *Node) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Otherwise, we're removing metadata from an instruction.
|
// Otherwise, we're removing metadata from an instruction.
|
||||||
assert(hasMetadataHashEntry() &&
|
assert((hasMetadataHashEntry() ==
|
||||||
getContext().pImpl->MetadataStore.count(this) &&
|
getContext().pImpl->MetadataStore.count(this)) &&
|
||||||
"HasMetadata bit out of date!");
|
"HasMetadata bit out of date!");
|
||||||
|
if (!hasMetadataHashEntry())
|
||||||
|
return; // Nothing to remove!
|
||||||
LLVMContextImpl::MDMapTy &Info = getContext().pImpl->MetadataStore[this];
|
LLVMContextImpl::MDMapTy &Info = getContext().pImpl->MetadataStore[this];
|
||||||
|
|
||||||
// Common case is removing the only entry.
|
// Common case is removing the only entry.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user