Skip to content

Refactor sysroot building #1341

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 8 commits into from
Jan 15, 2023
Merged

Refactor sysroot building #1341

merged 8 commits into from
Jan 15, 2023

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