diff options
| author | bors <bors@rust-lang.org> | 2024-08-14 00:56:53 +0000 | 
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2024-08-14 00:56:53 +0000 | 
| commit | e9c965df7b75ab5b1ae8f9a2680839ac1a1a3880 (patch) | |
| tree | 4822d048daddf346eee47d7b2b844c98f0641906 /compiler/rustc_codegen_gcc | |
| parent | e5b3e68abf170556b9d56c6f9028318e53c9f06b (diff) | |
| parent | bbd1c3ab73a931bf4823eec836de57e837d2161c (diff) | |
| download | rust-e9c965df7b75ab5b1ae8f9a2680839ac1a1a3880.tar.gz rust-e9c965df7b75ab5b1ae8f9a2680839ac1a1a3880.zip | |
Auto merge of #128812 - nnethercote:shrink-TyKind-FnPtr, r=compiler-errors
Shrink `TyKind::FnPtr`. By splitting the `FnSig` within `TyKind::FnPtr` into `FnSigTys` and `FnHeader`, which can be packed more efficiently. This reduces the size of the hot `TyKind` type from 32 bytes to 24 bytes on 64-bit platforms. This reduces peak memory usage by a few percent on some benchmarks. It also reduces cache misses and page faults similarly, though this doesn't translate to clear cycles or wall-time improvements on CI. r? `@compiler-errors`
Diffstat (limited to 'compiler/rustc_codegen_gcc')
| -rw-r--r-- | compiler/rustc_codegen_gcc/src/type_of.rs | 5 | 
1 files changed, 2 insertions, 3 deletions
| diff --git a/compiler/rustc_codegen_gcc/src/type_of.rs b/compiler/rustc_codegen_gcc/src/type_of.rs index d85ed4f12ff..b7b1be5369c 100644 --- a/compiler/rustc_codegen_gcc/src/type_of.rs +++ b/compiler/rustc_codegen_gcc/src/type_of.rs @@ -213,9 +213,8 @@ impl<'tcx> LayoutGccExt<'tcx> for TyAndLayout<'tcx> { // NOTE: we cannot remove this match like in the LLVM codegen because the call // to fn_ptr_backend_type handle the on-stack attribute. // TODO(antoyo): find a less hackish way to hande the on-stack attribute. - ty::FnPtr(sig) => { - cx.fn_ptr_backend_type(cx.fn_abi_of_fn_ptr(sig, ty::List::empty())) - } + ty::FnPtr(sig_tys, hdr) => cx + .fn_ptr_backend_type(cx.fn_abi_of_fn_ptr(sig_tys.with(hdr), ty::List::empty())), _ => self.scalar_gcc_type_at(cx, scalar, Size::ZERO), }; cx.scalar_types.borrow_mut().insert(self.ty, ty); | 
