diff options
| author | Michael Goulet <michael@errs.io> | 2025-01-08 00:28:47 +0000 |
|---|---|---|
| committer | Michael Goulet <michael@errs.io> | 2025-01-08 00:28:47 +0000 |
| commit | 3c3186148e4a66a507e606f191c35ed49d873b08 (patch) | |
| tree | 9ffe97bddbaed9c6bc1b684c75dfdda1f00b0e3c /compiler/rustc_hir_analysis/src/coherence/builtin.rs | |
| parent | ad211ced81509462cdfe4c29ed10f97279a0acae (diff) | |
| download | rust-3c3186148e4a66a507e606f191c35ed49d873b08.tar.gz rust-3c3186148e4a66a507e606f191c35ed49d873b08.zip | |
Don't allow transmuting ZSTs in dispatch_from_dyn impl
Diffstat (limited to 'compiler/rustc_hir_analysis/src/coherence/builtin.rs')
| -rw-r--r-- | compiler/rustc_hir_analysis/src/coherence/builtin.rs | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/compiler/rustc_hir_analysis/src/coherence/builtin.rs b/compiler/rustc_hir_analysis/src/coherence/builtin.rs index 3b98f358b1e..760c09a1e72 100644 --- a/compiler/rustc_hir_analysis/src/coherence/builtin.rs +++ b/compiler/rustc_hir_analysis/src/coherence/builtin.rs @@ -259,16 +259,25 @@ fn visit_implementation_of_dispatch_from_dyn(checker: &Checker<'_>) -> Result<() let coerced_fields = fields .iter() .filter(|field| { + // Ignore PhantomData fields + if tcx.type_of(field.did).instantiate_identity().is_phantom_data() { + return false; + } + let ty_a = field.ty(tcx, args_a); let ty_b = field.ty(tcx, args_b); + // Allow 1-ZSTs that don't mention type params. + // + // Allowing type params here would allow us to possibly transmute + // between ZSTs, which may be used to create library unsoundness. if let Ok(layout) = tcx.layout_of(infcx.typing_env(param_env).as_query_input(ty_a)) + && layout.is_1zst() + && !ty_a.has_non_region_param() { - if layout.is_1zst() { - // ignore 1-ZST fields - return false; - } + // ignore 1-ZST fields + return false; } if ty_a == ty_b { |
