Normalize MIR locals' types for generator layout computation.

This commit is contained in:
Oliver Scherer 2020-04-09 16:48:36 +02:00
parent 11f6096a9e
commit 8a03147f22
2 changed files with 14 additions and 1 deletions

View file

@ -720,15 +720,18 @@ fn compute_layout<'tcx>(
_ => bug!(),
};
let param_env = tcx.param_env(source.def_id());
for (local, decl) in body.local_decls.iter_enumerated() {
// Ignore locals which are internal or not live
if !live_locals.contains(local) || decl.internal {
continue;
}
let decl_ty = tcx.normalize_erasing_regions(param_env, decl.ty);
// Sanity check that typeck knows about the type of locals which are
// live across a suspension point
if !allowed.contains(&decl.ty) && !allowed_upvars.contains(&decl.ty) {
if !allowed.contains(&decl_ty) && !allowed_upvars.contains(&decl_ty) {
span_bug!(
body.span,
"Broken MIR: generator contains type {} in MIR, \

View file

@ -0,0 +1,10 @@
// check-pass
// edition:2018
// compile-flags: --crate-type=lib
pub async fn test() {
const C: usize = 4;
foo(&mut [0u8; C]).await;
}
async fn foo(_: &mut [u8]) {}