about summary refs log tree commit diff
path: root/compiler/rustc_middle/src/ty/instance.rs
diff options
context:
space:
mode:
authorlcnr <rust@lcnr.de>2023-10-02 13:15:29 +0200
committerlcnr <rust@lcnr.de>2023-10-02 13:19:37 +0200
commitdbc2cc8717dd8c8006595d9e9c91ad472109165a (patch)
treec80e39ebbdca1e66bab4cd16c29b9757d6a8d371 /compiler/rustc_middle/src/ty/instance.rs
parent15783292e5e26336f76ddc2123d66025ec6d84b7 (diff)
downloadrust-dbc2cc8717dd8c8006595d9e9c91ad472109165a.tar.gz
rust-dbc2cc8717dd8c8006595d9e9c91ad472109165a.zip
`skip_binder` to `instantiate_identity`
Diffstat (limited to 'compiler/rustc_middle/src/ty/instance.rs')
-rw-r--r--compiler/rustc_middle/src/ty/instance.rs9
1 files changed, 7 insertions, 2 deletions
diff --git a/compiler/rustc_middle/src/ty/instance.rs b/compiler/rustc_middle/src/ty/instance.rs
index 0b0a708e42b..0a425be52ff 100644
--- a/compiler/rustc_middle/src/ty/instance.rs
+++ b/compiler/rustc_middle/src/ty/instance.rs
@@ -617,12 +617,17 @@ impl<'tcx> Instance<'tcx> {
         v: EarlyBinder<T>,
     ) -> Result<T, NormalizationError<'tcx>>
     where
-        T: TypeFoldable<TyCtxt<'tcx>> + Clone,
+        T: TypeFoldable<TyCtxt<'tcx>>,
     {
         if let Some(args) = self.args_for_mir_body() {
             tcx.try_instantiate_and_normalize_erasing_regions(args, param_env, v)
         } else {
-            tcx.try_normalize_erasing_regions(param_env, v.skip_binder())
+            // We're using `instantiate_identity` as e.g.
+            // `FnPtrShim` is separately generated for every
+            // instantiation of the `FnDef`, so the MIR body
+            // is already instantiated. Any generic parameters it
+            // contains are generic parameters from the caller.
+            tcx.try_normalize_erasing_regions(param_env, v.instantiate_identity())
         }
     }