e3348a90d458c98749c8fd87dfbbcc6304facad9
[oota-llvm.git] / lib / Target / ARM / ARMTargetAsmInfo.cpp
1 //===-- ARMTargetAsmInfo.cpp - ARM asm properties ---------------*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This file contains the declarations of the ARMTargetAsmInfo properties.
11 //
12 //===----------------------------------------------------------------------===//
13
14 #include "ARMTargetAsmInfo.h"
15 using namespace llvm;
16
17 const char *const llvm::arm_asm_table[] = {
18   "{r0}", "r0",
19   "{r1}", "r1",
20   "{r2}", "r2",
21   "{r3}", "r3",
22   "{r4}", "r4",
23   "{r5}", "r5",
24   "{r6}", "r6",
25   "{r7}", "r7",
26   "{r8}", "r8",
27   "{r9}", "r9",
28   "{r10}", "r10",
29   "{r11}", "r11",
30   "{r12}", "r12",
31   "{r13}", "r13",
32   "{r14}", "r14",
33   "{lr}", "lr",
34   "{sp}", "sp",
35   "{ip}", "ip",
36   "{fp}", "fp",
37   "{sl}", "sl",
38   "{memory}", "memory",
39   "{cc}", "cc",
40   0,0
41 };
42
43 ARMDarwinTargetAsmInfo::ARMDarwinTargetAsmInfo() {
44   ZeroDirective = "\t.space\t";
45   ZeroFillDirective = "\t.zerofill\t";  // Uses .zerofill
46   SetDirective = "\t.set\t";
47   ProtectedDirective = NULL;
48   HasDotTypeDotSizeDirective = false;
49   SupportsDebugInformation = true;
50 }
51
52 ARMELFTargetAsmInfo::ARMELFTargetAsmInfo() {
53   NeedsSet = false;
54   HasLEB128 = true;
55   AbsoluteDebugSectionOffsets = true;
56   PrivateGlobalPrefix = ".L";
57   WeakRefDirective = "\t.weak\t";
58   SetDirective = "\t.set\t";
59   DwarfRequiresFrameSection = false;
60
61   SupportsDebugInformation = true;
62 }
63
64 // Instantiate default implementation.
65 TEMPLATE_INSTANTIATION(class ARMTargetAsmInfo<DarwinTargetAsmInfo>);
66 TEMPLATE_INSTANTIATION(class ARMTargetAsmInfo<TargetAsmInfo>);