Skip to content

Commit 8d78f8e

Browse files
authored
Rollup merge of rust-lang#122203 - adpaco-aws:smir-intrinsic-name, r=celinval
Add `intrinsic_name` to get plain intrinsic name Add an `intrinsic_name` API to retrieve the plain intrinsic name. The plain name does not include type arguments (as `trimmed_name` does), which is more convenient to match with intrinsic symbols.
2 parents e6ba504 + 68fc922 commit 8d78f8e

File tree

4 files changed

+35
-1
lines changed

4 files changed

+35
-1
lines changed

compiler/rustc_smir/src/rustc_smir/context.rs

+10
Original file line numberDiff line numberDiff line change
@@ -587,6 +587,16 @@ impl<'tcx> Context for TablesWrapper<'tcx> {
587587
}
588588
}
589589

590+
/// Retrieve the plain intrinsic name of an instance.
591+
///
592+
/// This assumes that the instance is an intrinsic.
593+
fn intrinsic_name(&self, def: InstanceDef) -> Symbol {
594+
let tables = self.0.borrow_mut();
595+
let instance = tables.instances[def];
596+
let intrinsic = tables.tcx.intrinsic(instance.def_id()).unwrap();
597+
intrinsic.name.to_string()
598+
}
599+
590600
fn ty_layout(&self, ty: Ty) -> Result<Layout, Error> {
591601
let mut tables = self.0.borrow_mut();
592602
let tcx = tables.tcx;

compiler/stable_mir/src/compiler_interface.rs

+1
Original file line numberDiff line numberDiff line change
@@ -183,6 +183,7 @@ pub trait Context {
183183
fn vtable_allocation(&self, global_alloc: &GlobalAlloc) -> Option<AllocId>;
184184
fn krate(&self, def_id: DefId) -> Crate;
185185
fn instance_name(&self, def: InstanceDef, trimmed: bool) -> Symbol;
186+
fn intrinsic_name(&self, def: InstanceDef) -> Symbol;
186187

187188
/// Return information about the target machine.
188189
fn target_info(&self) -> MachineInfo;

compiler/stable_mir/src/mir/mono.rs

+11
Original file line numberDiff line numberDiff line change
@@ -90,6 +90,17 @@ impl Instance {
9090
with(|context| context.instance_name(self.def, true))
9191
}
9292

93+
/// Retrieve the plain intrinsic name of an instance if it's an intrinsic.
94+
///
95+
/// The plain name does not include type arguments (as `trimmed_name` does),
96+
/// which is more convenient to match with intrinsic symbols.
97+
pub fn intrinsic_name(&self) -> Option<Symbol> {
98+
match self.kind {
99+
InstanceKind::Intrinsic => Some(with(|context| context.intrinsic_name(self.def))),
100+
InstanceKind::Item | InstanceKind::Virtual { .. } | InstanceKind::Shim => None,
101+
}
102+
}
103+
93104
/// Resolve an instance starting from a function definition and generic arguments.
94105
pub fn resolve(def: FnDef, args: &GenericArgs) -> Result<Instance, crate::Error> {
95106
with(|context| {

tests/ui-fulldeps/stable-mir/check_defs.rs

+13-1
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,7 @@ extern crate stable_mir;
1919

2020
use std::assert_matches::assert_matches;
2121
use mir::{mono::Instance, TerminatorKind::*};
22+
use stable_mir::mir::mono::InstanceKind;
2223
use rustc_smir::rustc_internal;
2324
use stable_mir::ty::{RigidTy, TyKind, Ty, UintTy};
2425
use stable_mir::*;
@@ -35,9 +36,10 @@ fn test_stable_mir() -> ControlFlow<()> {
3536
assert_eq!(main_fn.trimmed_name(), "main");
3637

3738
let instances = get_instances(main_fn.body().unwrap());
38-
assert_eq!(instances.len(), 2);
39+
assert_eq!(instances.len(), 3);
3940
test_fn(instances[0], "from_u32", "std::char::from_u32", "core");
4041
test_fn(instances[1], "Vec::<u8>::new", "std::vec::Vec::<u8>::new", "alloc");
42+
test_fn(instances[2], "ctpop::<u8>", "std::intrinsics::ctpop::<u8>", "core");
4143
test_vec_new(instances[1]);
4244
ControlFlow::Continue(())
4345
}
@@ -48,6 +50,14 @@ fn test_fn(instance: Instance, expected_trimmed: &str, expected_qualified: &str,
4850
assert_eq!(&trimmed, expected_trimmed);
4951
assert_eq!(&qualified, expected_qualified);
5052

53+
if instance.kind == InstanceKind::Intrinsic {
54+
let intrinsic = instance.intrinsic_name().unwrap();
55+
let (trimmed_base, _trimmed_args) = trimmed.split_once("::").unwrap();
56+
assert_eq!(intrinsic, trimmed_base);
57+
return;
58+
}
59+
assert!(instance.intrinsic_name().is_none());
60+
5161
let item = CrateItem::try_from(instance).unwrap();
5262
let trimmed = item.trimmed_name();
5363
let qualified = item.name();
@@ -119,10 +129,12 @@ fn generate_input(path: &str) -> std::io::Result<()> {
119129
write!(
120130
file,
121131
r#"
132+
#![feature(core_intrinsics)]
122133
123134
fn main() {{
124135
let _c = core::char::from_u32(99);
125136
let _v = Vec::<u8>::new();
137+
let _i = std::intrinsics::ctpop::<u8>(0);
126138
}}
127139
"#
128140
)?;

0 commit comments

Comments
 (0)