https://gcc.gnu.org/g:ff32f8fdcef87ef569fd072ee12c47237e8da2e7

commit ff32f8fdcef87ef569fd072ee12c47237e8da2e7
Author: Pierre-Emmanuel Patry <pierre-emmanuel.pa...@embecosm.com>
Date:   Mon Sep 4 13:22:21 2023 +0200

    Make proc macro definition cdecl
    
    We need to make sure proc macros have the C abi in order to be called by
    the compiler with dlopen.
    
    gcc/rust/ChangeLog:
    
            * backend/rust-compile-base.cc (HIRCompileBase::setup_fndecl):
            Add proc macro handlers dispatch.
            (handle_proc_macro_common): Add a function for common behavior
            between all kinds of proc macros.
            * backend/rust-compile-base.h: Add function prototypes.
    
    Signed-off-by: Pierre-Emmanuel Patry <pierre-emmanuel.pa...@embecosm.com>

Diff:
---
 gcc/rust/backend/rust-compile-base.cc | 47 +++++++++++++++++++++++++++++++++++
 gcc/rust/backend/rust-compile-base.h  | 12 +++++++++
 2 files changed, 59 insertions(+)

diff --git a/gcc/rust/backend/rust-compile-base.cc 
b/gcc/rust/backend/rust-compile-base.cc
index 7aab59baefec..1d1edfb20052 100644
--- a/gcc/rust/backend/rust-compile-base.cc
+++ b/gcc/rust/backend/rust-compile-base.cc
@@ -83,6 +83,13 @@ HIRCompileBase::setup_fndecl (tree fndecl, bool 
is_main_entry_point,
        = attr.get_path ().as_string () == Values::Attributes::NO_MANGLE;
       bool is_deprecated
        = attr.get_path ().as_string () == Values::Attributes::DEPRECATED;
+      bool is_proc_macro
+       = attr.get_path ().as_string () == Values::Attributes::PROC_MACRO;
+      bool is_proc_macro_attribute
+       = attr.get_path ().as_string ()
+         == Values::Attributes::PROC_MACRO_ATTRIBUTE;
+      bool is_proc_macro_derive = attr.get_path ().as_string ()
+                                 == Values::Attributes::PROC_MACRO_DERIVE;
 
       if (is_inline)
        {
@@ -108,9 +115,49 @@ HIRCompileBase::setup_fndecl (tree fndecl, bool 
is_main_entry_point,
        {
          handle_no_mangle_attribute_on_fndecl (fndecl, attr);
        }
+      else if (is_proc_macro)
+       {
+         handle_proc_macro_attribute_on_fndecl (fndecl, attr);
+       }
+      else if (is_proc_macro_attribute)
+       {
+         handle_proc_macro_attribute_attribute_on_fndecl (fndecl, attr);
+       }
+      else if (is_proc_macro_derive)
+       {
+         handle_proc_macro_derive_attribute_on_fndecl (fndecl, attr);
+       }
     }
 }
 
+static void
+handle_proc_macro_common (tree fndecl, const AST::Attribute &attr)
+{
+  DECL_ATTRIBUTES (fndecl)
+    = tree_cons (get_identifier ("cdecl"), NULL, DECL_ATTRIBUTES (fndecl));
+}
+
+void
+HIRCompileBase::handle_proc_macro_attribute_on_fndecl (
+  tree fndecl, const AST::Attribute &attr)
+{
+  handle_proc_macro_common (fndecl, attr);
+}
+
+void
+HIRCompileBase::handle_proc_macro_attribute_attribute_on_fndecl (
+  tree fndecl, const AST::Attribute &attr)
+{
+  handle_proc_macro_common (fndecl, attr);
+}
+
+void
+HIRCompileBase::handle_proc_macro_derive_attribute_on_fndecl (
+  tree fndecl, const AST::Attribute &attr)
+{
+  handle_proc_macro_common (fndecl, attr);
+}
+
 void
 HIRCompileBase::handle_cold_attribute_on_fndecl (tree fndecl,
                                                 const AST::Attribute &attr)
diff --git a/gcc/rust/backend/rust-compile-base.h 
b/gcc/rust/backend/rust-compile-base.h
index 4a763a27862e..84775c870112 100644
--- a/gcc/rust/backend/rust-compile-base.h
+++ b/gcc/rust/backend/rust-compile-base.h
@@ -110,6 +110,18 @@ protected:
   static void handle_inline_attribute_on_fndecl (tree fndecl,
                                                 const AST::Attribute &attr);
 
+  static void
+  handle_proc_macro_attribute_on_fndecl (tree fndecl,
+                                        const AST::Attribute &attr);
+
+  static void
+  handle_proc_macro_attribute_attribute_on_fndecl (tree fndecl,
+                                                  const AST::Attribute &attr);
+
+  static void
+  handle_proc_macro_derive_attribute_on_fndecl (tree fndecl,
+                                               const AST::Attribute &attr);
+
   static void handle_cold_attribute_on_fndecl (tree fndecl,
                                               const AST::Attribute &attr);

Reply via email to