aboutsummaryrefslogtreecommitdiff
path: root/gcc/rust
diff options
context:
space:
mode:
authorjjasmine <tanghocle456@gmail.com>2024-05-31 16:09:40 -0700
committerArthur Cohen <arthur.cohen@embecosm.com>2025-03-17 16:35:44 +0100
commitd7f480b7693d3d02bbd5d8bb9baaa54c1bf7feab (patch)
tree36218b2d2633dbd4f1c1e709374945c140c1262c /gcc/rust
parentbfc249cc179ab1097598bcc5baa726768f5c39c0 (diff)
downloadgcc-d7f480b7693d3d02bbd5d8bb9baaa54c1bf7feab.zip
gcc-d7f480b7693d3d02bbd5d8bb9baaa54c1bf7feab.tar.gz
gcc-d7f480b7693d3d02bbd5d8bb9baaa54c1bf7feab.tar.bz2
gccrs: Partial unsafe support for inline asm
gcc/rust/ChangeLog: * checks/errors/rust-unsafe-checker.cc (UnsafeChecker::visit): Partial unsafe support for inline asm * checks/errors/rust-unsafe-checker.h: Likewise. * hir/tree/rust-hir-expr.h: Likewise. * hir/tree/rust-hir.cc (InlineAsm::accept_vis): Likewise.
Diffstat (limited to 'gcc/rust')
-rw-r--r--gcc/rust/checks/errors/rust-unsafe-checker.cc11
-rw-r--r--gcc/rust/checks/errors/rust-unsafe-checker.h1
-rw-r--r--gcc/rust/hir/tree/rust-hir-expr.h4
-rw-r--r--gcc/rust/hir/tree/rust-hir.cc9
4 files changed, 23 insertions, 2 deletions
diff --git a/gcc/rust/checks/errors/rust-unsafe-checker.cc b/gcc/rust/checks/errors/rust-unsafe-checker.cc
index 8d986c7..c6ed922 100644
--- a/gcc/rust/checks/errors/rust-unsafe-checker.cc
+++ b/gcc/rust/checks/errors/rust-unsafe-checker.cc
@@ -637,6 +637,17 @@ UnsafeChecker::visit (AsyncBlockExpr &)
}
void
+UnsafeChecker::visit (InlineAsm &expr)
+{
+ if (unsafe_context.is_in_context ())
+ return;
+
+ rust_error_at (
+ expr.get_locus (), ErrorCode::E0133,
+ "use of inline assembly is unsafe and requires unsafe function or block");
+}
+
+void
UnsafeChecker::visit (TypeParam &)
{}
diff --git a/gcc/rust/checks/errors/rust-unsafe-checker.h b/gcc/rust/checks/errors/rust-unsafe-checker.h
index ba92672..1fa1fe0 100644
--- a/gcc/rust/checks/errors/rust-unsafe-checker.h
+++ b/gcc/rust/checks/errors/rust-unsafe-checker.h
@@ -115,6 +115,7 @@ private:
virtual void visit (MatchExpr &expr) override;
virtual void visit (AwaitExpr &expr) override;
virtual void visit (AsyncBlockExpr &expr) override;
+ virtual void visit (InlineAsm &expr);
virtual void visit (TypeParam &param) override;
virtual void visit (ConstGenericParam &param) override;
virtual void visit (LifetimeWhereClauseItem &item) override;
diff --git a/gcc/rust/hir/tree/rust-hir-expr.h b/gcc/rust/hir/tree/rust-hir-expr.h
index a0858a3..9c66f3e 100644
--- a/gcc/rust/hir/tree/rust-hir-expr.h
+++ b/gcc/rust/hir/tree/rust-hir-expr.h
@@ -3878,9 +3878,9 @@ public:
std::vector<location_t> line_spans;
- void accept_vis (HIRExpressionVisitor &vis) override{};
+ void accept_vis (HIRExpressionVisitor &vis) override;
- void accept_vis (HIRFullVisitor &vis) override{};
+ void accept_vis (HIRFullVisitor &vis) override;
std::string as_string () const override { return "InlineAsm HIR Node"; }
diff --git a/gcc/rust/hir/tree/rust-hir.cc b/gcc/rust/hir/tree/rust-hir.cc
index 5cb2245..66c6240 100644
--- a/gcc/rust/hir/tree/rust-hir.cc
+++ b/gcc/rust/hir/tree/rust-hir.cc
@@ -17,6 +17,7 @@
// <http://www.gnu.org/licenses/>.
#include "rust-ast-full.h"
+#include "rust-hir-expr.h"
#include "rust-hir-full.h"
#include "rust-hir-visitor.h"
#include "rust-diagnostics.h"
@@ -3770,6 +3771,14 @@ BorrowExpr::accept_vis (HIRFullVisitor &vis)
}
void
+InlineAsm::accept_vis (HIRExpressionVisitor &vis)
+{}
+
+void
+InlineAsm::accept_vis (HIRFullVisitor &vis)
+{}
+
+void
BorrowExpr::accept_vis (HIRExpressionVisitor &vis)
{
vis.visit (*this);