From: jjasmine <tanghocle...@gmail.com>

gcc/rust/ChangeLog:

        * hir/tree/rust-hir.cc (InlineAsm::accept_vis):
        Make sure CompileExpr::visit is reached
        * typecheck/rust-hir-type-check-expr.cc (TypeCheckExpr::visit):
        Likewise
gcc/testsuite/ChangeLog:

        * rust/compile/inline_asm_compile_nop.rs: New test.
---
 gcc/rust/hir/tree/rust-hir.cc                        |  4 +++-
 gcc/rust/typecheck/rust-hir-type-check-expr.cc       |  4 +---
 gcc/testsuite/rust/compile/inline_asm_compile_nop.rs | 12 ++++++++++++
 3 files changed, 16 insertions(+), 4 deletions(-)
 create mode 100644 gcc/testsuite/rust/compile/inline_asm_compile_nop.rs

diff --git a/gcc/rust/hir/tree/rust-hir.cc b/gcc/rust/hir/tree/rust-hir.cc
index 8e0d444ce15..f05e5065e62 100644
--- a/gcc/rust/hir/tree/rust-hir.cc
+++ b/gcc/rust/hir/tree/rust-hir.cc
@@ -3833,7 +3833,9 @@ BorrowExpr::accept_vis (HIRFullVisitor &vis)
 
 void
 InlineAsm::accept_vis (HIRExpressionVisitor &vis)
-{}
+{
+  vis.visit (*this);
+}
 
 void
 InlineAsm::accept_vis (HIRFullVisitor &vis)
diff --git a/gcc/rust/typecheck/rust-hir-type-check-expr.cc 
b/gcc/rust/typecheck/rust-hir-type-check-expr.cc
index 6635f13ea04..1197916d1f5 100644
--- a/gcc/rust/typecheck/rust-hir-type-check-expr.cc
+++ b/gcc/rust/typecheck/rust-hir-type-check-expr.cc
@@ -777,9 +777,7 @@ TypeCheckExpr::visit (HIR::RangeToExpr &expr)
 
 void
 TypeCheckExpr::visit (HIR::InlineAsm &expr)
-{
-  return;
-}
+{}
 
 void
 TypeCheckExpr::visit (HIR::RangeFullExpr &expr)
diff --git a/gcc/testsuite/rust/compile/inline_asm_compile_nop.rs 
b/gcc/testsuite/rust/compile/inline_asm_compile_nop.rs
new file mode 100644
index 00000000000..c49667c879d
--- /dev/null
+++ b/gcc/testsuite/rust/compile/inline_asm_compile_nop.rs
@@ -0,0 +1,12 @@
+#![feature(rustc_attrs)]
+
+#[rustc_builtin_macro]
+macro_rules! asm {
+    () => {}
+}
+
+fn main() {
+    unsafe {
+        asm!("nop");
+    }
+}
\ No newline at end of file
-- 
2.45.2

Reply via email to