aboutsummaryrefslogtreecommitdiff
path: root/gcc/rust/backend/rust-compile-extern.h
diff options
context:
space:
mode:
authorPhilip Herron <philip.herron@embecosm.com>2022-05-16 17:09:45 +0100
committerPhilip Herron <philip.herron@embecosm.com>2022-05-17 11:18:31 +0100
commit4a4206c017654af7a3468690e4e21fdaf86bcb5c (patch)
tree4ddbcbcb3a61bc12b5025c9bf1ea8316cdb5b083 /gcc/rust/backend/rust-compile-extern.h
parente4213b9568ae8cb8a4e31326e0e78c79db0a99cc (diff)
downloadgcc-4a4206c017654af7a3468690e4e21fdaf86bcb5c.zip
gcc-4a4206c017654af7a3468690e4e21fdaf86bcb5c.tar.gz
gcc-4a4206c017654af7a3468690e4e21fdaf86bcb5c.tar.bz2
Support extern-blocks defined within blocks
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
Diffstat (limited to 'gcc/rust/backend/rust-compile-extern.h')
-rw-r--r--gcc/rust/backend/rust-compile-extern.h27
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