2022-07-24 17:33:38 -04:00
|
|
|
#[cfg(feature="master")]
|
|
|
|
use gccjit::{VarAttribute, FnAttribute};
|
2020-05-10 10:54:30 -04:00
|
|
|
use rustc_codegen_ssa::traits::PreDefineMethods;
|
2022-07-24 17:33:38 -04:00
|
|
|
use rustc_hir::def_id::{DefId, LOCAL_CRATE};
|
2020-05-10 10:54:30 -04:00
|
|
|
use rustc_middle::middle::codegen_fn_attrs::CodegenFnAttrFlags;
|
|
|
|
use rustc_middle::mir::mono::{Linkage, Visibility};
|
2023-02-22 02:18:40 +00:00
|
|
|
use rustc_middle::ty::{self, Instance, TypeVisitableExt};
|
2021-09-28 09:18:27 -04:00
|
|
|
use rustc_middle::ty::layout::{FnAbiOf, LayoutOf};
|
2020-05-10 10:54:30 -04:00
|
|
|
|
2022-06-22 17:48:54 -04:00
|
|
|
use crate::attributes;
|
2020-05-10 10:54:30 -04:00
|
|
|
use crate::base;
|
|
|
|
use crate::context::CodegenCx;
|
|
|
|
use crate::type_of::LayoutGccExt;
|
|
|
|
|
|
|
|
impl<'gcc, 'tcx> PreDefineMethods<'tcx> for CodegenCx<'gcc, 'tcx> {
|
2022-07-24 17:33:38 -04:00
|
|
|
#[cfg_attr(not(feature="master"), allow(unused_variables))]
|
|
|
|
fn predefine_static(&self, def_id: DefId, _linkage: Linkage, visibility: Visibility, symbol_name: &str) {
|
2020-05-10 10:54:30 -04:00
|
|
|
let attrs = self.tcx.codegen_fn_attrs(def_id);
|
|
|
|
let instance = Instance::mono(self.tcx, def_id);
|
|
|
|
let ty = instance.ty(self.tcx, ty::ParamEnv::reveal_all());
|
2022-07-23 19:12:35 -04:00
|
|
|
let gcc_type = self.layout_of(ty).gcc_type(self);
|
2020-05-10 10:54:30 -04:00
|
|
|
|
|
|
|
let is_tls = attrs.flags.contains(CodegenFnAttrFlags::THREAD_LOCAL);
|
2021-09-26 12:20:02 -04:00
|
|
|
let global = self.define_global(symbol_name, gcc_type, is_tls, attrs.link_section);
|
2022-07-24 17:33:38 -04:00
|
|
|
#[cfg(feature="master")]
|
|
|
|
global.add_attribute(VarAttribute::Visibility(base::visibility_to_gcc(visibility)));
|
2020-05-10 10:54:30 -04:00
|
|
|
|
2022-07-24 17:33:38 -04:00
|
|
|
// TODO(antoyo): set linkage.
|
2020-05-10 10:54:30 -04:00
|
|
|
self.instances.borrow_mut().insert(instance, global);
|
|
|
|
}
|
|
|
|
|
2022-07-24 17:33:38 -04:00
|
|
|
#[cfg_attr(not(feature="master"), allow(unused_variables))]
|
|
|
|
fn predefine_fn(&self, instance: Instance<'tcx>, linkage: Linkage, visibility: Visibility, symbol_name: &str) {
|
2023-07-11 22:35:29 +01:00
|
|
|
assert!(!instance.args.has_infer());
|
2020-05-10 10:54:30 -04:00
|
|
|
|
2021-09-28 09:18:27 -04:00
|
|
|
let fn_abi = self.fn_abi_of_instance(instance, ty::List::empty());
|
2020-05-10 10:54:30 -04:00
|
|
|
self.linkage.set(base::linkage_to_gcc(linkage));
|
2023-01-08 11:42:00 -05:00
|
|
|
let decl = self.declare_fn(symbol_name, &fn_abi);
|
2020-05-10 10:54:30 -04:00
|
|
|
//let attrs = self.tcx.codegen_fn_attrs(instance.def_id());
|
|
|
|
|
2022-06-22 17:48:54 -04:00
|
|
|
attributes::from_fn_attrs(self, decl, instance);
|
|
|
|
|
2022-07-24 17:33:38 -04:00
|
|
|
// If we're compiling the compiler-builtins crate, e.g., the equivalent of
|
|
|
|
// compiler-rt, then we want to implicitly compile everything with hidden
|
|
|
|
// visibility as we're going to link this object all over the place but
|
|
|
|
// don't want the symbols to get exported.
|
|
|
|
if linkage != Linkage::Internal
|
|
|
|
&& linkage != Linkage::Private
|
|
|
|
&& self.tcx.is_compiler_builtins(LOCAL_CRATE)
|
|
|
|
{
|
|
|
|
#[cfg(feature="master")]
|
|
|
|
decl.add_attribute(FnAttribute::Visibility(gccjit::Visibility::Hidden));
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
#[cfg(feature="master")]
|
|
|
|
decl.add_attribute(FnAttribute::Visibility(base::visibility_to_gcc(visibility)));
|
|
|
|
}
|
|
|
|
|
2021-08-15 08:28:46 -04:00
|
|
|
// TODO(antoyo): call set_link_section() to allow initializing argc/argv.
|
|
|
|
// TODO(antoyo): set unique comdat.
|
|
|
|
// TODO(antoyo): use inline attribute from there in linkage.set() above.
|
2022-10-19 09:23:23 -04:00
|
|
|
|
|
|
|
self.functions.borrow_mut().insert(symbol_name.to_string(), decl);
|
|
|
|
self.function_instances.borrow_mut().insert(instance, unsafe { std::mem::transmute(decl) });
|
2020-05-10 10:54:30 -04:00
|
|
|
}
|
|
|
|
}
|