Skip to content

Conversation

bjorn3
Copy link
Member

@bjorn3 bjorn3 commented Jan 15, 2023

  • Don't require an existing sysroot when building for MinGW
  • Add MinGW rtstartup objects to the sysroot for the host, not just for the target.
  • Introduce SysrootTarget to centralize assembling the sysroot a bit
  • Make sysroot assembling faster

Part of https://github.com/bjorn3/rustc_codegen_cranelift/issues/1290

Rather than copying it from an existing sysroot
Also pass build/rtstartup as sysroot when building the standard library
Even mini_core needs it
By avoiding some redundant rustc calls and stripping debuginfo for
wrappers. ./y.rs build --sysroot none now runs 44% faster.

Benchmark 1: ./y_before.bin build --sysroot none
  Time (mean ± σ):      2.200 s ±  0.038 s    [User: 2.140 s, System: 0.653 s]
  Range (min … max):    2.171 s …  2.303 s    10 runs

Benchmark 2: ./y_after.bin build --sysroot none
  Time (mean ± σ):      1.528 s ±  0.020 s    [User: 1.388 s, System: 0.490 s]
  Range (min … max):    1.508 s …  1.580 s    10 runs

Summary
  './y_after.bin build --sysroot none' ran
    1.44 ± 0.03 times faster than './y_before.bin build --sysroot none'
This is an additional 17% improvement on ./y.rs compile --sysroot none

Benchmark 1: ./y_before.bin build --sysroot none
  Time (mean ± σ):      1.533 s ±  0.022 s    [User: 1.411 s, System: 0.471 s]
  Range (min … max):    1.517 s …  1.589 s    10 runs

Benchmark 2: ./y_after.bin build --sysroot none
  Time (mean ± σ):      1.311 s ±  0.020 s    [User: 1.232 s, System: 0.428 s]
  Range (min … max):    1.298 s …  1.366 s    10 runs

Summary
  './y_after.bin build --sysroot none' ran
    1.17 ± 0.02 times faster than './y_before.bin build --sysroot none'
@bjorn3 bjorn3 merged commit 611c518 into master Jan 15, 2023
@bjorn3 bjorn3 deleted the build_sysroot_cleanup branch January 15, 2023 19:36
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant