|  | //@ compile-flags: -Copt-level=3 | 
|  | #![crate_type = "lib"] | 
|  |  | 
|  | 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 | 
|  | // CHECK-NOT: alloca | 
|  | // CHECK-NOT: memcpy | 
|  | // CHECK-NOT: memset | 
|  | Box::new(MaybeUninit::uninit()) | 
|  | } | 
|  |  | 
|  | // 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()) | 
|  | } | 
|  |  | 
|  | #[repr(align(1024))] | 
|  | pub struct LotsaPadding(usize); | 
|  |  | 
|  | // Boxing a value with padding should not copy junk from the stack | 
|  | #[no_mangle] | 
|  | pub fn box_lotsa_padding() -> Box<LotsaPadding> { | 
|  | // CHECK-LABEL: @box_lotsa_padding | 
|  | // CHECK-NOT: alloca | 
|  | // CHECK-NOT: getelementptr | 
|  | // CHECK-NOT: memcpy | 
|  | // CHECK-NOT: memset | 
|  | Box::new(LotsaPadding(42)) | 
|  | } | 
|  |  | 
|  | // 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" {{.*}} } |