using namespace llvm;
using namespace llvm::dwarf;
-const char *const llvm::x86_asm_table[] = {
+static const char *const x86_asm_table[] = {
"{si}", "S",
"{di}", "D",
"{ax}", "a",
"{cc}", "cc",
0,0};
-X86DarwinTargetAsmInfo::X86DarwinTargetAsmInfo(const X86TargetMachine &TM):
- X86TargetAsmInfo<DarwinTargetAsmInfo>(TM) {
+X86DarwinTargetAsmInfo::X86DarwinTargetAsmInfo(const X86TargetMachine &TM) {
+ AsmTransCBE = x86_asm_table;
+ AssemblerDialect = TM.getSubtarget<X86Subtarget>().getAsmFlavor();
+
const X86Subtarget *Subtarget = &TM.getSubtarget<X86Subtarget>();
bool is64Bit = Subtarget->is64Bit();
AbsoluteEHSectionOffsets = false;
}
-X86ELFTargetAsmInfo::X86ELFTargetAsmInfo(const X86TargetMachine &TM) :
- X86TargetAsmInfo<TargetAsmInfo>(TM) {
+X86ELFTargetAsmInfo::X86ELFTargetAsmInfo(const X86TargetMachine &TM) {
+ AsmTransCBE = x86_asm_table;
+ AssemblerDialect = TM.getSubtarget<X86Subtarget>().getAsmFlavor();
PrivateGlobalPrefix = ".L";
WeakRefDirective = "\t.weak\t";
NonexecutableStackDirective = "\t.section\t.note.GNU-stack,\"\",@progbits";
}
+X86COFFTargetAsmInfo::X86COFFTargetAsmInfo(const X86TargetMachine &TM) {
+ AsmTransCBE = x86_asm_table;
+ AssemblerDialect = TM.getSubtarget<X86Subtarget>().getAsmFlavor();
+
+}
+
+
+X86WinTargetAsmInfo::X86WinTargetAsmInfo(const X86TargetMachine &TM) {
+ AsmTransCBE = x86_asm_table;
+ AssemblerDialect = TM.getSubtarget<X86Subtarget>().getAsmFlavor();
-X86WinTargetAsmInfo::X86WinTargetAsmInfo(const X86TargetMachine &TM):
- X86TargetAsmInfo<TargetAsmInfo>(TM) {
GlobalPrefix = "_";
CommentString = ";";
AlignmentIsInBytes = true;
}
-
-// Instantiate default implementation.
-TEMPLATE_INSTANTIATION(class X86TargetAsmInfo<TargetAsmInfo>);
namespace llvm {
- extern const char *const x86_asm_table[];
-
- template <class BaseTAI>
- struct X86TargetAsmInfo : public BaseTAI {
- explicit X86TargetAsmInfo(const TargetMachine &TM) {
- BaseTAI::AsmTransCBE = x86_asm_table;
- BaseTAI::AssemblerDialect =TM.getSubtarget<X86Subtarget>().getAsmFlavor();
- }
- };
-
- EXTERN_TEMPLATE_INSTANTIATION(class X86TargetAsmInfo<TargetAsmInfo>);
-
- struct X86DarwinTargetAsmInfo : public X86TargetAsmInfo<DarwinTargetAsmInfo> {
+ struct X86DarwinTargetAsmInfo : public DarwinTargetAsmInfo {
explicit X86DarwinTargetAsmInfo(const X86TargetMachine &TM);
};
- struct X86ELFTargetAsmInfo : public X86TargetAsmInfo<TargetAsmInfo> {
+ struct X86ELFTargetAsmInfo : public TargetAsmInfo {
explicit X86ELFTargetAsmInfo(const X86TargetMachine &TM);
};
- typedef X86TargetAsmInfo<COFFTargetAsmInfo> X86COFFTargetAsmInfo;
+ struct X86COFFTargetAsmInfo : public TargetAsmInfo {
+ explicit X86COFFTargetAsmInfo(const X86TargetMachine &TM);
+ };
- struct X86WinTargetAsmInfo : public X86TargetAsmInfo<TargetAsmInfo> {
+ struct X86WinTargetAsmInfo : public TargetAsmInfo {
explicit X86WinTargetAsmInfo(const X86TargetMachine &TM);
};