diff options
| author | bors <bors@rust-lang.org> | 2023-02-20 14:08:34 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2023-02-20 14:08:34 +0000 |
| commit | 9669e57ed1cd81c7f04db39f9b401198ae574c30 (patch) | |
| tree | cdeb9012fc4907fc9a04be5cd69ba8dc4110fe4b /compiler/rustc_codegen_llvm/src | |
| parent | 610dbcbf8e49947c17e48561a87a21d8b9ed4d23 (diff) | |
| parent | d1a242533392d4772c84ce2be80cf7fd40aa8be3 (diff) | |
| download | rust-9669e57ed1cd81c7f04db39f9b401198ae574c30.tar.gz rust-9669e57ed1cd81c7f04db39f9b401198ae574c30.zip | |
Auto merge of #2793 - RalfJung:rustup, r=RalfJung
Rustup
Diffstat (limited to 'compiler/rustc_codegen_llvm/src')
| -rw-r--r-- | compiler/rustc_codegen_llvm/src/type_of.rs | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/compiler/rustc_codegen_llvm/src/type_of.rs b/compiler/rustc_codegen_llvm/src/type_of.rs index cc8ff947fc3..9cda24bab87 100644 --- a/compiler/rustc_codegen_llvm/src/type_of.rs +++ b/compiler/rustc_codegen_llvm/src/type_of.rs @@ -329,7 +329,7 @@ impl<'tcx> LayoutLlvmExt<'tcx> for TyAndLayout<'tcx> { ) -> &'a Type { // HACK(eddyb) special-case fat pointers until LLVM removes // pointee types, to avoid bitcasting every `OperandRef::deref`. - match self.ty.kind() { + match *self.ty.kind() { ty::Ref(..) | ty::RawPtr(_) => { return self.field(cx, index).llvm_type(cx); } @@ -339,6 +339,11 @@ impl<'tcx> LayoutLlvmExt<'tcx> for TyAndLayout<'tcx> { let ptr_ty = cx.tcx.mk_mut_ptr(self.ty.boxed_ty()); return cx.layout_of(ptr_ty).scalar_pair_element_llvm_type(cx, index, immediate); } + // `dyn* Trait` has the same ABI as `*mut dyn Trait` + ty::Dynamic(bounds, region, ty::DynStar) => { + let ptr_ty = cx.tcx.mk_mut_ptr(cx.tcx.mk_dynamic(bounds, region, ty::Dyn)); + return cx.layout_of(ptr_ty).scalar_pair_element_llvm_type(cx, index, immediate); + } _ => {} } |
