mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-10 02:36:06 +00:00
implicit defs get added to the end of machine instrs sometimes. Scan the whole instruction for the metadata operand instead of assuming it will be at the end of the instruction.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@100792 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b57b6f1575
commit
d0024fec25
@ -127,10 +127,15 @@ void AsmPrinter::EmitInlineAsm(const MachineInstr *MI) const {
|
||||
// Get the !srcloc metadata node if we have it, and decode the loc cookie from
|
||||
// it.
|
||||
unsigned LocCookie = 0;
|
||||
if (const MDNode *SrcLoc = MI->getOperand(NumOperands-1).getMetadata()) {
|
||||
if (SrcLoc->getNumOperands() != 0)
|
||||
if (const ConstantInt *CI = dyn_cast<ConstantInt>(SrcLoc->getOperand(0)))
|
||||
LocCookie = CI->getZExtValue();
|
||||
for (unsigned i = MI->getNumOperands(); i != 0; --i) {
|
||||
if (MI->getOperand(i-1).isMetadata())
|
||||
if (const MDNode *SrcLoc = MI->getOperand(i-1).getMetadata())
|
||||
if (SrcLoc->getNumOperands() != 0)
|
||||
if (const ConstantInt *CI =
|
||||
dyn_cast<ConstantInt>(SrcLoc->getOperand(0))) {
|
||||
LocCookie = CI->getZExtValue();
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Emit the inline asm to a temporary string so we can emit it through
|
||||
|
Loading…
x
Reference in New Issue
Block a user