about summary refs log tree commit diff
path: root/compiler/rustc_codegen_llvm/src
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2022-04-04 04:48:36 +0000
committerbors <bors@rust-lang.org>2022-04-04 04:48:36 +0000
commitec667fbcfcd29e2b5080f6be04e229356b27e600 (patch)
tree62623f8ee1b49cfade05b2d78728bf6f988f654f /compiler/rustc_codegen_llvm/src
parentac4b3450ede3e5f694f78b991496fd30846c5932 (diff)
parent8588f798029758c4d412757ff5d31c79ce5c02bf (diff)
downloadrust-ec667fbcfcd29e2b5080f6be04e229356b27e600.tar.gz
rust-ec667fbcfcd29e2b5080f6be04e229356b27e600.zip
Auto merge of #95031 - compiler-errors:param-env-cache, r=Aaron1011
Do not use `ParamEnv::and` when building a cache key from a param-env and trait eval candidate

Do not use `ParamEnv::and` to cache a param-env with a selection/evaluation candidate.

This is because if the param-env is `RevealAll` mode, and the candidate looks global (i.e. it has erased regions, which can show up when we normalize a projection type under a binder<sup>1</sup>), then when we use `ParamEnv::and` to pair the candidate and the param-env for use as a cache key, we will throw away the param-env's caller bounds, and we'll end up caching a candidate that we inferred from the param-env with a empty param-env, which may cause cache-hit later when we have an empty param-env, and possibly mess with normalization like we see in the referenced issue during codegen.

Not sure how to trigger this with a more structured test, but changing `check-pass` to `build-pass` triggers the case that https://github.com/rust-lang/rust/issues/94903 detected.

<sup>1.</sup> That is, we will replace the late-bound region with a placeholder, which gets canonicalized and turned into an infererence variable, which gets erased during region freshening right before we cache the result. Sorry, it's quite a few steps.

Fixes #94903
r? `@Aaron1011` (or reassign as you see fit)
Diffstat (limited to 'compiler/rustc_codegen_llvm/src')
0 files changed, 0 insertions, 0 deletions