blob: bda700b6aa7344eb9174142caa0b2f950208ed7a [file] [log] [blame]
Chris Lattneraf76e592009-08-22 20:48:53 +00001//===-- MCAsmInfo.cpp - Asm Info -------------------------------------------==//
Jim Laskeyec0d9fe2006-09-06 18:35:33 +00002//
3// The LLVM Compiler Infrastructure
4//
Chris Lattner4ee451d2007-12-29 20:36:04 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Jim Laskeyec0d9fe2006-09-06 18:35:33 +00007//
8//===----------------------------------------------------------------------===//
9//
10// This file defines target asm properties related what form asm statements
11// should take.
12//
13//===----------------------------------------------------------------------===//
14
Chris Lattneraf76e592009-08-22 20:48:53 +000015#include "llvm/MC/MCAsmInfo.h"
Chandler Carruth8b67f772009-10-26 01:35:46 +000016#include "llvm/System/DataTypes.h"
Dale Johannesen3bb62832007-04-23 20:00:17 +000017#include <cctype>
18#include <cstring>
Jim Laskeyec0d9fe2006-09-06 18:35:33 +000019using namespace llvm;
20
Chris Lattner8eeba352010-01-20 06:34:14 +000021MCAsmInfo::MCAsmInfo() {
Chris Lattnerf9f93e42010-01-23 07:21:06 +000022 HasSubsectionsViaSymbols = false;
Chris Lattneraac138e2010-01-19 02:09:44 +000023 HasMachoZeroFillDirective = false;
Chris Lattner71eae712010-01-19 04:34:02 +000024 HasStaticCtorDtorReferenceInStaticMode = false;
Anton Korobeynikov32b952a2008-09-25 21:00:33 +000025 MaxInstLength = 4;
26 PCSymbol = "$";
27 SeparatorChar = ';';
Daniel Dunbar73163f82010-02-05 07:32:18 +000028 CommentColumn = 40;
Anton Korobeynikov32b952a2008-09-25 21:00:33 +000029 CommentString = "#";
30 GlobalPrefix = "";
31 PrivateGlobalPrefix = ".";
Chris Lattner90f8b702009-07-21 17:30:51 +000032 LinkerPrivateGlobalPrefix = "";
Chris Lattnere2b06012009-08-11 22:39:40 +000033 InlineAsmStart = "APP";
34 InlineAsmEnd = "NO_APP";
Anton Korobeynikov32b952a2008-09-25 21:00:33 +000035 AssemblerDialect = 0;
Chris Lattnera93ca922009-06-18 23:41:35 +000036 AllowQuotesInName = false;
Anton Korobeynikovc6f729e2009-09-18 16:57:42 +000037 AllowNameToStartWithDigit = false;
Anton Korobeynikov32b952a2008-09-25 21:00:33 +000038 ZeroDirective = "\t.zero\t";
Anton Korobeynikov32b952a2008-09-25 21:00:33 +000039 AsciiDirective = "\t.ascii\t";
40 AscizDirective = "\t.asciz\t";
41 Data8bitsDirective = "\t.byte\t";
42 Data16bitsDirective = "\t.short\t";
43 Data32bitsDirective = "\t.long\t";
44 Data64bitsDirective = "\t.quad\t";
Chris Lattner5277b222009-08-08 20:43:12 +000045 SunStyleELFSectionSwitchSyntax = false;
Bruno Cardoso Lopesfdf229e2009-08-13 23:30:21 +000046 UsesELFSectionDirectiveForBSS = false;
Anton Korobeynikov32b952a2008-09-25 21:00:33 +000047 AlignDirective = "\t.align\t";
48 AlignmentIsInBytes = true;
49 TextAlignFillValue = 0;
Chris Lattner78f485a2010-01-25 21:10:10 +000050 GPRel32Directive = 0;
Anton Korobeynikov32b952a2008-09-25 21:00:33 +000051 GlobalDirective = "\t.globl\t";
Chris Lattnercee63322010-01-26 20:40:54 +000052 HasSetDirective = true;
Chris Lattner9eb158d2010-01-23 07:47:02 +000053 HasLCOMMDirective = false;
Rafael Espindola2e2563b2010-01-26 20:21:43 +000054 COMMDirectiveAlignmentIsInBytes = true;
Anton Korobeynikov32b952a2008-09-25 21:00:33 +000055 HasDotTypeDotSizeDirective = true;
Rafael Espindola952b8392008-12-03 11:01:37 +000056 HasSingleParameterDotFile = true;
Chris Lattner3a9be0e2010-01-23 05:51:36 +000057 HasNoDeadStrip = false;
Anton Korobeynikov32b952a2008-09-25 21:00:33 +000058 WeakRefDirective = 0;
59 WeakDefDirective = 0;
Chris Lattner41eb8b42010-01-19 05:08:13 +000060 LinkOnceDirective = 0;
Chris Lattner152a29b2010-01-23 06:53:23 +000061 HiddenVisibilityAttr = MCSA_Hidden;
62 ProtectedVisibilityAttr = MCSA_Protected;
Anton Korobeynikov32b952a2008-09-25 21:00:33 +000063 AbsoluteDebugSectionOffsets = false;
64 AbsoluteEHSectionOffsets = false;
65 HasLEB128 = false;
66 HasDotLocAndDotFile = false;
67 SupportsDebugInformation = false;
Jim Grosbach1b747ad2009-08-11 00:09:57 +000068 ExceptionsType = ExceptionHandling::None;
Anton Korobeynikov32b952a2008-09-25 21:00:33 +000069 DwarfRequiresFrameSection = true;
Devang Patel0f7fef32009-04-13 17:02:03 +000070 DwarfUsesInlineInfoSection = false;
Anton Korobeynikov32b952a2008-09-25 21:00:33 +000071 DwarfSectionOffsetDirective = 0;
Chris Lattner18a4c162009-08-02 07:24:22 +000072
Anton Korobeynikov32b952a2008-09-25 21:00:33 +000073 AsmTransCBE = 0;
Chris Lattner4c7b07a2006-10-13 17:50:07 +000074}
Chris Lattnerf5b10ec2006-10-05 00:35:16 +000075
Chris Lattneraf76e592009-08-22 20:48:53 +000076MCAsmInfo::~MCAsmInfo() {
Chris Lattnerf5b10ec2006-10-05 00:35:16 +000077}
Chris Lattner4c7b07a2006-10-13 17:50:07 +000078
Anton Korobeynikova6199c82007-03-07 02:47:57 +000079
Chris Lattneraf76e592009-08-22 20:48:53 +000080unsigned MCAsmInfo::getULEB128Size(unsigned Value) {
Anton Korobeynikovffe31d72008-08-16 12:57:46 +000081 unsigned Size = 0;
82 do {
83 Value >>= 7;
84 Size += sizeof(int8_t);
85 } while (Value);
86 return Size;
87}
88
Chris Lattneraf76e592009-08-22 20:48:53 +000089unsigned MCAsmInfo::getSLEB128Size(int Value) {
Anton Korobeynikovffe31d72008-08-16 12:57:46 +000090 unsigned Size = 0;
91 int Sign = Value >> (8 * sizeof(Value) - 1);
92 bool IsMore;
93
94 do {
95 unsigned Byte = Value & 0x7f;
96 Value >>= 7;
97 IsMore = Value != Sign || ((Byte ^ Sign) & 0x40) != 0;
98 Size += sizeof(int8_t);
99 } while (IsMore);
100 return Size;
101}