Skip to content

Rollup of 10 pull requests #139766

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 29 commits into from
Apr 14, 2025
Merged

Rollup of 10 pull requests #139766

merged 29 commits into from
Apr 14, 2025

Conversation

jhpratt
Copy link
Member

@jhpratt jhpratt commented Apr 13, 2025

Successful merges:

r? @ghost
@rustbot modify labels: rollup

Create a similar rollup

xizheyin and others added 29 commits March 26, 2025 11:29
Normalization can fail from errors from other items so use a delayed
bug instead of checking the body.
…ross35,RalfJung,WaffleLapkin

Initial `UnsafePinned` implementation [Part 1: Libs]

Initial libs changes necessary to unblock further work on [RFC 3467](https://rust-lang.github.io/rfcs/3467-unsafe-pinned.html).
Tracking issue: rust-lang#125735

This PR is split off from rust-lang#136964, and includes just the libs changes:
- `UnsafePinned` struct
- private `UnsafeUnpin` structural auto trait
- Lang items for both
- Compiler changes necessary to block niches on `UnsafePinned`

This PR does not change codegen, miri, the existing `!Unpin` hack, or anything else. That work is to be split into later PRs.

---

cc ``@RalfJung`` ``@Noratrieb``

``@rustbot`` label F-unsafe_pinned T-libs-api
…errors

Expect an array when expected and acutal types are both arrays during cast

Closes rust-lang#138836
…bi, r=traviscross,compiler-errors

add `naked_functions_rustic_abi` feature gate

tracking issue: rust-lang#138997

Because the details of the rust abi are unstable, and a naked function must match its stated ABI, this feature gate keeps naked functions with a rustic abi ("Rust", "rust-cold", "rust-call" and "rust-intrinsic") unstable.

r? ````@traviscross````
…ion, r=compiler-errors

Use delayed bug for normalization errors in drop elaboration

Normalization can fail due to a lot of different earlier errors, so just use span_delayed_bug if normalization failed.

Closes rust-lang#137287
Closes rust-lang#135668

r? compiler-errors
…ler-errors

Various coercion cleanups

I think the commit order is the most reasonable one, but there's probably more ways to get to the same goal.

Essentially I got rid of the `simple` and `identity` helpers by adding a dedicated function for the common `identity` case and getting rid of the callbacks alltogether by realizing that all callbacks were of the pattern "use this fixed prefix list of adjustments, then add another adjustment with the unified type as the target type".

No behavioral changes intended
…rrors

Suggest remove redundant `$()?` around `vis`

Resolves: rust-lang#139480 .
…plify/simplify_primitive_clone, r=compiler-errors

Micro-optimize `InstSimplify`'s `simplify_primitive_clone`

r? ````@compiler-errors```` , since you already did rust-lang#139411 and got randomly selected for rust-lang#139638 (feel free to reassign!)

Another one similar in spirit to rust-lang#139411, but this time for `simplify_primitive_clone`, which is doing a bit of redundant work. Might not show up in benches, but probably worth micro-optimizing since the transformation is run even for debug builds.

See inline comments for my reasoning for making these changes.
…terators, r=compiler-errors

In `rustc_mir_transform`, iterate over index newtypes instead of ints

Just makes code more idiomatic/easier to read, IMHO.
Also, some drive-by simplifications and cleanups.
Convert `tests/ui/lint/dead-code/self-assign.rs` to a known-bug test

I did a survey pass over `tests/`, and this test seems like the only candidate suitable for conversion into a known-bug test. (Other tests had varying degrees of other issues that known-bug would not be suitable.)

r? compiler
fix smir's run! doc and import

This PR
* adds missing `extern crate rustc_middle` in `rustc_smir::run!` docstring
* adds missing `use rustc_smir::rustc_internal` in `run_driver!` scope
  * also adjust some tests that don't need to import rustc_internalany more
@rustbot rustbot added the A-attributes Area: Attributes (`#[…]`, `#![…]`) label Apr 13, 2025
@rustbot rustbot added S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. T-libs Relevant to the library team, which will review and decide on the PR/issue. rollup A PR which is a rollup labels Apr 13, 2025
@jhpratt
Copy link
Member Author

jhpratt commented Apr 13, 2025

@bors r+ rollup=never p=5

@bors
Copy link
Collaborator

bors commented Apr 13, 2025

📌 Commit 7ce62af has been approved by jhpratt

It is now in the queue for this repository.

@bors bors added S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion. and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels Apr 13, 2025
@bors
Copy link
Collaborator

bors commented Apr 14, 2025

⌛ Testing commit 7ce62af with merge 15f58c4...

@bors
Copy link
Collaborator

bors commented Apr 14, 2025

☀️ Test successful - checks-actions
Approved by: jhpratt
Pushing 15f58c4 to master...

@bors bors added the merged-by-bors This PR was explicitly merged by bors. label Apr 14, 2025
@bors bors merged commit 15f58c4 into rust-lang:master Apr 14, 2025
7 checks passed
@rustbot rustbot added this to the 1.88.0 milestone Apr 14, 2025
Copy link

What is this? This is an experimental post-merge analysis report that shows differences in test outcomes between the merged PR and its parent PR.

Comparing 6e83046 (parent) -> 15f58c4 (this PR)

Test differences

Show 567 test diffs

Stage 1

  • errors::verify_passes_attr_application_enum_145: [missing] -> pass (J0)
  • errors::verify_passes_attr_application_enum_146: pass -> [missing] (J0)
  • errors::verify_passes_attr_application_struct_147: pass -> [missing] (J0)
  • errors::verify_passes_attr_application_struct_enum_function_method_union_149: [missing] -> pass (J0)
  • errors::verify_passes_attr_application_struct_enum_function_method_union_150: pass -> [missing] (J0)
  • errors::verify_passes_attr_application_struct_enum_union_148: [missing] -> pass (J0)
  • errors::verify_passes_attr_application_struct_enum_union_149: pass -> [missing] (J0)
  • errors::verify_passes_attr_application_struct_union_147: [missing] -> pass (J0)
  • errors::verify_passes_attr_application_struct_union_148: pass -> [missing] (J0)
  • errors::verify_passes_attr_only_in_functions_137: [missing] -> pass (J0)
  • errors::verify_passes_attr_only_in_functions_138: pass -> [missing] (J0)
  • errors::verify_passes_cannot_stabilize_deprecated_153: [missing] -> pass (J0)
  • errors::verify_passes_cannot_stabilize_deprecated_154: pass -> [missing] (J0)
  • errors::verify_passes_const_stable_not_stable_162: [missing] -> pass (J0)
  • errors::verify_passes_deprecated_attribute_152: pass -> [missing] (J0)
  • errors::verify_passes_duplicate_feature_err_160: [missing] -> pass (J0)
  • errors::verify_passes_duplicate_feature_err_161: pass -> [missing] (J0)
  • errors::verify_passes_extern_main_139: [missing] -> pass (J0)
  • errors::verify_passes_extern_main_140: pass -> [missing] (J0)
  • errors::verify_passes_implied_feature_not_exist_159: [missing] -> pass (J0)
  • errors::verify_passes_implied_feature_not_exist_160: pass -> [missing] (J0)
  • errors::verify_passes_incorrect_target_140: [missing] -> pass (J0)
  • errors::verify_passes_incorrect_target_141: pass -> [missing] (J0)
  • errors::verify_passes_ineffective_unstable_impl_171: pass -> [missing] (J0)
  • errors::verify_passes_inline_ignored_for_exported_143: [missing] -> pass (J0)
  • errors::verify_passes_inline_ignored_for_exported_144: pass -> [missing] (J0)
  • errors::verify_passes_missing_const_err_161: [missing] -> pass (J0)
  • errors::verify_passes_missing_const_stab_attr_156: [missing] -> pass (J0)
  • errors::verify_passes_missing_const_stab_attr_157: pass -> [missing] (J0)
  • errors::verify_passes_missing_stability_attr_155: [missing] -> pass (J0)
  • errors::verify_passes_missing_stability_attr_156: pass -> [missing] (J0)
  • errors::verify_passes_multiple_rustc_main_138: [missing] -> pass (J0)
  • errors::verify_passes_naked_asm_outside_naked_fn_136: [missing] -> pass (J0)
  • errors::verify_passes_naked_asm_outside_naked_fn_137: pass -> [missing] (J0)
  • errors::verify_passes_naked_functions_incompatible_attribute_135: [missing] -> pass (J0)
  • errors::verify_passes_naked_functions_incompatible_attribute_136: pass -> [missing] (J0)
  • errors::verify_passes_naked_functions_must_naked_asm_134: [missing] -> pass (J0)
  • errors::verify_passes_naked_functions_must_naked_asm_135: pass -> [missing] (J0)
  • errors::verify_passes_no_patterns_132: [missing] -> pass (J0)
  • errors::verify_passes_no_patterns_133: pass -> [missing] (J0)
  • errors::verify_passes_no_sanitize_172: [missing] -> pass (J0)
  • errors::verify_passes_no_sanitize_173: pass -> [missing] (J0)
  • errors::verify_passes_object_lifetime_err_144: [missing] -> pass (J0)
  • errors::verify_passes_object_lifetime_err_145: pass -> [missing] (J0)
  • errors::verify_passes_only_has_effect_on_142: [missing] -> pass (J0)
  • errors::verify_passes_only_has_effect_on_143: pass -> [missing] (J0)
  • errors::verify_passes_params_not_allowed_133: [missing] -> pass (J0)
  • errors::verify_passes_params_not_allowed_134: pass -> [missing] (J0)
  • errors::verify_passes_proc_macro_bad_sig_163: [missing] -> pass (J0)
  • errors::verify_passes_proc_macro_bad_sig_164: pass -> [missing] (J0)
  • errors::verify_passes_rustc_const_stable_indirect_pairing_173: [missing] -> pass (J0)
  • errors::verify_passes_rustc_const_stable_indirect_pairing_174: pass -> [missing] (J0)
  • errors::verify_passes_trait_impl_const_stable_157: [missing] -> pass (J0)
  • errors::verify_passes_trait_impl_const_stable_158: pass -> [missing] (J0)
  • errors::verify_passes_transparent_incompatible_150: [missing] -> pass (J0)
  • errors::verify_passes_transparent_incompatible_151: pass -> [missing] (J0)
  • errors::verify_passes_undefined_naked_function_abi_132: pass -> [missing] (J0)
  • errors::verify_passes_unknown_feature_159: pass -> [missing] (J0)
  • errors::verify_passes_unnecessary_partial_stable_feature_169: [missing] -> pass (J0)
  • errors::verify_passes_unnecessary_partial_stable_feature_170: pass -> [missing] (J0)
  • errors::verify_passes_unnecessary_stable_feature_168: [missing] -> pass (J0)
  • errors::verify_passes_unnecessary_stable_feature_169: pass -> [missing] (J0)
  • errors::verify_passes_unreachable_due_to_uninhabited_164: [missing] -> pass (J0)
  • errors::verify_passes_unstable_attr_for_already_stable_feature_154: [missing] -> pass (J0)
  • errors::verify_passes_unstable_attr_for_already_stable_feature_155: pass -> [missing] (J0)
  • errors::verify_passes_unsupported_attributes_in_where_174: [missing] -> pass (J0)
  • errors::verify_passes_unused_assign_passed_172: pass -> [missing] (J0)
  • errors::verify_passes_unused_capture_maybe_capture_ref_166: [missing] -> pass (J0)
  • errors::verify_passes_unused_capture_maybe_capture_ref_167: pass -> [missing] (J0)
  • errors::verify_passes_unused_var_assigned_only_168: pass -> [missing] (J0)
  • errors::verify_passes_unused_var_maybe_capture_ref_165: [missing] -> pass (J0)
  • errors::verify_passes_unused_var_maybe_capture_ref_166: pass -> [missing] (J0)
  • errors::verify_passes_useless_assignment_141: [missing] -> pass (J0)
  • errors::verify_passes_useless_assignment_142: pass -> [missing] (J0)
  • errors::verify_passes_useless_stability_153: pass -> [missing] (J0)
  • [crashes] tests/crashes/135668.rs: pass -> [missing] (J3)
  • [crashes] tests/crashes/137287.rs: pass -> [missing] (J3)
  • [ui] tests/ui/asm/naked-functions-rustic-abi.rs#aarch64: [missing] -> ignore (only executed when the architecture is aarch64) (J3)
  • [ui] tests/ui/asm/naked-functions-rustic-abi.rs#x86_64: [missing] -> pass (J3)
  • [ui] tests/ui/cast/cast-array-issue-138836.rs: [missing] -> pass (J3)
  • [ui] tests/ui/drop/drop_elaboration_with_errors2.rs: [missing] -> pass (J3)
  • [ui] tests/ui/drop/drop_elaboration_with_errors3.rs: [missing] -> pass (J3)
  • [ui] tests/ui/feature-gates/feature-gate-naked_functions_rustic_abi.rs: [missing] -> pass (J3)
  • [ui] tests/ui/lint/removed-lints/undefined_naked_function_abi.rs: [missing] -> pass (J3)
  • [ui] tests/ui/macros/remove-repetition-issue-139480.rs: [missing] -> pass (J3)
  • [ui] tests/ui/rfcs/rfc-3467-unsafe-pinned/unsafe-pinned-hides-niche.rs: [missing] -> pass (J3)

Stage 2

  • [ui] tests/ui/cast/cast-array-issue-138836.rs: [missing] -> pass (J1)
  • [ui] tests/ui/drop/drop_elaboration_with_errors2.rs: [missing] -> pass (J1)
  • [ui] tests/ui/drop/drop_elaboration_with_errors3.rs: [missing] -> pass (J1)
  • [ui] tests/ui/lint/dead-code/self-assign.rs: ignore (ignored always (FIXME(81658, 83171))) -> pass (J1)
  • [ui] tests/ui/lint/removed-lints/undefined_naked_function_abi.rs: [missing] -> pass (J1)
  • [ui] tests/ui/macros/remove-repetition-issue-139480.rs: [missing] -> pass (J1)
  • [ui] tests/ui/rfcs/rfc-3467-unsafe-pinned/unsafe-pinned-hides-niche.rs: [missing] -> pass (J1)
  • [crashes] tests/crashes/135668.rs: pass -> [missing] (J2)
  • [crashes] tests/crashes/137287.rs: pass -> [missing] (J2)
  • [ui] tests/ui/asm/naked-functions-rustic-abi.rs#x86_64: [missing] -> pass (J4)
  • [ui] tests/ui/feature-gates/feature-gate-naked_functions_rustic_abi.rs: [missing] -> pass (J4)
  • [ui] tests/ui/asm/naked-functions-rustic-abi.rs#aarch64: [missing] -> ignore (only executed when the architecture is aarch64) (J5)
  • [ui] tests/ui/asm/naked-functions-rustic-abi.rs#aarch64: [missing] -> pass (J6)
  • [ui] tests/ui/asm/naked-functions-rustic-abi.rs#x86_64: [missing] -> ignore (only executed when the architecture is x86_64) (J7)

(and 14 additional test diffs)

Additionally, 453 doctest diffs were found. These are ignored, as they are noisy.

Job group index

Job duration changes

  1. x86_64-apple-1: 6994.9s -> 9425.3s (34.7%)
  2. dist-aarch64-linux: 7613.4s -> 5511.4s (-27.6%)
  3. dist-aarch64-apple: 4532.4s -> 5768.9s (27.3%)
  4. dist-x86_64-apple: 8779.4s -> 7203.2s (-18.0%)
  5. dist-x86_64-netbsd: 5013.5s -> 5856.7s (16.8%)
  6. x86_64-apple-2: 4184.6s -> 4712.2s (12.6%)
  7. x86_64-msvc-2: 6573.1s -> 6913.3s (5.2%)
  8. dist-powerpc64le-linux: 9192.1s -> 9634.9s (4.8%)
  9. armhf-gnu: 4552.6s -> 4370.3s (-4.0%)
  10. x86_64-msvc-ext1: 7085.1s -> 7348.5s (3.7%)
How to interpret the job duration changes?

Job durations can vary a lot, based on the actual runner instance
that executed the job, system noise, invalidated caches, etc. The table above is provided
mostly for t-infra members, for simpler debugging of potential CI slow-downs.

@rust-timer
Copy link
Collaborator

📌 Perf builds for each rolled up PR:

PR# Message Perf Build Sha
#137043 Initial UnsafePinned implementation [Part 1: Libs] 6a15d05bd3e565f39aa3834effd2bdfd781077c4 (link)
#138962 Expect an array when expected and acutal types are both arr… 6d8b4b6da5d463c279a999e1581759244d7ea340 (link)
#139001 add naked_functions_rustic_abi feature gate 80e749e14d1313930d23b96f1f54662ba4773b3f (link)
#139379 Use delayed bug for normalization errors in drop elaboration b265f8259707a7a3948c74bd2b8ed6724bb35c85 (link)
#139582 Various coercion cleanups bf2edc2d09ef0a2ce75f057d84404ae8bb8ee0a3 (link)
#139628 Suggest remove redundant $()? around vis 8ba594e0d93717fe77d19f28969d7d6e3ac87911 (link)
#139644 Micro-optimize InstSimplify's simplify_primitive_clone 0a3a110b911712d35e88e11a2625e981abf5e393 (link)
#139674 In rustc_mir_transform, iterate over index newtypes inste… 3c2d8a92bdf68cae581a6b5c8299088354523c56 (link)
#139740 Convert tests/ui/lint/dead-code/self-assign.rs to a known… 78fb8da9a253af09f26cab4771a38e393517edfe (link)
#139741 fix smir's run! doc and import 9433826045d92b72392c894200d70ed4d95ab339 (link)

previous master: 6e83046233

In the case of a perf regression, run the following command for each PR you suspect might be the cause: @rust-timer build $SHA

@rust-timer
Copy link
Collaborator

Finished benchmarking commit (15f58c4): comparison URL.

Overall result: ❌ regressions - please read the text below

Our benchmarks found a performance regression caused by this PR.
This might be an actual regression, but it can also be just noise.

Next Steps:

  • If the regression was expected or you think it can be justified,
    please write a comment with sufficient written justification, and add
    @rustbot label: +perf-regression-triaged to it, to mark the regression as triaged.
  • If you think that you know of a way to resolve the regression, try to create
    a new PR with a fix for the regression.
  • If you do not understand the regression or you think that it is just noise,
    you can ask the @rust-lang/wg-compiler-performance working group for help (members of this group
    were already notified of this PR).

@rustbot label: +perf-regression
cc @rust-lang/wg-compiler-performance

Instruction count

This is the most reliable metric that we have; it was used to determine the overall result at the top of this comment. However, even this metric can sometimes exhibit noise.

mean range count
Regressions ❌
(primary)
1.1% [0.5%, 2.1%] 15
Regressions ❌
(secondary)
1.0% [0.3%, 2.4%] 3
Improvements ✅
(primary)
- - 0
Improvements ✅
(secondary)
- - 0
All ❌✅ (primary) 1.1% [0.5%, 2.1%] 15

Max RSS (memory usage)

Results (primary 3.2%, secondary 8.7%)

This is a less reliable metric that may be of interest but was not used to determine the overall result at the top of this comment.

mean range count
Regressions ❌
(primary)
3.2% [0.9%, 8.9%] 5
Regressions ❌
(secondary)
8.7% [8.7%, 8.7%] 1
Improvements ✅
(primary)
- - 0
Improvements ✅
(secondary)
- - 0
All ❌✅ (primary) 3.2% [0.9%, 8.9%] 5

Cycles

Results (primary 1.5%, secondary 2.4%)

This is a less reliable metric that may be of interest but was not used to determine the overall result at the top of this comment.

mean range count
Regressions ❌
(primary)
1.5% [1.4%, 1.7%] 3
Regressions ❌
(secondary)
2.4% [2.4%, 2.4%] 1
Improvements ✅
(primary)
- - 0
Improvements ✅
(secondary)
- - 0
All ❌✅ (primary) 1.5% [1.4%, 1.7%] 3

Binary size

This benchmark run did not return any relevant results for this metric.

Bootstrap: 779.963s -> 780.383s (0.05%)
Artifact size: 365.51 MiB -> 365.54 MiB (0.01%)

@rustbot rustbot added the perf-regression Performance regression. label Apr 14, 2025
@Mark-Simulacrum
Copy link
Member

@rust-timer build 6a15d05

@rust-timer

This comment has been minimized.

@Mark-Simulacrum
Copy link
Member

@rust-timer build bf2edc2

@Mark-Simulacrum
Copy link
Member

Local diff from webrender:

There's a couple PRs in this set that touched trait-related code so it's not clear which of them is responsible for the relatively large, real regression in doc builds here.

< 155,228,145  ???:
   27,557,372    <rustc_trait_selection::traits::select::SelectionContext>::confirm_auto_impl_candidate::{closure#0}
   13,369,044    <rustc_trait_selection::traits::auto_trait::AutoTraitFinder>::evaluate_predicates
   10,633,650    <rustc_trait_selection::traits::select::SelectionContext>::poly_select::{closure#0}
    6,826,305    <rustc_middle::ty::context::CtxtInterners>::intern_predicate
    6,254,324    <hashbrown::raw::RawTable<(rustc_middle::ty::context::InternedInSet<rustc_type_ir::ty_info::WithCachedTypeInfo<rustc_type_ir::binder::Binder<rustc_middle::ty::context::TyCtxt, rustc_type_ir::predicate_kind::PredicateKind<rustc_middle::ty::context::TyCtxt>>>>, ())>>::reserve_rehash::<rustc_data_structures::sharded::table_entry<rustc_middle::ty::>
    5,752,216    free
    4,971,213    <rustc_type_ir::binder::ArgFolder<rustc_middle::ty::context::TyCtxt> as rustc_type_ir::fold::TypeFolder<rustc_middle::ty::context::TyCtxt>>::fold_ty
    4,721,603    <rustc_trait_selection::traits::select::SelectionContext>::candidate_from_obligation::{closure#0}::{closure#0}
    4,390,603    <rustc_middle::ty::context::CtxtInterners>::intern_ty
    4,033,658    malloc
    3,928,995    <rustc_trait_selection::traits::select::SelectionContext>::match_impl::{closure#0}
    3,841,526    <rustc_middle::ty::FieldDef>::ty
    2,928,094    <rustc_trait_selection::traits::auto_trait::AutoTraitFinder>::clean_pred
    2,875,570    <hashbrown::raw::RawTable<(rustc_span::symbol::Symbol, rustc_expand::base::SyntaxExtensionKind)>>::reserve_rehash::<hashbrown::map::make_hasher<rustc_span::symbol::Symbol, rustc_expand::base::SyntaxExtensionKind, rustc_hash::FxBuildHasher>::{closure#0}>
   -2,875,516    <hashbrown::raw::RawTable<(rustc_span::def_id::LocalDefId, alloc::vec::Vec<rustc_span::symbol::Ident>)>>::reserve_rehash::<hashbrown::map::make_hasher<rustc_span::def_id::LocalDefId, alloc::vec::Vec<rustc_span::symbol::Ident>, rustc_hash::FxBuildHasher>::{closure#0}>
    2,704,826    <indexmap::map::IndexMap<rustc_middle::ty::predicate::Predicate, (), core::hash::BuildHasherDefault<rustc_hash::FxHasher>>>::insert_full
    2,670,641    <rustc_trait_selection::traits::select::SelectionContext>::evaluate_trait_predicate_recursively

@rust-timer
Copy link
Collaborator

Finished benchmarking commit (6a15d05): comparison URL.

Overall result: ❌ regressions - please read the text below

Instruction count

This is the most reliable metric that we have; it was used to determine the overall result at the top of this comment. However, even this metric can sometimes exhibit noise.

mean range count
Regressions ❌
(primary)
1.1% [0.5%, 2.1%] 15
Regressions ❌
(secondary)
0.8% [0.2%, 2.4%] 4
Improvements ✅
(primary)
- - 0
Improvements ✅
(secondary)
- - 0
All ❌✅ (primary) 1.1% [0.5%, 2.1%] 15

Max RSS (memory usage)

Results (primary 4.0%, secondary 6.2%)

This is a less reliable metric that may be of interest but was not used to determine the overall result at the top of this comment.

mean range count
Regressions ❌
(primary)
4.0% [1.6%, 8.2%] 3
Regressions ❌
(secondary)
6.2% [3.7%, 8.7%] 2
Improvements ✅
(primary)
- - 0
Improvements ✅
(secondary)
- - 0
All ❌✅ (primary) 4.0% [1.6%, 8.2%] 3

Cycles

Results (primary 1.6%, secondary 6.1%)

This is a less reliable metric that may be of interest but was not used to determine the overall result at the top of this comment.

mean range count
Regressions ❌
(primary)
1.6% [1.5%, 1.8%] 3
Regressions ❌
(secondary)
6.1% [2.7%, 7.1%] 5
Improvements ✅
(primary)
- - 0
Improvements ✅
(secondary)
- - 0
All ❌✅ (primary) 1.6% [1.5%, 1.8%] 3

Binary size

This benchmark run did not return any relevant results for this metric.

Bootstrap: 779.963s -> 781.539s (0.20%)
Artifact size: 365.51 MiB -> 365.47 MiB (-0.01%)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-attributes Area: Attributes (`#[…]`, `#![…]`) merged-by-bors This PR was explicitly merged by bors. perf-regression Performance regression. rollup A PR which is a rollup S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion. T-compiler Relevant to the compiler team, which will review and decide on the PR/issue. T-libs Relevant to the library team, which will review and decide on the PR/issue.
Projects
None yet
Development

Successfully merging this pull request may close these issues.