From 246bf1f3077b329ccef58f251f8d81b56f29ac86 Mon Sep 17 00:00:00 2001
From: FedericoBruzzone
Date: Mon, 6 Jan 2025 11:39:07 +0100
Subject: [PATCH] Add `TooGeneric` variant to `LayoutError` and emit `Unknown`
one
- `check-pass` test for a MRE of #135020
- fail test for #135138
- switch to `TooGeneric` for checking CMSE fn signatures
- switch to `TooGeneric` for compute `SizeSkeleton` (for transmute)
- fix broken tests
---
.../rustc_const_eval/src/const_eval/error.rs | 2 +-
.../src/hir_ty_lowering/cmse.rs | 8 ++-
compiler/rustc_hir_typeck/src/intrinsicck.rs | 2 +-
compiler/rustc_middle/messages.ftl | 3 +
compiler/rustc_middle/src/error.rs | 3 +
compiler/rustc_middle/src/ty/layout.rs | 14 ++--
compiler/rustc_transmute/src/layout/tree.rs | 1 +
compiler/rustc_ty_utils/src/layout.rs | 69 ++++++++++++++-----
.../html/templates/type_layout.html | 16 +++--
tests/crashes/135020.rs | 11 ---
tests/rustdoc/type-layout.rs | 9 ++-
tests/ui/enum-discriminant/eval-error.rs | 2 +-
tests/ui/enum-discriminant/eval-error.stderr | 12 +++-
...te-instantiation-struct-tail-ice-114484.rs | 2 +-
.../layout/base-layout-is-sized-ice-123078.rs | 1 +
.../base-layout-is-sized-ice-123078.stderr | 14 +++-
tests/ui/layout/invalid-unsized-const-eval.rs | 1 +
.../layout/invalid-unsized-const-eval.stderr | 11 ++-
...nvalid-unsized-in-always-sized-tail.stderr | 18 ++++-
.../issue-unsized-tail-restatic-ice-122488.rs | 1 +
...ue-unsized-tail-restatic-ice-122488.stderr | 11 ++-
...utable-due-to-trivial-bounds-ice-135138.rs | 11 +++
...le-due-to-trivial-bounds-ice-135138.stderr | 9 +++
.../unexpected-unsized-field-issue-135020.rs | 7 ++
.../layout/unknown-when-no-type-parameter.rs | 14 ++++
.../unknown-when-no-type-parameter.stderr | 16 +++++
.../unknown-when-ptr-metadata-is-DST.rs | 12 ++++
.../unknown-when-ptr-metadata-is-DST.stderr | 9 +++
.../ice-struct-tail-normalization-113272.rs | 2 +-
29 files changed, 233 insertions(+), 58 deletions(-)
delete mode 100644 tests/crashes/135020.rs
create mode 100644 tests/ui/layout/uncomputable-due-to-trivial-bounds-ice-135138.rs
create mode 100644 tests/ui/layout/uncomputable-due-to-trivial-bounds-ice-135138.stderr
create mode 100644 tests/ui/layout/unexpected-unsized-field-issue-135020.rs
create mode 100644 tests/ui/layout/unknown-when-no-type-parameter.rs
create mode 100644 tests/ui/layout/unknown-when-no-type-parameter.stderr
create mode 100644 tests/ui/layout/unknown-when-ptr-metadata-is-DST.rs
create mode 100644 tests/ui/layout/unknown-when-ptr-metadata-is-DST.stderr
diff --git a/compiler/rustc_const_eval/src/const_eval/error.rs b/compiler/rustc_const_eval/src/const_eval/error.rs
index fee7287951d0a..cc21a18af3a09 100644
--- a/compiler/rustc_const_eval/src/const_eval/error.rs
+++ b/compiler/rustc_const_eval/src/const_eval/error.rs
@@ -140,7 +140,7 @@ where
// Don't emit a new diagnostic for these errors, they are already reported elsewhere or
// should remain silent.
err_inval!(AlreadyReported(info)) => ErrorHandled::Reported(info, span),
- err_inval!(Layout(LayoutError::Unknown(_))) | err_inval!(TooGeneric) => {
+ err_inval!(Layout(LayoutError::TooGeneric(_))) | err_inval!(TooGeneric) => {
ErrorHandled::TooGeneric(span)
}
err_inval!(Layout(LayoutError::ReferencesError(guar))) => {
diff --git a/compiler/rustc_hir_analysis/src/hir_ty_lowering/cmse.rs b/compiler/rustc_hir_analysis/src/hir_ty_lowering/cmse.rs
index 394719314612e..4c8f2735b9795 100644
--- a/compiler/rustc_hir_analysis/src/hir_ty_lowering/cmse.rs
+++ b/compiler/rustc_hir_analysis/src/hir_ty_lowering/cmse.rs
@@ -201,7 +201,7 @@ fn should_emit_generic_error<'tcx>(abi: ExternAbi, layout_err: &'tcx LayoutError
use LayoutError::*;
match layout_err {
- Unknown(ty) => {
+ TooGeneric(ty) => {
match abi {
ExternAbi::CCmseNonSecureCall => {
// prevent double reporting of this error
@@ -211,7 +211,11 @@ fn should_emit_generic_error<'tcx>(abi: ExternAbi, layout_err: &'tcx LayoutError
_ => bug!("invalid ABI: {abi}"),
}
}
- SizeOverflow(..) | NormalizationFailure(..) | ReferencesError(..) | Cycle(..) => {
+ Unknown(..)
+ | SizeOverflow(..)
+ | NormalizationFailure(..)
+ | ReferencesError(..)
+ | Cycle(..) => {
false // not our job to report these
}
}
diff --git a/compiler/rustc_hir_typeck/src/intrinsicck.rs b/compiler/rustc_hir_typeck/src/intrinsicck.rs
index f4929aae59901..54e9e699353fa 100644
--- a/compiler/rustc_hir_typeck/src/intrinsicck.rs
+++ b/compiler/rustc_hir_typeck/src/intrinsicck.rs
@@ -122,7 +122,7 @@ impl<'a, 'tcx> FnCtxt<'a, 'tcx> {
format!("generic size {size}")
}
}
- Err(LayoutError::Unknown(bad)) => {
+ Err(LayoutError::TooGeneric(bad)) => {
if *bad == ty {
"this type does not have a fixed size".to_owned()
} else {
diff --git a/compiler/rustc_middle/messages.ftl b/compiler/rustc_middle/messages.ftl
index 5dd85978f007f..8dc529b4d7a21 100644
--- a/compiler/rustc_middle/messages.ftl
+++ b/compiler/rustc_middle/messages.ftl
@@ -100,6 +100,8 @@ middle_strict_coherence_needs_negative_coherence =
to use `strict_coherence` on this trait, the `with_negative_coherence` feature must be enabled
.label = due to this attribute
+middle_too_generic = `{$ty}` does not have a fixed size
+
middle_type_length_limit = reached the type-length limit while instantiating `{$shrunk}`
middle_unknown_layout =
@@ -107,4 +109,5 @@ middle_unknown_layout =
middle_values_too_big =
values of the type `{$ty}` are too big for the target architecture
+
middle_written_to_path = the full type name has been written to '{$path}'
diff --git a/compiler/rustc_middle/src/error.rs b/compiler/rustc_middle/src/error.rs
index 6300d856393c6..b0187a1848cf1 100644
--- a/compiler/rustc_middle/src/error.rs
+++ b/compiler/rustc_middle/src/error.rs
@@ -129,6 +129,9 @@ pub enum LayoutError<'tcx> {
#[diag(middle_unknown_layout)]
Unknown { ty: Ty<'tcx> },
+ #[diag(middle_too_generic)]
+ TooGeneric { ty: Ty<'tcx> },
+
#[diag(middle_values_too_big)]
Overflow { ty: Ty<'tcx> },
diff --git a/compiler/rustc_middle/src/ty/layout.rs b/compiler/rustc_middle/src/ty/layout.rs
index 1e67cdfc32a9b..0d41a1d7dbfba 100644
--- a/compiler/rustc_middle/src/ty/layout.rs
+++ b/compiler/rustc_middle/src/ty/layout.rs
@@ -231,6 +231,7 @@ impl fmt::Display for ValidityRequirement {
pub enum LayoutError<'tcx> {
Unknown(Ty<'tcx>),
SizeOverflow(Ty<'tcx>),
+ TooGeneric(Ty<'tcx>),
NormalizationFailure(Ty<'tcx>, NormalizationError<'tcx>),
ReferencesError(ErrorGuaranteed),
Cycle(ErrorGuaranteed),
@@ -244,6 +245,7 @@ impl<'tcx> LayoutError<'tcx> {
match self {
Unknown(_) => middle_unknown_layout,
SizeOverflow(_) => middle_values_too_big,
+ TooGeneric(_) => middle_too_generic,
NormalizationFailure(_, _) => middle_cannot_be_normalized,
Cycle(_) => middle_cycle,
ReferencesError(_) => middle_layout_references_error,
@@ -257,6 +259,7 @@ impl<'tcx> LayoutError<'tcx> {
match self {
Unknown(ty) => E::Unknown { ty },
SizeOverflow(ty) => E::Overflow { ty },
+ TooGeneric(ty) => E::TooGeneric { ty },
NormalizationFailure(ty, e) => {
E::NormalizationFailure { ty, failure_ty: e.get_type_for_failure() }
}
@@ -272,6 +275,9 @@ impl<'tcx> fmt::Display for LayoutError<'tcx> {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
match *self {
LayoutError::Unknown(ty) => write!(f, "the type `{ty}` has an unknown layout"),
+ LayoutError::TooGeneric(ty) => {
+ write!(f, "`{ty}` does not have a fixed size")
+ }
LayoutError::SizeOverflow(ty) => {
write!(f, "values of the type `{ty}` are too big for the target architecture")
}
@@ -350,10 +356,11 @@ impl<'tcx> SizeSkeleton<'tcx> {
return Err(tcx.arena.alloc(LayoutError::Unknown(ty)));
}
}
- Err(err @ LayoutError::Unknown(_)) => err,
+ Err(err @ LayoutError::TooGeneric(_)) => err,
// We can't extract SizeSkeleton info from other layout errors
Err(
e @ LayoutError::Cycle(_)
+ | e @ LayoutError::Unknown(_)
| e @ LayoutError::SizeOverflow(_)
| e @ LayoutError::NormalizationFailure(..)
| e @ LayoutError::ReferencesError(_),
@@ -413,10 +420,9 @@ impl<'tcx> SizeSkeleton<'tcx> {
// Alignment is unchanged by arrays.
return Ok(SizeSkeleton::Known(Size::from_bytes(size), a));
}
- Err(tcx.arena.alloc(LayoutError::Unknown(ty)))
+ Err(err)
}
- SizeSkeleton::Pointer { .. } => Err(err),
- SizeSkeleton::Generic(_) => Err(tcx.arena.alloc(LayoutError::Unknown(ty))),
+ SizeSkeleton::Pointer { .. } | SizeSkeleton::Generic(_) => Err(err),
}
}
diff --git a/compiler/rustc_transmute/src/layout/tree.rs b/compiler/rustc_transmute/src/layout/tree.rs
index 6ce9969aefe90..b00585d292212 100644
--- a/compiler/rustc_transmute/src/layout/tree.rs
+++ b/compiler/rustc_transmute/src/layout/tree.rs
@@ -197,6 +197,7 @@ pub(crate) mod rustc {
match err {
LayoutError::Unknown(..)
| LayoutError::ReferencesError(..)
+ | LayoutError::TooGeneric(..)
| LayoutError::NormalizationFailure(..) => Self::UnknownLayout,
LayoutError::SizeOverflow(..) => Self::SizeOverflow,
LayoutError::Cycle(err) => Self::TypeError(*err),
diff --git a/compiler/rustc_ty_utils/src/layout.rs b/compiler/rustc_ty_utils/src/layout.rs
index 17be0bd0ab9e1..a04c753611831 100644
--- a/compiler/rustc_ty_utils/src/layout.rs
+++ b/compiler/rustc_ty_utils/src/layout.rs
@@ -104,14 +104,12 @@ fn map_error<'tcx>(
// This is sometimes not a compile error if there are trivially false where clauses.
// See `tests/ui/layout/trivial-bounds-sized.rs` for an example.
assert!(field.layout.is_unsized(), "invalid layout error {err:#?}");
- if !field.ty.is_sized(cx.tcx(), cx.typing_env) {
- let guar = cx.tcx().dcx().delayed_bug(format!(
+ if cx.typing_env.param_env.caller_bounds().is_empty() {
+ cx.tcx().dcx().delayed_bug(format!(
"encountered unexpected unsized field in layout of {ty:?}: {field:#?}"
));
- LayoutError::ReferencesError(guar)
- } else {
- LayoutError::Unknown(ty)
}
+ LayoutError::Unknown(ty)
}
LayoutCalculatorError::EmptyUnion => {
// This is always a compile error.
@@ -146,6 +144,35 @@ fn univariant_uninterned<'tcx>(
cx.calc.univariant(fields, repr, kind).map_err(|err| map_error(cx, ty, err))
}
+fn validate_const_with_value<'tcx>(
+ const_: ty::Const<'tcx>,
+ ty: Ty<'tcx>,
+ cx: &LayoutCx<'tcx>,
+) -> Result, &'tcx LayoutError<'tcx>> {
+ match const_.kind() {
+ ty::ConstKind::Value(..) => Ok(const_),
+ ty::ConstKind::Error(guar) => {
+ return Err(error(cx, LayoutError::ReferencesError(guar)));
+ }
+ ty::ConstKind::Param(_) | ty::ConstKind::Expr(_) => {
+ if !const_.has_param() {
+ bug!("no generic type found in the type: {ty:?}");
+ }
+ return Err(error(cx, LayoutError::TooGeneric(ty)));
+ }
+ ty::ConstKind::Unevaluated(_) => {
+ if !const_.has_param() {
+ return Err(error(cx, LayoutError::Unknown(ty)));
+ } else {
+ return Err(error(cx, LayoutError::TooGeneric(ty)));
+ }
+ }
+ ty::ConstKind::Infer(_) | ty::ConstKind::Bound(..) | ty::ConstKind::Placeholder(_) => {
+ bug!("unexpected type: {ty:?}");
+ }
+ }
+}
+
fn layout_of_uncached<'tcx>(
cx: &LayoutCx<'tcx>,
ty: Ty<'tcx>,
@@ -182,12 +209,13 @@ fn layout_of_uncached<'tcx>(
&mut layout.backend_repr
{
if let Some(start) = start {
- scalar.valid_range_mut().start = start
- .try_to_bits(tcx, cx.typing_env)
- .ok_or_else(|| error(cx, LayoutError::Unknown(ty)))?;
+ scalar.valid_range_mut().start =
+ validate_const_with_value(start, ty, cx)?
+ .try_to_bits(tcx, cx.typing_env)
+ .ok_or_else(|| error(cx, LayoutError::Unknown(ty)))?;
}
if let Some(end) = end {
- let mut end = end
+ let mut end = validate_const_with_value(end, ty, cx)?
.try_to_bits(tcx, cx.typing_env)
.ok_or_else(|| error(cx, LayoutError::Unknown(ty)))?;
if !include_end {
@@ -319,17 +347,13 @@ fn layout_of_uncached<'tcx>(
}
// Arrays and slices.
- ty::Array(element, mut count) => {
- if count.has_aliases() {
- count = tcx.normalize_erasing_regions(cx.typing_env, count);
- if count.has_aliases() {
- return Err(error(cx, LayoutError::Unknown(ty)));
- }
- }
-
- let count = count
+ ty::Array(element, count) => {
+ let count = validate_const_with_value(count, ty, cx)?
+ .to_valtree()
+ .0
.try_to_target_usize(tcx)
.ok_or_else(|| error(cx, LayoutError::Unknown(ty)))?;
+
let element = cx.layout_of(element)?;
let size = element
.size
@@ -687,6 +711,9 @@ fn layout_of_uncached<'tcx>(
// Types with no meaningful known layout.
ty::Alias(..) => {
+ if ty.has_param() {
+ return Err(error(cx, LayoutError::TooGeneric(ty)));
+ }
// NOTE(eddyb) `layout_of` query should've normalized these away,
// if that was possible, so there's no reason to try again here.
return Err(error(cx, LayoutError::Unknown(ty)));
@@ -696,7 +723,11 @@ fn layout_of_uncached<'tcx>(
bug!("Layout::compute: unexpected type `{}`", ty)
}
- ty::Placeholder(..) | ty::Param(_) => {
+ ty::Param(_) => {
+ return Err(error(cx, LayoutError::TooGeneric(ty)));
+ }
+
+ ty::Placeholder(..) => {
return Err(error(cx, LayoutError::Unknown(ty)));
}
})
diff --git a/src/librustdoc/html/templates/type_layout.html b/src/librustdoc/html/templates/type_layout.html
index aee96fb8c417e..9c62826ccc2e3 100644
--- a/src/librustdoc/html/templates/type_layout.html
+++ b/src/librustdoc/html/templates/type_layout.html
@@ -28,13 +28,11 @@
{# #}
{% endfor %}
{% endif %}
- {# This kind of layout error can occur with valid code, e.g. if you try to
- get the layout of a generic type such as `Vec`. #}
+ {# This kind of layout error can occur with valid code, for example
+ if there are trivial bounds: `struct Foo(str, str) where str: Sized;`. #}
{% when Err(LayoutError::Unknown(_)) %}
{# #}
- Note: Unable to compute type layout, {#+ #}
- possibly due to this type having generic parameters. {#+ #}
- Layout can only be computed for concrete, fully-instantiated types. {# #}
+ Note: Unable to compute type layout. {# #}
{# This kind of error probably can't happen with valid code, but we don't
want to panic and prevent the docs from building, so we just let the
@@ -44,6 +42,14 @@
{# #}
Note: Encountered an error during type layout; {#+ #}
the type was too big. {# #}
+ {# This kind of layout error can occur with valid code, e.g. if you try to
+ get the layout of a generic type such as `Vec`. #}
+ {% when Err(LayoutError::TooGeneric(_)) %}
+
{# #}
+ Note: Unable to compute type layout, {#+ #}
+ possibly due to this type having generic parameters. {#+ #}
+ Layout can only be computed for concrete, fully-instantiated types. {# #}
+
{% when Err(LayoutError::ReferencesError(_)) %}
{# #}
Note: Encountered an error during type layout; {#+ #}
diff --git a/tests/crashes/135020.rs b/tests/crashes/135020.rs
deleted file mode 100644
index b44056eb3af30..0000000000000
--- a/tests/crashes/135020.rs
+++ /dev/null
@@ -1,11 +0,0 @@
-//@ known-bug: #135020
-
-pub fn problem_thingy(items: &mut impl Iterator) {
- let mut peeker = items.peekable();
- match peeker.peek() {
- Some(_) => (),
- None => return (),
- }
-}
-
-pub fn main() {}
diff --git a/tests/rustdoc/type-layout.rs b/tests/rustdoc/type-layout.rs
index 1e462210cba21..5f34c8b99e0ff 100644
--- a/tests/rustdoc/type-layout.rs
+++ b/tests/rustdoc/type-layout.rs
@@ -37,7 +37,8 @@ pub struct Y(u8);
pub struct Z;
// We can't compute layout for generic types.
-//@ hasraw type_layout/struct.Generic.html 'Unable to compute type layout, possibly due to this type having generic parameters'
+//@ hasraw type_layout/struct.Generic.html 'Unable to compute type layout, possibly due to this type having generic parameters.'
+//@ hasraw type_layout/struct.Generic.html 'Layout can only be computed for concrete, fully-instantiated types.'
//@ !hasraw - 'Size: '
pub struct Generic(T);
@@ -91,3 +92,9 @@ pub enum Uninhabited {}
//@ hasraw type_layout/struct.Uninhabited2.html 'Size: '
//@ hasraw - '8 bytes (uninhabited)'
pub struct Uninhabited2(std::convert::Infallible, u64);
+
+pub trait Project { type Assoc; }
+// We can't compute layout. A `LayoutError::Unknown` is returned.
+//@ hasraw type_layout/struct.Unknown.html 'Unable to compute type layout.'
+//@ !hasraw - 'Size: '
+pub struct Unknown(<() as Project>::Assoc) where for<'a> (): Project;
diff --git a/tests/ui/enum-discriminant/eval-error.rs b/tests/ui/enum-discriminant/eval-error.rs
index f2c3b58162765..08b71d52a8b03 100644
--- a/tests/ui/enum-discriminant/eval-error.rs
+++ b/tests/ui/enum-discriminant/eval-error.rs
@@ -6,7 +6,7 @@ union Foo {
enum Bar {
Boo = {
- let _: Option = None;
+ let _: Option = None; //~ ERROR evaluation of constant value failed
0
},
}
diff --git a/tests/ui/enum-discriminant/eval-error.stderr b/tests/ui/enum-discriminant/eval-error.stderr
index 0f12308de3c1c..6bec2c8b420f7 100644
--- a/tests/ui/enum-discriminant/eval-error.stderr
+++ b/tests/ui/enum-discriminant/eval-error.stderr
@@ -45,7 +45,13 @@ help: wrap the field type in `ManuallyDrop<...>`
LL | a: std::mem::ManuallyDrop,
| +++++++++++++++++++++++ +
-error: aborting due to 4 previous errors
+error[E0080]: evaluation of constant value failed
+ --> $DIR/eval-error.rs:9:30
+ |
+LL | let _: Option = None;
+ | ^^^^ the type `Foo` has an unknown layout
+
+error: aborting due to 5 previous errors
-Some errors have detailed explanations: E0277, E0517, E0740.
-For more information about an error, try `rustc --explain E0277`.
+Some errors have detailed explanations: E0080, E0277, E0517, E0740.
+For more information about an error, try `rustc --explain E0080`.
diff --git a/tests/ui/infinite/infinite-instantiation-struct-tail-ice-114484.rs b/tests/ui/infinite/infinite-instantiation-struct-tail-ice-114484.rs
index 410862c532624..e28b8f373dabb 100644
--- a/tests/ui/infinite/infinite-instantiation-struct-tail-ice-114484.rs
+++ b/tests/ui/infinite/infinite-instantiation-struct-tail-ice-114484.rs
@@ -24,7 +24,7 @@ impl VirtualWrapper {
impl MyTrait for VirtualWrapper {
fn virtualize(&self) -> &dyn MyTrait {
unsafe { virtualize_my_trait(L, self) }
- // unsafe { virtualize_my_trait(L, &self.0) } // <-- this code fixes the problem
+ // unsafe { virtualize_my_trait(L, &self.0) } // <-- this code fixes the problem
}
}
diff --git a/tests/ui/layout/base-layout-is-sized-ice-123078.rs b/tests/ui/layout/base-layout-is-sized-ice-123078.rs
index 15f11145f845e..b1c33e1507551 100644
--- a/tests/ui/layout/base-layout-is-sized-ice-123078.rs
+++ b/tests/ui/layout/base-layout-is-sized-ice-123078.rs
@@ -8,6 +8,7 @@ struct S {
}
const C: S = unsafe { std::mem::transmute(()) };
+//~^ ERROR cannot transmute between types of different sizes, or dependently-sized types
const _: [(); {
C;
0
diff --git a/tests/ui/layout/base-layout-is-sized-ice-123078.stderr b/tests/ui/layout/base-layout-is-sized-ice-123078.stderr
index 9181368533a46..d8743d4e6d63b 100644
--- a/tests/ui/layout/base-layout-is-sized-ice-123078.stderr
+++ b/tests/ui/layout/base-layout-is-sized-ice-123078.stderr
@@ -16,6 +16,16 @@ help: the `Box` type always has a statically known size and allocates its conten
LL | a: Box<[u8]>,
| ++++ +
-error: aborting due to 1 previous error
+error[E0512]: cannot transmute between types of different sizes, or dependently-sized types
+ --> $DIR/base-layout-is-sized-ice-123078.rs:10:23
+ |
+LL | const C: S = unsafe { std::mem::transmute(()) };
+ | ^^^^^^^^^^^^^^^^^^^
+ |
+ = note: source type: `()` (0 bits)
+ = note: target type: `S` (the type `S` has an unknown layout)
+
+error: aborting due to 2 previous errors
-For more information about this error, try `rustc --explain E0277`.
+Some errors have detailed explanations: E0277, E0512.
+For more information about an error, try `rustc --explain E0277`.
diff --git a/tests/ui/layout/invalid-unsized-const-eval.rs b/tests/ui/layout/invalid-unsized-const-eval.rs
index 2dec0b0faacf2..1f664d30055d6 100644
--- a/tests/ui/layout/invalid-unsized-const-eval.rs
+++ b/tests/ui/layout/invalid-unsized-const-eval.rs
@@ -10,5 +10,6 @@ struct LazyLock {
}
static EMPTY_SET: LazyLock = todo!();
+//~^ ERROR could not evaluate static initializer
fn main() {}
diff --git a/tests/ui/layout/invalid-unsized-const-eval.stderr b/tests/ui/layout/invalid-unsized-const-eval.stderr
index bf65782b7a805..a434ca9b2c7cf 100644
--- a/tests/ui/layout/invalid-unsized-const-eval.stderr
+++ b/tests/ui/layout/invalid-unsized-const-eval.stderr
@@ -7,6 +7,13 @@ LL | data: (dyn Sync, ()),
= help: the trait `Sized` is not implemented for `(dyn Sync + 'static)`
= note: only the last element of a tuple may have a dynamically sized type
-error: aborting due to 1 previous error
+error[E0080]: could not evaluate static initializer
+ --> $DIR/invalid-unsized-const-eval.rs:12:1
+ |
+LL | static EMPTY_SET: LazyLock = todo!();
+ | ^^^^^^^^^^^^^^^^^^^^^^^^^^ the type `(dyn Sync, ())` has an unknown layout
+
+error: aborting due to 2 previous errors
-For more information about this error, try `rustc --explain E0277`.
+Some errors have detailed explanations: E0080, E0277.
+For more information about an error, try `rustc --explain E0080`.
diff --git a/tests/ui/layout/invalid-unsized-in-always-sized-tail.stderr b/tests/ui/layout/invalid-unsized-in-always-sized-tail.stderr
index 3f565d6ee5ba8..f54e97e2a5c76 100644
--- a/tests/ui/layout/invalid-unsized-in-always-sized-tail.stderr
+++ b/tests/ui/layout/invalid-unsized-in-always-sized-tail.stderr
@@ -18,6 +18,20 @@ LL | struct MySlice(T);
| |
| this could be changed to `T: ?Sized`...
-error: aborting due to 1 previous error
+error[E0080]: could not evaluate static initializer
+ --> $SRC_DIR/core/src/mem/mod.rs:LL:COL
+ |
+ = note: the type `MySlice<[bool]>` has an unknown layout
+ |
+note: inside `align_of::`
+ --> $SRC_DIR/core/src/mem/mod.rs:LL:COL
+note: inside `CHECK`
+ --> $DIR/invalid-unsized-in-always-sized-tail.rs:15:28
+ |
+LL | static CHECK: () = assert!(align_of::() == 1);
+ | ^^^^^^^^^^^^^^^^
+
+error: aborting due to 2 previous errors
-For more information about this error, try `rustc --explain E0277`.
+Some errors have detailed explanations: E0080, E0277.
+For more information about an error, try `rustc --explain E0080`.
diff --git a/tests/ui/layout/issue-unsized-tail-restatic-ice-122488.rs b/tests/ui/layout/issue-unsized-tail-restatic-ice-122488.rs
index 96c993035ef18..f84c10d8e5c03 100644
--- a/tests/ui/layout/issue-unsized-tail-restatic-ice-122488.rs
+++ b/tests/ui/layout/issue-unsized-tail-restatic-ice-122488.rs
@@ -6,5 +6,6 @@ struct ArenaSet::Target>(V, U);
//~^ ERROR the size for values of type `V` cannot be known at compilation time
const DATA: *const ArenaSet> = std::ptr::null_mut();
+//~^ ERROR evaluation of constant value failed
pub fn main() {}
diff --git a/tests/ui/layout/issue-unsized-tail-restatic-ice-122488.stderr b/tests/ui/layout/issue-unsized-tail-restatic-ice-122488.stderr
index f39cb29868af5..220951fab86f8 100644
--- a/tests/ui/layout/issue-unsized-tail-restatic-ice-122488.stderr
+++ b/tests/ui/layout/issue-unsized-tail-restatic-ice-122488.stderr
@@ -22,6 +22,13 @@ help: the `Box` type always has a statically known size and allocates its conten
LL | struct ArenaSet::Target>(Box, U);
| ++++ +
-error: aborting due to 1 previous error
+error[E0080]: evaluation of constant value failed
+ --> $DIR/issue-unsized-tail-restatic-ice-122488.rs:8:1
+ |
+LL | const DATA: *const ArenaSet> = std::ptr::null_mut();
+ | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the type `ArenaSet, [u8]>` has an unknown layout
+
+error: aborting due to 2 previous errors
-For more information about this error, try `rustc --explain E0277`.
+Some errors have detailed explanations: E0080, E0277.
+For more information about an error, try `rustc --explain E0080`.
diff --git a/tests/ui/layout/uncomputable-due-to-trivial-bounds-ice-135138.rs b/tests/ui/layout/uncomputable-due-to-trivial-bounds-ice-135138.rs
new file mode 100644
index 0000000000000..91280e49dcd7e
--- /dev/null
+++ b/tests/ui/layout/uncomputable-due-to-trivial-bounds-ice-135138.rs
@@ -0,0 +1,11 @@
+#![feature(trivial_bounds)]
+
+fn return_str()
+where
+ str: Sized,
+{
+ [(); { let _a: Option = None; 0 }];
+ //~^ ERROR evaluation of constant value failed
+}
+
+fn main() {}
diff --git a/tests/ui/layout/uncomputable-due-to-trivial-bounds-ice-135138.stderr b/tests/ui/layout/uncomputable-due-to-trivial-bounds-ice-135138.stderr
new file mode 100644
index 0000000000000..6c7c51db8df7f
--- /dev/null
+++ b/tests/ui/layout/uncomputable-due-to-trivial-bounds-ice-135138.stderr
@@ -0,0 +1,9 @@
+error[E0080]: evaluation of constant value failed
+ --> $DIR/uncomputable-due-to-trivial-bounds-ice-135138.rs:7:16
+ |
+LL | [(); { let _a: Option = None; 0 }];
+ | ^^ the type `Option` has an unknown layout
+
+error: aborting due to 1 previous error
+
+For more information about this error, try `rustc --explain E0080`.
diff --git a/tests/ui/layout/unexpected-unsized-field-issue-135020.rs b/tests/ui/layout/unexpected-unsized-field-issue-135020.rs
new file mode 100644
index 0000000000000..c81d037e510f2
--- /dev/null
+++ b/tests/ui/layout/unexpected-unsized-field-issue-135020.rs
@@ -0,0 +1,7 @@
+//@ check-pass
+
+fn problem_thingy(items: &mut impl Iterator) {
+ items.peekable();
+}
+
+fn main() {}
diff --git a/tests/ui/layout/unknown-when-no-type-parameter.rs b/tests/ui/layout/unknown-when-no-type-parameter.rs
new file mode 100644
index 0000000000000..94c32cf262f2a
--- /dev/null
+++ b/tests/ui/layout/unknown-when-no-type-parameter.rs
@@ -0,0 +1,14 @@
+#![feature(trivial_bounds)]
+
+//@ error-pattern: error[E0080]: evaluation of constant value failed
+//@ error-pattern: the type `<() as Project>::Assoc` has an unknown layout
+
+trait Project {
+ type Assoc;
+}
+
+fn foo() where (): Project {
+ [(); size_of::<<() as Project>::Assoc>()];
+}
+
+fn main() {}
diff --git a/tests/ui/layout/unknown-when-no-type-parameter.stderr b/tests/ui/layout/unknown-when-no-type-parameter.stderr
new file mode 100644
index 0000000000000..d0456e2b3293b
--- /dev/null
+++ b/tests/ui/layout/unknown-when-no-type-parameter.stderr
@@ -0,0 +1,16 @@
+error[E0080]: evaluation of constant value failed
+ --> $SRC_DIR/core/src/mem/mod.rs:LL:COL
+ |
+ = note: the type `<() as Project>::Assoc` has an unknown layout
+ |
+note: inside `std::mem::size_of::<<() as Project>::Assoc>`
+ --> $SRC_DIR/core/src/mem/mod.rs:LL:COL
+note: inside `foo::{constant#0}`
+ --> $DIR/unknown-when-no-type-parameter.rs:11:10
+ |
+LL | [(); size_of::<<() as Project>::Assoc>()];
+ | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+error: aborting due to 1 previous error
+
+For more information about this error, try `rustc --explain E0080`.
diff --git a/tests/ui/layout/unknown-when-ptr-metadata-is-DST.rs b/tests/ui/layout/unknown-when-ptr-metadata-is-DST.rs
new file mode 100644
index 0000000000000..973235fe65afc
--- /dev/null
+++ b/tests/ui/layout/unknown-when-ptr-metadata-is-DST.rs
@@ -0,0 +1,12 @@
+#![feature(ptr_metadata)]
+#![feature(trivial_bounds)]
+
+fn return_str()
+where
+ str: std::ptr::Pointee,
+{
+ [(); { let _a: Option<&str> = None; 0 }];
+ //~^ ERROR evaluation of constant value failed
+}
+
+fn main() {}
diff --git a/tests/ui/layout/unknown-when-ptr-metadata-is-DST.stderr b/tests/ui/layout/unknown-when-ptr-metadata-is-DST.stderr
new file mode 100644
index 0000000000000..68bba2e967826
--- /dev/null
+++ b/tests/ui/layout/unknown-when-ptr-metadata-is-DST.stderr
@@ -0,0 +1,9 @@
+error[E0080]: evaluation of constant value failed
+ --> $DIR/unknown-when-ptr-metadata-is-DST.rs:8:16
+ |
+LL | [(); { let _a: Option<&str> = None; 0 }];
+ | ^^ the type `str` has an unknown layout
+
+error: aborting due to 1 previous error
+
+For more information about this error, try `rustc --explain E0080`.
diff --git a/tests/ui/structs/ice-struct-tail-normalization-113272.rs b/tests/ui/structs/ice-struct-tail-normalization-113272.rs
index 0ae24a7b71b49..ce2871fabb8c5 100644
--- a/tests/ui/structs/ice-struct-tail-normalization-113272.rs
+++ b/tests/ui/structs/ice-struct-tail-normalization-113272.rs
@@ -13,6 +13,6 @@ struct Other {
fn main() {
unsafe {
std::mem::transmute::