diff options
author | Philip Herron <philip.herron@embecosm.com> | 2022-07-08 15:13:57 +0100 |
---|---|---|
committer | Philip Herron <philip.herron@embecosm.com> | 2022-07-15 11:59:38 +0100 |
commit | 6bf6241f29e73678b8c7d3508cdb39b55ae9d1ab (patch) | |
tree | 11bfbd4b50e747d310ed1d596032c49b3cd6b710 | |
parent | f51284b598863eb0cbeb2984fd1499a672f2191d (diff) | |
download | gcc-6bf6241f29e73678b8c7d3508cdb39b55ae9d1ab.zip gcc-6bf6241f29e73678b8c7d3508cdb39b55ae9d1ab.tar.gz gcc-6bf6241f29e73678b8c7d3508cdb39b55ae9d1ab.tar.bz2 |
External Items with Rust ABI need to mangle the full path
When compiling external rust abi item requires the fully qualified
canonical path to be mangled in order to link correctly.
-rw-r--r-- | gcc/rust/backend/rust-compile-extern.h | 11 | ||||
-rw-r--r-- | gcc/rust/resolve/rust-ast-resolve-item.cc | 6 |
2 files changed, 17 insertions, 0 deletions
diff --git a/gcc/rust/backend/rust-compile-extern.h b/gcc/rust/backend/rust-compile-extern.h index c24437d..ddad350 100644 --- a/gcc/rust/backend/rust-compile-extern.h +++ b/gcc/rust/backend/rust-compile-extern.h @@ -130,6 +130,17 @@ public: tree compiled_fn_type = TyTyResolveCompile::compile (ctx, fntype); std::string ir_symbol_name = function.get_item_name (); std::string asm_name = function.get_item_name (); + if (fntype->get_abi () == ABI::RUST) + { + // then we need to get the canonical path of it and mangle it + const Resolver::CanonicalPath *canonical_path = nullptr; + bool ok = ctx->get_mappings ()->lookup_canonical_path ( + function.get_mappings ().get_nodeid (), &canonical_path); + rust_assert (ok); + + ir_symbol_name = canonical_path->get () + fntype->subst_as_string (); + asm_name = ctx->mangle_item (fntype, *canonical_path); + } const unsigned int flags = Backend::function_is_declaration; tree fndecl diff --git a/gcc/rust/resolve/rust-ast-resolve-item.cc b/gcc/rust/resolve/rust-ast-resolve-item.cc index 244bf64..75bd2e1 100644 --- a/gcc/rust/resolve/rust-ast-resolve-item.cc +++ b/gcc/rust/resolve/rust-ast-resolve-item.cc @@ -1027,6 +1027,12 @@ void ResolveExternItem::visit (AST::ExternalFunctionItem &function) { NodeId scope_node_id = function.get_node_id (); + auto decl = CanonicalPath::new_seg (function.get_node_id (), + function.get_identifier ()); + auto path = prefix.append (decl); + auto cpath = canonical_prefix.append (decl); + + mappings->insert_canonical_path (function.get_node_id (), cpath); resolve_visibility (function.get_visibility ()); |