aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorM V V S Manoj Kumar <mvvsmanojkumar@gmail.com>2023-02-17 23:39:56 +0530
committerArthur Cohen <arthur.cohen@embecosm.com>2023-04-06 10:47:24 +0200
commitf2d6ab839ce7aafc629e7f3ecf2b8f98fc1fe6cd (patch)
tree4c72850c69506cd19b9871264c39e9c06975ff1c /gcc
parent2785d591116a135215f473534b20f5da6075b265 (diff)
downloadgcc-f2d6ab839ce7aafc629e7f3ecf2b8f98fc1fe6cd.zip
gcc-f2d6ab839ce7aafc629e7f3ecf2b8f98fc1fe6cd.tar.gz
gcc-f2d6ab839ce7aafc629e7f3ecf2b8f98fc1fe6cd.tar.bz2
gccrs: Added AST Node AST::InlineAsm
Addresses #1567 Created a AST node InlineAsm similar to the one found in rustc. As there is no Symbol struct/class in gccrs I have made every instance of Symbol a string. gcc/rust/ChangeLog: * ast/rust-ast-full-decls.h (class InlineAsm):Added class declaration. * ast/rust-expr.h (class InlineAsm):Added class definition. Signed-off-by: M V V S Manoj Kumar <mvvsmanojkumar@gmail.com>
Diffstat (limited to 'gcc')
-rw-r--r--gcc/rust/ast/rust-ast-full-decls.h1
-rw-r--r--gcc/rust/ast/rust-expr.h138
2 files changed, 139 insertions, 0 deletions
diff --git a/gcc/rust/ast/rust-ast-full-decls.h b/gcc/rust/ast/rust-ast-full-decls.h
index 9d7b00a..64341d3 100644
--- a/gcc/rust/ast/rust-ast-full-decls.h
+++ b/gcc/rust/ast/rust-ast-full-decls.h
@@ -149,6 +149,7 @@ struct MatchCase;
class MatchExpr;
class AwaitExpr;
class AsyncBlockExpr;
+class InlineAsm;
// rust-stmt.h
class EmptyStmt;
diff --git a/gcc/rust/ast/rust-expr.h b/gcc/rust/ast/rust-expr.h
index 3ed1885d..f546184 100644
--- a/gcc/rust/ast/rust-expr.h
+++ b/gcc/rust/ast/rust-expr.h
@@ -4634,6 +4634,144 @@ protected:
return new AsyncBlockExpr (*this);
}
};
+
+// Inline Assembly Node
+class InlineAsm : public ExprWithoutBlock
+{
+ // Inline-assembly specific options
+ enum InlineAsmOptions
+ {
+ PURE = 1 << 0,
+ NOMEM = 1 << 1,
+ READONLY = 1 << 2,
+ PRESERVES_FLAGS = 1 << 3,
+ NORETURN = 1 << 4,
+ NOSTACK = 1 << 5,
+ ATT_SYNTAX = 1 << 6,
+ RAW = 1 << 7,
+ MAY_UNWIND = 1 << 8,
+ };
+
+ struct AnonConst
+ {
+ NodeId id;
+ std::unique_ptr<Expr> value;
+ };
+
+ struct InlineAsmRegOrRegClass
+ {
+ enum Type
+ {
+ Reg,
+ RegClass,
+ };
+
+ struct Reg
+ {
+ std::string Symbol;
+ };
+
+ struct RegClass
+ {
+ std::string Symbol;
+ };
+
+ Identifier name;
+ Location locus;
+ };
+
+ struct InlineAsmOperand
+ {
+ enum RegisterType
+ {
+ In,
+ Out,
+ InOut,
+ SplitInOut,
+ Const,
+ Sym,
+ };
+
+ struct In
+ {
+ InlineAsmRegOrRegClass reg;
+ std::unique_ptr<Expr> expr;
+ };
+
+ struct Out
+ {
+ InlineAsmRegOrRegClass reg;
+ bool late;
+ std::unique_ptr<Expr> expr; // can be null
+ };
+
+ struct InOut
+ {
+ InlineAsmRegOrRegClass reg;
+ bool late;
+ std::unique_ptr<Expr> expr; // this can't be null
+ };
+
+ struct SplitInOut
+ {
+ InlineAsmRegOrRegClass reg;
+ bool late;
+ std::unique_ptr<Expr> in_expr;
+ std::unique_ptr<Expr> out_expr; // could be null
+ };
+
+ struct Const
+ {
+ AnonConst anon_const;
+ };
+
+ struct Sym
+ {
+ std::unique_ptr<Expr> sym;
+ };
+ Location locus;
+ };
+
+ struct InlineAsmPlaceHolder
+ {
+ size_t operand_idx;
+ char modifier; // can be null
+ Location locus;
+ };
+
+ struct InlineAsmTemplatePiece
+ {
+ bool is_placeholder;
+ union
+ {
+ std::string string;
+ InlineAsmPlaceHolder placeholder;
+ };
+ };
+
+ struct TupleClobber
+ {
+ // as gccrs still doesen't contain a symbol class I have put them as strings
+ std::string symbol;
+ Location loc;
+ };
+
+ struct TupleTemplateStr
+ {
+ // as gccrs still doesen't contain a symbol class I have put them as strings
+ std::string symbol;
+ std::string optional_symbol;
+ Location loc;
+ };
+
+public:
+ std::vector<InlineAsmTemplatePiece> template_;
+ std::vector<TupleTemplateStr> template_strs;
+ std::vector<InlineAsmOperand> operands;
+ TupleClobber clobber_abi;
+ InlineAsmOptions options;
+ std::vector<Location> line_spans;
+};
} // namespace AST
} // namespace Rust