blob: 67f0cfa5be88dcb6509e3dd683f795f4157ebc64 [file] [log] [blame]
Dan Gohmanf17a25c2007-07-18 16:29:46 +00001//===-- TargetAsmInfo.cpp - Asm Info ---------------------------------------==//
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 defines target asm properties related what form asm statements
11// should take.
12//
13//===----------------------------------------------------------------------===//
14
15#include "llvm/Target/TargetAsmInfo.h"
Anton Korobeynikov65c0d872008-02-27 23:33:50 +000016#include "llvm/Support/Dwarf.h"
Dan Gohmanf17a25c2007-07-18 16:29:46 +000017#include <cctype>
18#include <cstring>
19
20using namespace llvm;
21
22TargetAsmInfo::TargetAsmInfo() :
23 TextSection("\t.text"),
24 DataSection("\t.data"),
25 BSSSection("\t.bss"),
26 TLSDataSection("\t.section .tdata,\"awT\",@progbits"),
27 TLSBSSSection("\t.section .tbss,\"awT\",@nobits"),
28 ZeroFillDirective(0),
Dan Gohmana65530a2008-05-05 00:28:39 +000029 NonexecutableStackDirective(0),
Dan Gohmanf17a25c2007-07-18 16:29:46 +000030 NeedsSet(false),
31 MaxInstLength(4),
32 PCSymbol("$"),
33 SeparatorChar(';'),
34 CommentString("#"),
35 GlobalPrefix(""),
36 PrivateGlobalPrefix("."),
37 JumpTableSpecialLabelPrefix(0),
38 GlobalVarAddrPrefix(""),
39 GlobalVarAddrSuffix(""),
40 FunctionAddrPrefix(""),
41 FunctionAddrSuffix(""),
Bill Wendlingd1bda4f2007-09-11 08:27:17 +000042 PersonalityPrefix(""),
43 PersonalitySuffix(""),
Bill Wendling2d369922007-09-11 17:20:55 +000044 NeedsIndirectEncoding(false),
Dan Gohmanf17a25c2007-07-18 16:29:46 +000045 InlineAsmStart("#APP"),
46 InlineAsmEnd("#NO_APP"),
47 AssemblerDialect(0),
Dale Johannesen8f03a202008-06-03 18:09:06 +000048 StringConstantPrefix(".str"),
Dan Gohmanf17a25c2007-07-18 16:29:46 +000049 ZeroDirective("\t.zero\t"),
50 ZeroDirectiveSuffix(0),
51 AsciiDirective("\t.ascii\t"),
52 AscizDirective("\t.asciz\t"),
53 Data8bitsDirective("\t.byte\t"),
54 Data16bitsDirective("\t.short\t"),
55 Data32bitsDirective("\t.long\t"),
56 Data64bitsDirective("\t.quad\t"),
57 AlignDirective("\t.align\t"),
58 AlignmentIsInBytes(true),
Lauro Ramos Venancio9190bc42008-02-28 22:14:09 +000059 TextAlignFillValue(0),
Dan Gohmanf17a25c2007-07-18 16:29:46 +000060 SwitchToSectionDirective("\t.section\t"),
61 TextSectionStartSuffix(""),
62 DataSectionStartSuffix(""),
63 SectionEndDirectiveSuffix(0),
64 ConstantPoolSection("\t.section .rodata"),
65 JumpTableDataSection("\t.section .rodata"),
66 JumpTableDirective(0),
67 CStringSection(0),
68 StaticCtorsSection("\t.section .ctors,\"aw\",@progbits"),
69 StaticDtorsSection("\t.section .dtors,\"aw\",@progbits"),
70 FourByteConstantSection(0),
71 EightByteConstantSection(0),
72 SixteenByteConstantSection(0),
73 ReadOnlySection(0),
Gordon Henriksene383f2a2007-12-23 20:58:16 +000074 GlobalDirective("\t.globl\t"),
Dan Gohmanf17a25c2007-07-18 16:29:46 +000075 SetDirective(0),
76 LCOMMDirective(0),
77 COMMDirective("\t.comm\t"),
78 COMMDirectiveTakesAlignment(true),
79 HasDotTypeDotSizeDirective(true),
80 UsedDirective(0),
81 WeakRefDirective(0),
Dale Johannesenfb3ac732007-11-20 23:24:42 +000082 WeakDefDirective(0),
Dan Gohmanf17a25c2007-07-18 16:29:46 +000083 HiddenDirective("\t.hidden\t"),
84 ProtectedDirective("\t.protected\t"),
85 AbsoluteDebugSectionOffsets(false),
86 AbsoluteEHSectionOffsets(false),
87 HasLEB128(false),
Dan Gohman307ad202007-09-24 21:09:53 +000088 HasDotLocAndDotFile(false),
Dan Gohmanf17a25c2007-07-18 16:29:46 +000089 SupportsDebugInformation(false),
90 SupportsExceptionHandling(false),
91 DwarfRequiresFrameSection(true),
Dale Johannesen23b89a62007-11-21 00:45:00 +000092 GlobalEHDirective(0),
Dale Johannesenf09b5992008-01-10 02:03:30 +000093 SupportsWeakOmittedEHFrame(true),
Dan Gohmanf17a25c2007-07-18 16:29:46 +000094 DwarfSectionOffsetDirective(0),
95 DwarfAbbrevSection(".debug_abbrev"),
96 DwarfInfoSection(".debug_info"),
97 DwarfLineSection(".debug_line"),
98 DwarfFrameSection(".debug_frame"),
Dan Gohmanf17a25c2007-07-18 16:29:46 +000099 DwarfPubNamesSection(".debug_pubnames"),
100 DwarfPubTypesSection(".debug_pubtypes"),
101 DwarfStrSection(".debug_str"),
102 DwarfLocSection(".debug_loc"),
103 DwarfARangesSection(".debug_aranges"),
104 DwarfRangesSection(".debug_ranges"),
105 DwarfMacInfoSection(".debug_macinfo"),
106 DwarfEHFrameSection(".eh_frame"),
107 DwarfExceptionSection(".gcc_except_table"),
108 AsmTransCBE(0) {
109}
110
111TargetAsmInfo::~TargetAsmInfo() {
112}
113
114/// Measure the specified inline asm to determine an approximation of its
115/// length.
116/// Comments (which run till the next SeparatorChar or newline) do not
117/// count as an instruction.
118/// Any other non-whitespace text is considered an instruction, with
119/// multiple instructions separated by SeparatorChar or newlines.
120/// Variable-length instructions are not handled here; this function
121/// may be overloaded in the target code to do that.
122unsigned TargetAsmInfo::getInlineAsmLength(const char *Str) const {
123 // Count the number of instructions in the asm.
124 bool atInsnStart = true;
125 unsigned Length = 0;
126 for (; *Str; ++Str) {
127 if (*Str == '\n' || *Str == SeparatorChar)
128 atInsnStart = true;
129 if (atInsnStart && !isspace(*Str)) {
130 Length += MaxInstLength;
131 atInsnStart = false;
132 }
133 if (atInsnStart && strncmp(Str, CommentString, strlen(CommentString))==0)
134 atInsnStart = false;
135 }
136
137 return Length;
138}
139
Anton Korobeynikov8750d7c2008-02-29 22:09:08 +0000140unsigned TargetAsmInfo::PreferredEHDataFormat(DwarfEncoding::Target Reason,
Anton Korobeynikov65c0d872008-02-27 23:33:50 +0000141 bool Global) const {
142 return dwarf::DW_EH_PE_absptr;
143}
144