Skip to main content

rustc_codegen_ssa/
mono_item.rs

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                    // do not define this function; it will become a global assembly block
79                } 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}