diff options
author | Philip Herron <philip.herron@embecosm.com> | 2022-04-29 15:27:53 +0100 |
---|---|---|
committer | Philip Herron <philip.herron@embecosm.com> | 2022-04-30 13:31:12 +0100 |
commit | 44c058c30dd1d36f87c36f2c487355a5736d0afc (patch) | |
tree | 9414376dc8e452c4bd69ec5a776daeb25db979c8 /gcc/rust/backend/rust-compile-item.cc | |
parent | f38bf60c3ac7f039db5ff5c7c0587325097892c8 (diff) | |
download | gcc-44c058c30dd1d36f87c36f2c487355a5736d0afc.zip gcc-44c058c30dd1d36f87c36f2c487355a5736d0afc.tar.gz gcc-44c058c30dd1d36f87c36f2c487355a5736d0afc.tar.bz2 |
Fix address expression to respect reference/pointer types
Diffstat (limited to 'gcc/rust/backend/rust-compile-item.cc')
-rw-r--r-- | gcc/rust/backend/rust-compile-item.cc | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/gcc/rust/backend/rust-compile-item.cc b/gcc/rust/backend/rust-compile-item.cc index 969c852..36fa787 100644 --- a/gcc/rust/backend/rust-compile-item.cc +++ b/gcc/rust/backend/rust-compile-item.cc @@ -146,7 +146,10 @@ CompileItem::visit (HIR::Function &function) ctx->insert_function_decl (fntype, lookup); } - reference = address_expression (lookup, ref_locus); + reference + = address_expression (lookup, + build_pointer_type (TREE_TYPE (lookup)), + ref_locus); return; } } @@ -171,7 +174,9 @@ CompileItem::visit (HIR::Function &function) function.get_outer_attrs (), function.get_locus (), function.get_definition ().get (), canonical_path, fntype, function.has_function_return_type ()); - reference = address_expression (fndecl, ref_locus); + reference + = address_expression (fndecl, build_pointer_type (TREE_TYPE (fndecl)), + ref_locus); } void |