about summary refs log tree commit diff
path: root/compiler/rustc_mir_transform/src/coverage/mappings.rs
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2024-07-04 21:17:19 +0000
committerbors <bors@rust-lang.org>2024-07-04 21:17:19 +0000
commitcc8da78a036dc3c15c35a97651b02af9a6d30c1e (patch)
tree7fed19378e80e1b3d189f66557a85c15cb8cf971 /compiler/rustc_mir_transform/src/coverage/mappings.rs
parentc4225812973cee4bba952cbf7a421f69871fed0d (diff)
parent529a3f4ce609f4bc98215185838351d9815fbdc1 (diff)
downloadrust-cc8da78a036dc3c15c35a97651b02af9a6d30c1e.tar.gz
rust-cc8da78a036dc3c15c35a97651b02af9a6d30c1e.zip
Auto merge of #127288 - lqd:typelen-cache, r=compiler-errors
cache type sizes in type-size limit visitor

This is basically https://github.com/rust-lang/rust/pull/125507#issuecomment-2206813779 as lcnr can't open the PR now.

Locally it reduces the `itertools` regression by quite a bit, to "only +50%" compared to nightly (that includes overhead from the local lack of artifact post-processing, and is just a data point to compare to the 10-20x timings without the cache).

```console
Benchmark 1: cargo +stage1 build --release
  Time (mean ± σ):      2.721 s ±  0.009 s    [User: 2.446 s, System: 0.325 s]
  Range (min … max):    2.710 s …  2.738 s    10 runs

Benchmark 2: cargo +nightly build --release
  Time (mean ± σ):      1.784 s ±  0.005 s    [User: 1.540 s, System: 0.279 s]
  Range (min … max):    1.778 s …  1.792 s    10 runs

Summary
  cargo +nightly build --release ran
    1.52 ± 0.01 times faster than cargo +stage1 build --release
```

On master, it's from 34s to the 2.7s above.

r? compiler-errors
Diffstat (limited to 'compiler/rustc_mir_transform/src/coverage/mappings.rs')
0 files changed, 0 insertions, 0 deletions