https://gcc.gnu.org/g:20db1716d9803f5b2288b2ff32807f152a128630

commit 20db1716d9803f5b2288b2ff32807f152a128630
Author: badumbatish <tanghocle...@gmail.com>
Date:   Thu Aug 1 16:22:32 2024 -0700

    Perform lowering hir output operand to tree
    
    gcc/rust/ChangeLog:
    
            * backend/rust-compile-asm.cc (CompileAsm::asm_build_expr):
            Add debug comment
            (CompileAsm::asm_construct_outputs):
            Perform lowering hir output operand to tree

Diff:
---
 gcc/rust/backend/rust-compile-asm.cc | 12 +++++++++++-
 1 file changed, 11 insertions(+), 1 deletion(-)

diff --git a/gcc/rust/backend/rust-compile-asm.cc 
b/gcc/rust/backend/rust-compile-asm.cc
index 2b32c99dae83..bce49ead28f7 100644
--- a/gcc/rust/backend/rust-compile-asm.cc
+++ b/gcc/rust/backend/rust-compile-asm.cc
@@ -26,6 +26,7 @@ CompileAsm::asm_build_expr (HIR::InlineAsm &expr)
   ASM_INPUT_P (asm_expr) = expr.is_simple_asm ();
   ASM_VOLATILE_P (asm_expr) = false;
   ASM_INLINE_P (asm_expr) = expr.is_inline_asm ();
+  /*Backend::debug (asm_expr);*/
   return asm_expr;
 }
 
@@ -91,8 +92,17 @@ CompileAsm::asm_construct_outputs (HIR::InlineAsm &expr)
          == AST::InlineAsmOperand::RegisterType::Out)
        {
          auto out = output.get_out ();
+
          tree out_tree = CompileExpr::Compile (out.expr.get (), this->ctx);
-         Backend::debug (out_tree);
+         // expects a tree list
+         // TODO: This assumes that the output is a register
+         std::string expr_name = "=r";
+         auto name = build_string (expr_name.size () + 1, expr_name.c_str ());
+         head
+           = chainon (head, build_tree_list (build_tree_list (NULL_TREE, name),
+                                             out_tree));
+
+         /*Backend::debug (head);*/
          /*head = chainon (head, out_tree);*/
        }
     }

Reply via email to