blob: 806bcd5614aa4a4fc2dd18620f2d41505c910ea3 [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;
Anton Korobeynikovf700e682008-07-09 13:20:48 +000051 };
52
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000053 struct X86ELFTargetAsmInfo : public X86TargetAsmInfo<ELFTargetAsmInfo> {
Anton Korobeynikovf700e682008-07-09 13:20:48 +000054 explicit X86ELFTargetAsmInfo(const X86TargetMachine &TM);
Anton Korobeynikovcd2a4e52008-07-09 13:21:08 +000055 virtual unsigned PreferredEHDataFormat(DwarfEncoding::Target Reason,
56 bool Global) const;
Anton Korobeynikovf700e682008-07-09 13:20:48 +000057 };
58
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000059 struct X86COFFTargetAsmInfo : public X86GenericTargetAsmInfo {
Anton Korobeynikovf700e682008-07-09 13:20:48 +000060 explicit X86COFFTargetAsmInfo(const X86TargetMachine &TM);
Anton Korobeynikovcd2a4e52008-07-09 13:21:08 +000061 virtual unsigned PreferredEHDataFormat(DwarfEncoding::Target Reason,
62 bool Global) const;
Anton Korobeynikov52069b52008-07-09 13:21:29 +000063 virtual std::string UniqueSectionForGlobal(const GlobalValue* GV,
64 SectionKind::Kind kind) const;
asl27ffd262008-08-16 12:57:07 +000065 virtual std::string printSectionFlags(unsigned flags) const;
Anton Korobeynikovf700e682008-07-09 13:20:48 +000066 };
67
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000068 struct X86WinTargetAsmInfo : public X86GenericTargetAsmInfo {
Anton Korobeynikovf700e682008-07-09 13:20:48 +000069 explicit X86WinTargetAsmInfo(const X86TargetMachine &TM);
Dan Gohmanf17a25c2007-07-18 16:29:46 +000070 };
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000071
Dan Gohmanf17a25c2007-07-18 16:29:46 +000072} // namespace llvm
73
74#endif
Anton Korobeynikov3829e8a2008-09-25 21:00:33 +000075