Fix duplicate arcinner_layout_for_value_layout
calls
This commit is contained in:
parent
8006510ab0
commit
2a466466c7
2 changed files with 47 additions and 6 deletions
28
tests/codegen/issues/issue-111603.rs
Normal file
28
tests/codegen/issues/issue-111603.rs
Normal file
|
@ -0,0 +1,28 @@
|
|||
// compile-flags: -O
|
||||
|
||||
#![crate_type = "lib"]
|
||||
#![feature(get_mut_unchecked, new_uninit)]
|
||||
|
||||
use std::sync::Arc;
|
||||
|
||||
// CHECK-LABEL: @new_uninit
|
||||
#[no_mangle]
|
||||
pub fn new_uninit(x: u64) -> Arc<[u64; 1000]> {
|
||||
// CHECK: call alloc::sync::arcinner_layout_for_value_layout
|
||||
// CHECK-NOT: call alloc::sync::arcinner_layout_for_value_layout
|
||||
let mut arc = Arc::new_uninit();
|
||||
unsafe { Arc::get_mut_unchecked(&mut arc) }.write([x; 1000]);
|
||||
unsafe { arc.assume_init() }
|
||||
}
|
||||
|
||||
// CHECK-LABEL: @new_uninit_slice
|
||||
#[no_mangle]
|
||||
pub fn new_uninit_slice(x: u64) -> Arc<[u64]> {
|
||||
// CHECK: call alloc::sync::arcinner_layout_for_value_layout
|
||||
// CHECK-NOT: call alloc::sync::arcinner_layout_for_value_layout
|
||||
let mut arc = Arc::new_uninit_slice(1000);
|
||||
for elem in unsafe { Arc::get_mut_unchecked(&mut arc) } {
|
||||
elem.write(x);
|
||||
}
|
||||
unsafe { arc.assume_init() }
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue