blob: d971680976796b4f5af910ed09ae808c40dcca59 [file] [log] [blame]
Dan Gohmanf17a25c2007-07-18 16:29:46 +00001//=====-- X86TargetAsmInfo.h - X86 asm properties -------------*- C++ -*--====//
2//
3// The LLVM Compiler Infrastructure
4//
Chris Lattner081ce942007-12-29 20:36:04 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Dan Gohmanf17a25c2007-07-18 16:29:46 +00007//
8//===----------------------------------------------------------------------===//
9//
10// This file contains the declaration of the X86TargetAsmInfo class.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef X86TARGETASMINFO_H
15#define X86TARGETASMINFO_H
16
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000017#include "X86TargetMachine.h"
Dan Gohmanf17a25c2007-07-18 16:29:46 +000018#include "llvm/Target/TargetAsmInfo.h"
asl631323b2008-07-19 13:15:21 +000019#include "llvm/Target/ELFTargetAsmInfo.h"
20#include "llvm/Target/DarwinTargetAsmInfo.h"
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000021#include "llvm/Support/Compiler.h"
Dan Gohmanf17a25c2007-07-18 16:29:46 +000022
23namespace llvm {
24
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000025 extern const char *const x86_asm_table[];
Dan Gohmanf17a25c2007-07-18 16:29:46 +000026
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000027 template <class BaseTAI>
28 struct X86TargetAsmInfo : public BaseTAI {
Chris Lattnerecb3eaf2009-07-20 17:59:32 +000029 explicit X86TargetAsmInfo(const X86TargetMachine &TM) : BaseTAI(TM) {
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000030 BaseTAI::AsmTransCBE = x86_asm_table;
Chris Lattnerecb3eaf2009-07-20 17:59:32 +000031 BaseTAI::AssemblerDialect =TM.getSubtarget<X86Subtarget>().getAsmFlavor();
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000032 }
Anton Korobeynikovf700e682008-07-09 13:20:48 +000033 };
34
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000035 typedef X86TargetAsmInfo<TargetAsmInfo> X86GenericTargetAsmInfo;
36
37 EXTERN_TEMPLATE_INSTANTIATION(class X86TargetAsmInfo<TargetAsmInfo>);
38
39 struct X86DarwinTargetAsmInfo : public X86TargetAsmInfo<DarwinTargetAsmInfo> {
Anton Korobeynikovf700e682008-07-09 13:20:48 +000040 explicit X86DarwinTargetAsmInfo(const X86TargetMachine &TM);
Anton Korobeynikovcd2a4e52008-07-09 13:21:08 +000041 virtual unsigned PreferredEHDataFormat(DwarfEncoding::Target Reason,
42 bool Global) const;
Rafael Espindola1a931842008-12-19 10:55:56 +000043 virtual const char *getEHGlobalPrefix() const;
Anton Korobeynikovf700e682008-07-09 13:20:48 +000044 };
45
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000046 struct X86ELFTargetAsmInfo : public X86TargetAsmInfo<ELFTargetAsmInfo> {
Anton Korobeynikovf700e682008-07-09 13:20:48 +000047 explicit X86ELFTargetAsmInfo(const X86TargetMachine &TM);
Anton Korobeynikovcd2a4e52008-07-09 13:21:08 +000048 virtual unsigned PreferredEHDataFormat(DwarfEncoding::Target Reason,
49 bool Global) const;
Anton Korobeynikovf700e682008-07-09 13:20:48 +000050 };
51
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000052 struct X86COFFTargetAsmInfo : public X86GenericTargetAsmInfo {
Anton Korobeynikovf700e682008-07-09 13:20:48 +000053 explicit X86COFFTargetAsmInfo(const X86TargetMachine &TM);
Anton Korobeynikovcd2a4e52008-07-09 13:21:08 +000054 virtual unsigned PreferredEHDataFormat(DwarfEncoding::Target Reason,
55 bool Global) const;
Chris Lattnerb8245582009-07-24 04:49:34 +000056 virtual const char *
Chris Lattnercc195212009-07-25 23:21:55 +000057 getSectionPrefixForUniqueGlobal(SectionKind kind) const;
Chris Lattner94d8a762009-07-26 07:33:58 +000058
Chris Lattnerd8310522009-07-27 05:32:16 +000059 virtual void getSectionFlagsAsString(SectionKind Kind,
60 SmallVectorImpl<char> &Str) const;
Anton Korobeynikovf700e682008-07-09 13:20:48 +000061 };
62
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000063 struct X86WinTargetAsmInfo : public X86GenericTargetAsmInfo {
Anton Korobeynikovf700e682008-07-09 13:20:48 +000064 explicit X86WinTargetAsmInfo(const X86TargetMachine &TM);
Dan Gohmanf17a25c2007-07-18 16:29:46 +000065 };
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000066
Dan Gohmanf17a25c2007-07-18 16:29:46 +000067} // namespace llvm
68
69#endif