Ignore unsized types when trying to determine the size of a type

This commit is contained in:
Urgau 2024-02-14 19:12:19 +01:00
parent 502ce8287b
commit ddec8c5edc
2 changed files with 12 additions and 0 deletions

View File

@ -207,6 +207,13 @@ fn is_cast_to_bigger_memory_layout<'tcx>(
} }
let from_layout = cx.layout_of(*inner_start_ty).ok()?; let from_layout = cx.layout_of(*inner_start_ty).ok()?;
// if the type isn't sized, we bail out, instead of potentially giving
// the user a meaningless warning.
if from_layout.is_unsized() {
return None;
}
let alloc_layout = cx.layout_of(alloc_ty).ok()?; let alloc_layout = cx.layout_of(alloc_ty).ok()?;
let to_layout = cx.layout_of(*inner_end_ty).ok()?; let to_layout = cx.layout_of(*inner_end_ty).ok()?;

View File

@ -239,6 +239,11 @@ unsafe fn bigger_layout() {
//~^ ERROR casting references to a bigger memory layout //~^ ERROR casting references to a bigger memory layout
} }
{
let x: Box<dyn Send> = Box::new(0i32);
let _z = unsafe { &*(&*x as *const dyn Send as *const i32) };
}
unsafe fn from_ref(this: &i32) -> &i64 { unsafe fn from_ref(this: &i32) -> &i64 {
&*(this as *const i32 as *const i64) &*(this as *const i32 as *const i64)
} }