1use rustc_hir::attrs::Linkage;
2use rustc_middle::middle::codegen_fn_attrs::CodegenFnAttrFlags;
3use rustc_middle::mir::mono::{MonoItem, MonoItemData, Visibility};
4use rustc_middle::ty::layout::HasTyCtxt;
5use tracing::debug;
6
7use crate::base;
8use crate::mir::naked_asm;
9use crate::traits::*;
10
11pub trait MonoItemExt<'a, 'tcx> {
12 fn define<Bx: BuilderMethods<'a, 'tcx>>(
13 &self,
14 cx: &'a mut Bx::CodegenCx,
15 cgu_name: &str,
16 item_data: MonoItemData,
17 );
18 fn predefine<Bx: BuilderMethods<'a, 'tcx>>(
19 &self,
20 cx: &'a mut Bx::CodegenCx,
21 cgu_name: &str,
22 linkage: Linkage,
23 visibility: Visibility,
24 );
25 fn to_raw_string(&self) -> String;
26}
27
28impl<'a, 'tcx: 'a> MonoItemExt<'a, 'tcx> for MonoItem<'tcx> {
29 fn define<Bx: BuilderMethods<'a, 'tcx>>(
30 &self,
31 cx: &'a mut Bx::CodegenCx,
32 cgu_name: &str,
33 item_data: MonoItemData,
34 ) {
35 {
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("event compiler/rustc_codegen_ssa/src/mono_item.rs:35",
"rustc_codegen_ssa::mono_item", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_codegen_ssa/src/mono_item.rs"),
::tracing_core::__macro_support::Option::Some(35u32),
::tracing_core::__macro_support::Option::Some("rustc_codegen_ssa::mono_item"),
::tracing_core::field::FieldSet::new(&["message"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::EVENT)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let enabled =
::tracing::Level::DEBUG <= ::tracing::level_filters::STATIC_MAX_LEVEL
&&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{
let interest = __CALLSITE.interest();
!interest.is_never() &&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest)
};
if enabled {
(|value_set: ::tracing::field::ValueSet|
{
let meta = __CALLSITE.metadata();
::tracing::Event::dispatch(meta, &value_set);
;
})({
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = __CALLSITE.metadata().fields().iter();
__CALLSITE.metadata().fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&format_args!("BEGIN IMPLEMENTING \'{0} ({1})\' in cgu {2}",
self, self.to_raw_string(), cgu_name) as &dyn Value))])
});
} else { ; }
};debug!("BEGIN IMPLEMENTING '{} ({})' in cgu {}", self, self.to_raw_string(), cgu_name);
36
37 match *self {
38 MonoItem::Static(def_id) => {
39 cx.codegen_static(def_id);
40 }
41 MonoItem::GlobalAsm(item_id) => {
42 base::codegen_global_asm(cx, item_id);
43 }
44 MonoItem::Fn(instance) => {
45 let flags = cx.tcx().codegen_instance_attrs(instance.def).flags;
46 if flags.contains(CodegenFnAttrFlags::NAKED) {
47 naked_asm::codegen_naked_asm::<Bx::CodegenCx>(cx, instance, item_data);
48 } else {
49 base::codegen_instance::<Bx>(cx, instance);
50 }
51 }
52 }
53
54 {
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("event compiler/rustc_codegen_ssa/src/mono_item.rs:54",
"rustc_codegen_ssa::mono_item", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_codegen_ssa/src/mono_item.rs"),
::tracing_core::__macro_support::Option::Some(54u32),
::tracing_core::__macro_support::Option::Some("rustc_codegen_ssa::mono_item"),
::tracing_core::field::FieldSet::new(&["message"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::EVENT)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let enabled =
::tracing::Level::DEBUG <= ::tracing::level_filters::STATIC_MAX_LEVEL
&&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{
let interest = __CALLSITE.interest();
!interest.is_never() &&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest)
};
if enabled {
(|value_set: ::tracing::field::ValueSet|
{
let meta = __CALLSITE.metadata();
::tracing::Event::dispatch(meta, &value_set);
;
})({
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = __CALLSITE.metadata().fields().iter();
__CALLSITE.metadata().fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&format_args!("END IMPLEMENTING \'{0} ({1})\' in cgu {2}",
self, self.to_raw_string(), cgu_name) as &dyn Value))])
});
} else { ; }
};debug!("END IMPLEMENTING '{} ({})' in cgu {}", self, self.to_raw_string(), cgu_name);
55 }
56
57 fn predefine<Bx: BuilderMethods<'a, 'tcx>>(
58 &self,
59 cx: &'a mut Bx::CodegenCx,
60 cgu_name: &str,
61 linkage: Linkage,
62 visibility: Visibility,
63 ) {
64 {
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("event compiler/rustc_codegen_ssa/src/mono_item.rs:64",
"rustc_codegen_ssa::mono_item", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_codegen_ssa/src/mono_item.rs"),
::tracing_core::__macro_support::Option::Some(64u32),
::tracing_core::__macro_support::Option::Some("rustc_codegen_ssa::mono_item"),
::tracing_core::field::FieldSet::new(&["message"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::EVENT)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let enabled =
::tracing::Level::DEBUG <= ::tracing::level_filters::STATIC_MAX_LEVEL
&&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{
let interest = __CALLSITE.interest();
!interest.is_never() &&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest)
};
if enabled {
(|value_set: ::tracing::field::ValueSet|
{
let meta = __CALLSITE.metadata();
::tracing::Event::dispatch(meta, &value_set);
;
})({
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = __CALLSITE.metadata().fields().iter();
__CALLSITE.metadata().fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&format_args!("BEGIN PREDEFINING \'{0} ({1})\' in cgu {2}",
self, self.to_raw_string(), cgu_name) as &dyn Value))])
});
} else { ; }
};debug!("BEGIN PREDEFINING '{} ({})' in cgu {}", self, self.to_raw_string(), cgu_name);
65
66 let symbol_name = self.symbol_name(cx.tcx()).name;
67
68 {
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("event compiler/rustc_codegen_ssa/src/mono_item.rs:68",
"rustc_codegen_ssa::mono_item", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_codegen_ssa/src/mono_item.rs"),
::tracing_core::__macro_support::Option::Some(68u32),
::tracing_core::__macro_support::Option::Some("rustc_codegen_ssa::mono_item"),
::tracing_core::field::FieldSet::new(&["message"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::EVENT)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let enabled =
::tracing::Level::DEBUG <= ::tracing::level_filters::STATIC_MAX_LEVEL
&&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{
let interest = __CALLSITE.interest();
!interest.is_never() &&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest)
};
if enabled {
(|value_set: ::tracing::field::ValueSet|
{
let meta = __CALLSITE.metadata();
::tracing::Event::dispatch(meta, &value_set);
;
})({
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = __CALLSITE.metadata().fields().iter();
__CALLSITE.metadata().fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&format_args!("symbol {0}",
symbol_name) as &dyn Value))])
});
} else { ; }
};debug!("symbol {symbol_name}");
69
70 match *self {
71 MonoItem::Static(def_id) => {
72 cx.predefine_static(def_id, linkage, visibility, symbol_name);
73 }
74 MonoItem::Fn(instance) => {
75 let attrs = cx.tcx().codegen_instance_attrs(instance.def);
76
77 if attrs.flags.contains(CodegenFnAttrFlags::NAKED) {
78 } else {
80 cx.predefine_fn(instance, linkage, visibility, symbol_name);
81 };
82 }
83 MonoItem::GlobalAsm(..) => {}
84 }
85
86 {
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("event compiler/rustc_codegen_ssa/src/mono_item.rs:86",
"rustc_codegen_ssa::mono_item", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_codegen_ssa/src/mono_item.rs"),
::tracing_core::__macro_support::Option::Some(86u32),
::tracing_core::__macro_support::Option::Some("rustc_codegen_ssa::mono_item"),
::tracing_core::field::FieldSet::new(&["message"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::EVENT)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let enabled =
::tracing::Level::DEBUG <= ::tracing::level_filters::STATIC_MAX_LEVEL
&&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{
let interest = __CALLSITE.interest();
!interest.is_never() &&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest)
};
if enabled {
(|value_set: ::tracing::field::ValueSet|
{
let meta = __CALLSITE.metadata();
::tracing::Event::dispatch(meta, &value_set);
;
})({
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = __CALLSITE.metadata().fields().iter();
__CALLSITE.metadata().fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&format_args!("END PREDEFINING \'{0} ({1})\' in cgu {2}",
self, self.to_raw_string(), cgu_name) as &dyn Value))])
});
} else { ; }
};debug!("END PREDEFINING '{} ({})' in cgu {}", self, self.to_raw_string(), cgu_name);
87 }
88
89 fn to_raw_string(&self) -> String {
90 match *self {
91 MonoItem::Fn(instance) => {
92 ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("Fn({0:?}, {1})", instance.def,
instance.args.as_ptr().addr()))
})format!("Fn({:?}, {})", instance.def, instance.args.as_ptr().addr())
93 }
94 MonoItem::Static(id) => ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("Static({0:?})", id))
})format!("Static({id:?})"),
95 MonoItem::GlobalAsm(id) => ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("GlobalAsm({0:?})", id))
})format!("GlobalAsm({id:?})"),
96 }
97 }
98}