blob: b3190b124bd7e642229cc4c875b5445e7601c7f5 [file] [log] [blame]
Chris Lattnerb0133452009-06-21 20:16:42 +00001//===- AsmParser.h - Parser for Assembly Files ------------------*- 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 class declares the parser for assembly files.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef ASMPARSER_H
15#define ASMPARSER_H
16
17#include "AsmLexer.h"
Daniel Dunbar3c2a8932009-07-20 18:55:04 +000018#include "llvm/MC/MCAsmParser.h"
Daniel Dunbara5508c82009-06-30 00:33:19 +000019#include "llvm/MC/MCStreamer.h"
Chris Lattnerb0133452009-06-21 20:16:42 +000020
21namespace llvm {
Daniel Dunbar7e8d6c72009-06-29 20:37:27 +000022class AsmExpr;
Chris Lattner3f5738d2009-06-24 04:31:49 +000023class MCContext;
Chris Lattner3417d712009-06-23 18:41:30 +000024class MCInst;
Chris Lattner92ffdd12009-06-24 00:52:40 +000025class MCStreamer;
Daniel Dunbarbd4bf3d2009-06-30 01:49:52 +000026class MCValue;
Daniel Dunbar2b11c7d2009-07-20 20:01:54 +000027class TargetAsmParser;
Daniel Dunbarbd4bf3d2009-06-30 01:49:52 +000028
Daniel Dunbar3c2a8932009-07-20 18:55:04 +000029class AsmParser : MCAsmParser {
Daniel Dunbard0a08e02009-06-30 23:38:38 +000030public:
31 struct X86Operand;
32
33private:
Chris Lattnerb0133452009-06-21 20:16:42 +000034 AsmLexer Lexer;
Chris Lattner3f5738d2009-06-24 04:31:49 +000035 MCContext &Ctx;
Chris Lattner92ffdd12009-06-24 00:52:40 +000036 MCStreamer &Out;
Daniel Dunbar3c2a8932009-07-20 18:55:04 +000037 TargetAsmParser &TargetParser;
Chris Lattner92ffdd12009-06-24 00:52:40 +000038
Chris Lattnerb0133452009-06-21 20:16:42 +000039public:
Daniel Dunbar3c2a8932009-07-20 18:55:04 +000040 AsmParser(SourceMgr &_SM, MCContext &_Ctx, MCStreamer &_Out,
41 TargetAsmParser &_TargetParser)
42 : Lexer(_SM), Ctx(_Ctx), Out(_Out), TargetParser(_TargetParser) {}
Chris Lattnerb0133452009-06-21 20:16:42 +000043 ~AsmParser() {}
44
45 bool Run();
46
Daniel Dunbar3c2a8932009-07-20 18:55:04 +000047public:
48 TargetAsmParser &getTargetParser() const { return TargetParser; }
49
Daniel Dunbar2b11c7d2009-07-20 20:01:54 +000050 virtual MCAsmLexer &getLexer() { return Lexer; }
51
Chris Lattner36e02122009-06-21 20:54:55 +000052private:
53 bool ParseStatement();
Daniel Dunbarc9dc78a2009-06-30 00:49:23 +000054
55 void Warning(SMLoc L, const char *Msg);
Chris Lattner2adc9e72009-06-21 21:22:11 +000056 bool Error(SMLoc L, const char *Msg);
57 bool TokError(const char *Msg);
Chris Lattnere5074c42009-06-22 01:29:09 +000058
59 void EatToEndOfStatement();
60
Daniel Dunbar2d2ee152009-06-25 21:56:11 +000061 bool ParseAssignment(const char *Name, bool IsDotSet);
Daniel Dunbar7e8d6c72009-06-29 20:37:27 +000062
63 /// ParseExpression - Parse a general assembly expression.
64 ///
65 /// @param Res - The resulting expression. The pointer value is null on error.
66 /// @result - False on success.
67 bool ParseExpression(AsmExpr *&Res);
Daniel Dunbarbd4bf3d2009-06-30 01:49:52 +000068
69 /// ParseAbsoluteExpression - Parse an expression which must evaluate to an
70 /// absolute value.
Daniel Dunbar7e8d6c72009-06-29 20:37:27 +000071 ///
72 /// @param Res - The value of the absolute expression. The result is undefined
73 /// on error.
74 /// @result - False on success.
75 bool ParseAbsoluteExpression(int64_t &Res);
76
Daniel Dunbarbd4bf3d2009-06-30 01:49:52 +000077 /// ParseRelocatableExpression - Parse an expression which must be
78 /// relocatable.
79 ///
80 /// @param Res - The relocatable expression value. The result is undefined on
81 /// error.
82 /// @result - False on success.
83 bool ParseRelocatableExpression(MCValue &Res);
84
Daniel Dunbar9bff6532009-07-02 02:09:07 +000085 /// ParseParenRelocatableExpression - Parse an expression which must be
86 /// relocatable, assuming that an initial '(' has already been consumed.
87 ///
88 /// @param Res - The relocatable expression value. The result is undefined on
89 /// error.
90 /// @result - False on success.
91 ///
92 /// @see ParseRelocatableExpression, ParseParenExpr.
93 bool ParseParenRelocatableExpression(MCValue &Res);
94
Daniel Dunbar7e8d6c72009-06-29 20:37:27 +000095 bool ParsePrimaryExpr(AsmExpr *&Res);
96 bool ParseBinOpRHS(unsigned Precedence, AsmExpr *&Res);
97 bool ParseParenExpr(AsmExpr *&Res);
Chris Lattner3417d712009-06-23 18:41:30 +000098
99 // X86 specific.
Daniel Dunbard0a08e02009-06-30 23:38:38 +0000100 bool ParseX86InstOperands(const char *InstName, MCInst &Inst);
Chris Lattner3417d712009-06-23 18:41:30 +0000101 bool ParseX86Operand(X86Operand &Op);
102 bool ParseX86MemOperand(X86Operand &Op);
Daniel Dunbar36a20072009-07-02 01:58:24 +0000103 bool ParseX86Register(X86Operand &Op);
Chris Lattnerbedf6c22009-06-24 04:43:34 +0000104
105 // Directive Parsing.
Chris Lattnerf7ebca42009-06-24 05:13:15 +0000106 bool ParseDirectiveDarwinSection(); // Darwin specific ".section".
107 bool ParseDirectiveSectionSwitch(const char *Section,
108 const char *Directives = 0);
Daniel Dunbara10e5192009-06-24 23:30:00 +0000109 bool ParseDirectiveAscii(bool ZeroTerminated); // ".ascii", ".asciiz"
110 bool ParseDirectiveValue(unsigned Size); // ".byte", ".long", ...
111 bool ParseDirectiveFill(); // ".fill"
112 bool ParseDirectiveSpace(); // ".space"
Daniel Dunbar2d2ee152009-06-25 21:56:11 +0000113 bool ParseDirectiveSet(); // ".set"
Daniel Dunbar4a5a5612009-06-25 22:44:51 +0000114 bool ParseDirectiveOrg(); // ".org"
Daniel Dunbarcc566a712009-06-29 23:46:59 +0000115 // ".align{,32}", ".p2align{,w,l}"
116 bool ParseDirectiveAlign(bool IsPow2, unsigned ValueSize);
Daniel Dunbara5508c82009-06-30 00:33:19 +0000117
118 /// ParseDirectiveSymbolAttribute - Parse a directive like ".globl" which
119 /// accepts a single symbol (which should be a label or an external).
120 bool ParseDirectiveSymbolAttribute(MCStreamer::SymbolAttr Attr);
Kevin Enderby4c21caa2009-07-14 18:17:10 +0000121 bool ParseDirectiveDarwinSymbolDesc(); // Darwin specific ".desc"
Kevin Enderbycbe475d2009-07-14 21:35:03 +0000122 bool ParseDirectiveDarwinLsym(); // Darwin specific ".lsym"
Chris Lattnera1e11f52009-07-07 20:30:46 +0000123
Chris Lattner28ad7542009-07-09 17:25:12 +0000124 bool ParseDirectiveComm(bool IsLocal); // ".comm" and ".lcomm"
Chris Lattner07cadaf2009-07-10 22:20:30 +0000125 bool ParseDirectiveDarwinZerofill(); // Darwin specific ".zerofill"
Kevin Enderbyc9d93ef2009-07-13 21:03:15 +0000126
127 // Darwin specific ".subsections_via_symbols"
128 bool ParseDirectiveDarwinSubsectionsViaSymbols();
Kevin Enderby09ea5702009-07-15 15:30:11 +0000129 // Darwin specific .dump and .load
Kevin Enderbyee551352009-07-20 20:25:37 +0000130 bool ParseDirectiveDarwinDumpOrLoad(SMLoc IDLoc, bool IsDump);
Kevin Enderby56523ce2009-07-13 23:15:14 +0000131
132 bool ParseDirectiveAbort(); // ".abort"
Kevin Enderbyd1ea5392009-07-14 23:21:55 +0000133 bool ParseDirectiveInclude(); // ".include"
Chris Lattnerb0133452009-06-21 20:16:42 +0000134};
135
136} // end namespace llvm
137
138#endif