rust/tests/codegen/box-maybe-uninit.rs

34 lines
1.2 KiB
Rust
Raw Normal View History

2018-09-20 13:57:25 -05:00
// compile-flags: -O
// min-llvm-version: 15.0
#![crate_type = "lib"]
2018-09-20 13:57:25 -05:00
use std::mem::MaybeUninit;
// Boxing a `MaybeUninit` value should not copy junk from the stack
#[no_mangle]
pub fn box_uninitialized() -> Box<MaybeUninit<usize>> {
// CHECK-LABEL: @box_uninitialized
// CHECK-NOT: store
2019-02-05 15:26:30 -06:00
// CHECK-NOT: alloca
// CHECK-NOT: memcpy
// CHECK-NOT: memset
2019-03-19 03:46:11 -05:00
Box::new(MaybeUninit::uninit())
2018-09-20 13:57:25 -05:00
}
2019-03-19 03:46:11 -05:00
// https://github.com/rust-lang/rust/issues/58201
#[no_mangle]
pub fn box_uninitialized2() -> Box<MaybeUninit<[usize; 1024 * 1024]>> {
// CHECK-LABEL: @box_uninitialized2
// CHECK-NOT: store
// CHECK-NOT: alloca
// CHECK-NOT: memcpy
// CHECK-NOT: memset
Box::new(MaybeUninit::uninit())
}
// Hide the `allocalign` attribute in the declaration of __rust_alloc
// from the CHECK-NOT above, and also verify the attributes got set reasonably.
// CHECK: declare {{(dso_local )?}}noalias noundef ptr @__rust_alloc(i{{[0-9]+}} noundef, i{{[0-9]+}} allocalign noundef) unnamed_addr [[RUST_ALLOC_ATTRS:#[0-9]+]]
// CHECK-DAG: attributes [[RUST_ALLOC_ATTRS]] = { {{.*}} allockind("alloc,uninitialized,aligned") allocsize(0) {{(uwtable )?}}"alloc-family"="__rust_alloc" {{.*}} }