rust/tests/mir-opt/pre-codegen/mem_replace.mem_replace.PreCodegen.after.mir

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

64 lines
2.4 KiB
Rust
Raw Normal View History

// MIR for `mem_replace` after PreCodegen
fn mem_replace(_1: &mut u32, _2: u32) -> u32 {
2023-06-06 08:47:00 -05:00
debug r => _1;
debug v => _2;
let mut _0: u32;
scope 1 (inlined std::mem::replace::<u32>) {
debug dest => _1;
debug src => _2;
scope 2 {
scope 3 {
2023-06-06 08:47:00 -05:00
debug result => _0;
2023-08-20 14:00:21 -05:00
scope 16 (inlined std::ptr::write::<u32>) {
2023-03-11 09:27:44 -06:00
debug dst => _1;
2023-06-06 08:47:00 -05:00
debug src => _2;
2023-08-20 14:00:21 -05:00
scope 17 {
}
}
}
2023-06-06 08:47:00 -05:00
scope 4 (inlined std::ptr::read::<u32>) {
2023-03-11 09:27:44 -06:00
debug src => _1;
scope 5 {
2023-08-20 14:00:21 -05:00
scope 6 (inlined std::ptr::read::runtime::<u32>) {
debug src => _1;
scope 7 (inlined intrinsics::is_aligned_and_not_null::<u32>) {
debug ptr => _1;
scope 8 (inlined ptr::const_ptr::<impl *const u32>::is_null) {
debug self => _1;
let mut _3: *const u8;
scope 9 {
scope 10 (inlined ptr::const_ptr::<impl *const T>::is_null::runtime_impl) {
debug ptr => _3;
scope 11 (inlined ptr::const_ptr::<impl *const u8>::addr) {
debug self => _3;
scope 12 {
scope 13 (inlined ptr::const_ptr::<impl *const u8>::cast::<()>) {
debug self => _3;
}
}
}
}
}
}
scope 14 (inlined ptr::const_ptr::<impl *const u32>::is_aligned) {
debug self => _1;
scope 15 (inlined align_of::<u32>) {
}
}
}
}
}
}
}
}
bb0: {
2023-08-20 14:00:21 -05:00
StorageLive(_3);
2023-03-11 09:27:44 -06:00
_0 = (*_1);
2023-08-20 14:00:21 -05:00
StorageDead(_3);
2023-03-11 09:27:44 -06:00
(*_1) = _2;
2023-06-06 08:47:00 -05:00
return;
}
}