blob: f89171d3da713535192da53e8aecde54b6de3530 [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 {
29 explicit X86TargetAsmInfo(const X86TargetMachine &TM):
30 BaseTAI(TM) {
31 const X86Subtarget *Subtarget = &TM.getSubtarget<X86Subtarget>();
32
33 BaseTAI::AsmTransCBE = x86_asm_table;
34 BaseTAI::AssemblerDialect = Subtarget->getAsmFlavor();
35 }
Anton Korobeynikov8bf5d342008-07-09 13:19:08 +000036
Dan Gohmanf17a25c2007-07-18 16:29:46 +000037 virtual bool ExpandInlineAsm(CallInst *CI) const;
Anton Korobeynikov65c0d872008-02-27 23:33:50 +000038
Dan Gohmanf17a25c2007-07-18 16:29:46 +000039 private:
Dan Gohmanf17a25c2007-07-18 16:29:46 +000040 bool LowerToBSwap(CallInst *CI) const;
Anton Korobeynikovf700e682008-07-09 13:20:48 +000041 };
42
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000043 typedef X86TargetAsmInfo<TargetAsmInfo> X86GenericTargetAsmInfo;
44
45 EXTERN_TEMPLATE_INSTANTIATION(class X86TargetAsmInfo<TargetAsmInfo>);
46
47 struct X86DarwinTargetAsmInfo : public X86TargetAsmInfo<DarwinTargetAsmInfo> {
Anton Korobeynikovf700e682008-07-09 13:20:48 +000048 explicit X86DarwinTargetAsmInfo(const X86TargetMachine &TM);
Anton Korobeynikovcd2a4e52008-07-09 13:21:08 +000049 virtual unsigned PreferredEHDataFormat(DwarfEncoding::Target Reason,
50 bool Global) const;
Rafael Espindola1a931842008-12-19 10:55:56 +000051 virtual const char *getEHGlobalPrefix() const;
Anton Korobeynikovf700e682008-07-09 13:20:48 +000052 };
53
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000054 struct X86ELFTargetAsmInfo : public X86TargetAsmInfo<ELFTargetAsmInfo> {
Anton Korobeynikovf700e682008-07-09 13:20:48 +000055 explicit X86ELFTargetAsmInfo(const X86TargetMachine &TM);
Anton Korobeynikovcd2a4e52008-07-09 13:21:08 +000056 virtual unsigned PreferredEHDataFormat(DwarfEncoding::Target Reason,
57 bool Global) const;
Anton Korobeynikovf700e682008-07-09 13:20:48 +000058 };
59
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000060 struct X86COFFTargetAsmInfo : public X86GenericTargetAsmInfo {
Anton Korobeynikovf700e682008-07-09 13:20:48 +000061 explicit X86COFFTargetAsmInfo(const X86TargetMachine &TM);
Anton Korobeynikovcd2a4e52008-07-09 13:21:08 +000062 virtual unsigned PreferredEHDataFormat(DwarfEncoding::Target Reason,
63 bool Global) const;
Anton Korobeynikov52069b52008-07-09 13:21:29 +000064 virtual std::string UniqueSectionForGlobal(const GlobalValue* GV,
65 SectionKind::Kind kind) const;
asl27ffd262008-08-16 12:57:07 +000066 virtual std::string printSectionFlags(unsigned flags) const;
Anton Korobeynikovf700e682008-07-09 13:20:48 +000067 };
68
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000069 struct X86WinTargetAsmInfo : public X86GenericTargetAsmInfo {
Anton Korobeynikovf700e682008-07-09 13:20:48 +000070 explicit X86WinTargetAsmInfo(const X86TargetMachine &TM);
Dan Gohmanf17a25c2007-07-18 16:29:46 +000071 };
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000072
Dan Gohmanf17a25c2007-07-18 16:29:46 +000073} // namespace llvm
74
75#endif