aboutsummaryrefslogtreecommitdiff
path: root/gcc/rust/backend/rust-compile-extern.h
diff options
context:
space:
mode:
authorbors[bot] <26634292+bors[bot]@users.noreply.github.com>2022-05-18 14:50:31 +0000
committerGitHub <noreply@github.com>2022-05-18 14:50:31 +0000
commit9e61c6eb220cf54b3fcac3d3fe7a7f1f59bcc7ad (patch)
treeeb502effa494d5446a8da49aca8ff8d54e49f9f1 /gcc/rust/backend/rust-compile-extern.h
parent8cad07cfd2244ad9a40027a4306b81b4553a4797 (diff)
parent4a4206c017654af7a3468690e4e21fdaf86bcb5c (diff)
downloadgcc-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.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