diff options
author | bors[bot] <26634292+bors[bot]@users.noreply.github.com> | 2022-05-18 14:50:31 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-05-18 14:50:31 +0000 |
commit | 9e61c6eb220cf54b3fcac3d3fe7a7f1f59bcc7ad (patch) | |
tree | eb502effa494d5446a8da49aca8ff8d54e49f9f1 /gcc/rust/backend/rust-compile-extern.h | |
parent | 8cad07cfd2244ad9a40027a4306b81b4553a4797 (diff) | |
parent | 4a4206c017654af7a3468690e4e21fdaf86bcb5c (diff) | |
download | gcc-9e61c6eb220cf54b3fcac3d3fe7a7f1f59bcc7ad.zip gcc-9e61c6eb220cf54b3fcac3d3fe7a7f1f59bcc7ad.tar.gz gcc-9e61c6eb220cf54b3fcac3d3fe7a7f1f59bcc7ad.tar.bz2 |
Merge #1250
1250: Support extern-blocks defined within blocks r=philberty a=philberty
This adds support for declaring extern blocks within blocks. So this adds
the missing name resolution visitor for the statement context. Then we
extract out a common extern block hir lowering function for both contexts.
The type resolution step needs to be updated to be like the code-generation
step so that we can solve these paths in a query rather than a top-down
approach but this is a known issue.
The final step was to support query-based compilation to extern functions.
Fixes #976
Co-authored-by: Philip Herron <philip.herron@embecosm.com>
Diffstat (limited to 'gcc/rust/backend/rust-compile-extern.h')
-rw-r--r-- | gcc/rust/backend/rust-compile-extern.h | 27 |
1 files changed, 22 insertions, 5 deletions
diff --git a/gcc/rust/backend/rust-compile-extern.h b/gcc/rust/backend/rust-compile-extern.h index 1987805..c24437d 100644 --- a/gcc/rust/backend/rust-compile-extern.h +++ b/gcc/rust/backend/rust-compile-extern.h @@ -29,11 +29,19 @@ class CompileExternItem : public HIRCompileBase, public HIR::HIRExternalItemVisitor { public: - static void compile (HIR::ExternalItem *item, Context *ctx, - TyTy::BaseType *concrete = nullptr) + static tree compile (HIR::ExternalItem *item, Context *ctx, + TyTy::BaseType *concrete = nullptr, + bool is_query_mode = false, + Location ref_locus = Location ()) { - CompileExternItem compiler (ctx, concrete); + CompileExternItem compiler (ctx, concrete, ref_locus); item->accept_vis (compiler); + + if (is_query_mode && compiler.reference == error_mark_node) + rust_internal_error_at (ref_locus, "failed to compile extern item: %s", + item->as_string ().c_str ()); + + return compiler.reference; } void visit (HIR::ExternalStaticItem &item) override @@ -58,6 +66,8 @@ public: item.get_locus ()); ctx->insert_var_decl (item.get_mappings ().get_hirid (), static_global); ctx->push_var (static_global); + + reference = ctx->get_backend ()->var_expression (static_global, ref_locus); } void visit (HIR::ExternalFunctionItem &function) override @@ -129,14 +139,21 @@ public: setup_abi_options (fndecl, fntype->get_abi ()); ctx->insert_function_decl (fntype, fndecl); + + reference + = address_expression (fndecl, build_pointer_type (TREE_TYPE (fndecl)), + ref_locus); } private: - CompileExternItem (Context *ctx, TyTy::BaseType *concrete) - : HIRCompileBase (ctx), concrete (concrete) + CompileExternItem (Context *ctx, TyTy::BaseType *concrete, Location ref_locus) + : HIRCompileBase (ctx), concrete (concrete), reference (error_mark_node), + ref_locus (ref_locus) {} TyTy::BaseType *concrete; + tree reference; + Location ref_locus; }; } // namespace Compile |