mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-04 10:30:01 +00:00
Remove a call to TargetMachine::getSubtarget from the inline
asm support in the asm printer. If we can get a subtarget from the machine function then we should do so, otherwise we can go ahead and create a default one since we're at the module level. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@229916 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
55d7decf27
commit
f6456a560c
@ -92,7 +92,17 @@ void AsmPrinter::EmitInlineAsm(StringRef Str, const MDNode *LocMDNode,
|
||||
!OutStreamer.isIntegratedAssemblerRequired()) {
|
||||
emitInlineAsmStart();
|
||||
OutStreamer.EmitRawText(Str);
|
||||
emitInlineAsmEnd(TM.getSubtarget<MCSubtargetInfo>(), nullptr);
|
||||
// If we have a machine function then grab the MCSubtarget off of that,
|
||||
// otherwise we're at the module level and want to construct one from
|
||||
// the default CPU and target triple.
|
||||
if (MF) {
|
||||
emitInlineAsmEnd(MF->getSubtarget<MCSubtargetInfo>(), nullptr);
|
||||
} else {
|
||||
std::unique_ptr<MCSubtargetInfo> STI(TM.getTarget().createMCSubtargetInfo(
|
||||
TM.getTargetTriple(), TM.getTargetCPU(),
|
||||
TM.getTargetFeatureString()));
|
||||
emitInlineAsmEnd(*STI, nullptr);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user