forked from OSchip/llvm-project
SPARC: Register null target streamer
Fixes null dereference in emitFunctionBodyStart for 64-bit
This commit is contained in:
parent
1179bdf300
commit
48732d3541
|
@ -84,6 +84,10 @@ static MCTargetStreamer *createTargetAsmStreamer(MCStreamer &S,
|
||||||
return new SparcTargetAsmStreamer(S, OS);
|
return new SparcTargetAsmStreamer(S, OS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static MCTargetStreamer *createNullTargetStreamer(MCStreamer &S) {
|
||||||
|
return new SparcTargetStreamer(S);
|
||||||
|
}
|
||||||
|
|
||||||
static MCInstPrinter *createSparcMCInstPrinter(const Triple &T,
|
static MCInstPrinter *createSparcMCInstPrinter(const Triple &T,
|
||||||
unsigned SyntaxVariant,
|
unsigned SyntaxVariant,
|
||||||
const MCAsmInfo &MAI,
|
const MCAsmInfo &MAI,
|
||||||
|
@ -122,6 +126,9 @@ extern "C" LLVM_EXTERNAL_VISIBILITY void LLVMInitializeSparcTargetMC() {
|
||||||
// Register the asm streamer.
|
// Register the asm streamer.
|
||||||
TargetRegistry::RegisterAsmTargetStreamer(*T, createTargetAsmStreamer);
|
TargetRegistry::RegisterAsmTargetStreamer(*T, createTargetAsmStreamer);
|
||||||
|
|
||||||
|
// Register the null streamer.
|
||||||
|
TargetRegistry::RegisterNullTargetStreamer(*T, createNullTargetStreamer);
|
||||||
|
|
||||||
// Register the MCInstPrinter
|
// Register the MCInstPrinter
|
||||||
TargetRegistry::RegisterMCInstPrinter(*T, createSparcMCInstPrinter);
|
TargetRegistry::RegisterMCInstPrinter(*T, createSparcMCInstPrinter);
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,9 +22,9 @@ class SparcTargetStreamer : public MCTargetStreamer {
|
||||||
public:
|
public:
|
||||||
SparcTargetStreamer(MCStreamer &S);
|
SparcTargetStreamer(MCStreamer &S);
|
||||||
/// Emit ".register <reg>, #ignore".
|
/// Emit ".register <reg>, #ignore".
|
||||||
virtual void emitSparcRegisterIgnore(unsigned reg) = 0;
|
virtual void emitSparcRegisterIgnore(unsigned reg){};
|
||||||
/// Emit ".register <reg>, #scratch".
|
/// Emit ".register <reg>, #scratch".
|
||||||
virtual void emitSparcRegisterScratch(unsigned reg) = 0;
|
virtual void emitSparcRegisterScratch(unsigned reg){};
|
||||||
};
|
};
|
||||||
|
|
||||||
// This part is for ascii assembly output
|
// This part is for ascii assembly output
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
; RUN: llc < %s -march=sparcv9 -mattr=+popc -disable-sparc-delay-filler -disable-sparc-leaf-proc | FileCheck %s
|
; RUN: llc < %s -march=sparcv9 -mattr=+popc -disable-sparc-delay-filler -disable-sparc-leaf-proc | FileCheck %s
|
||||||
; RUN: llc < %s -march=sparcv9 -mattr=+popc | FileCheck %s -check-prefix=OPT
|
; RUN: llc < %s -march=sparcv9 -mattr=+popc | FileCheck %s -check-prefix=OPT
|
||||||
|
; RUN: llc %s -march=sparcv9 -mattr=+popc -filetype=null
|
||||||
|
|
||||||
; CHECK-LABEL: ret2:
|
; CHECK-LABEL: ret2:
|
||||||
; CHECK: mov %i1, %i0
|
; CHECK: mov %i1, %i0
|
||||||
|
|
Loading…
Reference in New Issue