Skip to content
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

WASM huge performance regression #2590

Closed
davxy opened this issue Dec 3, 2023 · 13 comments
Closed

WASM huge performance regression #2590

davxy opened this issue Dec 3, 2023 · 13 comments
Assignees

Comments

@davxy
Copy link
Member

davxy commented Dec 3, 2023

While re-running the Sassafras benches I noticed a slowdown for the whole set of (Sassafras) benchmarks.

After bisection I found that it started with #2217

To easily reproduce/test I created a branch from the commit which introduced the regression: https://github.com/davxy/polkadot-sdk/tree/davxy-perfs-degradation-poc

This contains the minimal code to trigger it... mostly a patch to the do_something extrinsic for the node-template to execute some code which computes a bandersnatch ring verifier.

$ cargo build -p node-template --release --features runtime-benchmarks
$ ./benchmark.sh
...
Time ~=   207800 µs

The degradation is not noticed with

$ WASM_BUILD_STD=0 cargo build -p node-template --release --features runtime-benchmarks
$ ./benchmark.sh
..
Time ~=    16070 µs

These timings badly impacts Sassafras as for tickets verification we go from the realm of ms to almost seconds, which probably is not acceptable.

cc @koute @bkchr

@bkchr
Copy link
Member

bkchr commented Dec 3, 2023

Please run the benchmarks using the production profile. Does that help?

@davxy
Copy link
Member Author

davxy commented Dec 3, 2023

EDIT: I haven't update my script to point toproduction folder. So production doesn't have the issue. Only release

@davxy davxy added this to SDK Node Dec 3, 2023
@github-project-automation github-project-automation bot moved this to backlog in SDK Node Dec 3, 2023
@davxy
Copy link
Member Author

davxy commented Dec 3, 2023

I also suspect that this may affect the Weight of the more involved extrinsics already used in prod

@ggwpez ggwpez mentioned this issue Dec 3, 2023
@burdges
Copy link

burdges commented Dec 4, 2023

Just a few possible regression sources:

Could the recompiled std break the fallback mechanism our forked curves use, thereby invoking direct curve arithmetic instead of the host calls?

Could the recompiled std reduce allocation speed? We do have some allocation inside arkworks, not anything in a loop afaik, but maybe if your benchmark runs in a loop it'd add up.

@koute
Copy link
Contributor

koute commented Dec 4, 2023

This is really weird. Compiling the std should definitely not have regressed the performance. This smells like a bug to me.

I'll take a look at this. If there will be a quick fix then I'll do that; if not I'll make a PR to flip the WASM_BUILD_STD default the other way around.

@koute koute self-assigned this Dec 4, 2023
@koute
Copy link
Contributor

koute commented Dec 4, 2023

(1) production profile, precompiled std:

Time ~=    16530
              µs

(2) production profile, compiling std:

Time ~=    16230
              µs

(3) release profile, compiling std

Time ~=    23050
              µs

Built with:

# (1)
WASM_BUILD_STD=0 cargo build -p node-template --profile=production --features runtime-benchmarks

# (2)
cargo build -p node-template --profile=production --features runtime-benchmarks

# (3)
cargo build -p node-template --release --features runtime-benchmarks

All builds were done fresh, where for (1) I removed the target/production after the first build.

My rustc:

$ rustc --version
rustc 1.75.0-nightly (edf0b1db0 2023-11-10)

@davxy I'm afraid I can't reproduce your issue. Can you give me your exact rustc version?

@davxy
Copy link
Member Author

davxy commented Dec 4, 2023

❯ rustc --version
rustc 1.74.0 (79e9716c9 2023-11-13)

I see that you used nightly. Please retry with stable.

I tried with nightly as well and indeed it doesn't have the problem

❯ rustc +nightly --version
rustc 1.76.0-nightly (a1a37735c 2023-11-23)

@davxy
Copy link
Member Author

davxy commented Dec 4, 2023

@koute please also try with a more complete benchmark which is a bit slower also on nightly

Branch: https://github.com/davxy/polkadot-sdk/tree/restore-sassafras-good-shape

Benchmarks: Sassafras tickets submission (x is the number of tickets)

Stable (1.74)

$ cargo build -p node-sassafras --release --features runtime-benchmarks
$ ./benchmark submit_tickets
...
Time ~=   705900
    + x    34260
              µs

Stable (1.74) + WASM_BUILD_STD=0

$ WASM_BUILD_STD=0 cargo build -p node-sassafras --release --features runtime-benchmarks
$ ./benchmark submit_tickets
...
Time ~=    68550
    + x     3865
              µs

Nightly (1.76)

$ cargo +nightly build -p node-sassafras --release --features runtime-benchmarks
$ ./benchmark submit_tickets
...
Time ~=    90390
    + x     5048
              µs

Nightly (1.76) + WASM_BUILD_STD=0

$ WASM_BUILD_STD=0 cargo +nightly build -p node-sassafras --release --features runtime-benchmarks
$ ./benchmark submit_tickets
Time ~=    67000
    + x     3910
                  µs

@koute
Copy link
Contributor

koute commented Dec 4, 2023

I see that you used nightly. Please retry with stable.

Still can't reproduce it, even on stable.

$ CARGO_TARGET_DIR=target/build-std-false WASM_BUILD_STD=0 rustup run 1.74.0 cargo build -p node-template --profile=production --features runtime-benchmarks
$ CARGO_TARGET_DIR=target/build-std-true WASM_BUILD_STD=1 rustup run 1.74.0 cargo build -p node-template --profile=production --features runtime-benchmarks

$ binary="./target/build-std-false/production/node-template" ./benchmark.sh
Time ~=    16140
              µs

$ binary="./target/build-std-true/production/node-template" ./benchmark.sh
Time ~=    16480
              µs

(I commented out the binary=... line in your script so that I can set the path through an environment variable.)

And just to verify, the std does get built in one case and not in the other:

$ ls target/build-std-false/production/wbuild/node-template-runtime/target/wasm32-unknown-unknown/production/build | rg std | wc -l
0
$ ls target/build-std-true/production/wbuild/node-template-runtime/target/wasm32-unknown-unknown/production/build | rg std | wc -l
1

The blobs are different in size, and the build-std one is smaller (which is as expected):

$ stat target/build-std-true/production/wbuild/node-template-runtime/node_template_runtime.wasm | rg "Size: \d+" -o
Size: 5620625
$ stat target/build-std-false/production/wbuild/node-template-runtime/node_template_runtime.wasm | rg "Size: \d+" -o
Size: 5872569

And verify that it was compiled with stable:

$ cat target/build-std-true/production/wbuild/node-template-runtime/target/.rustc_info.json | rg -o "rustc \S+ .+?\)"
rustc 1.74.0 (79e9716c9 2023-11-13)
$ cat target/build-std-false/production/wbuild/node-template-runtime/target/.rustc_info.json | rg -o "rustc \S+ .+?\)"
rustc 1.74.0 (79e9716c9 2023-11-13)

@koute
Copy link
Contributor

koute commented Dec 4, 2023

I managed to reproduce the issue for the second benchmark which @davxy posted, but it needs to be compiled as release.

Build type Build std? Weight Size of .wasm
release No 69730 7203988
release Yes 744300 6960520
production No 69740 6269825
production Yes 69240 6015984

I'm guessing something inside of std is probably not getting inlined, which craters the performance, and the prebuilt stds are not affected because they're built with LTO?

@davxy
Copy link
Member Author

davxy commented Dec 4, 2023

For the record: current nightly doesn't have the issue in release as well

Bisection of nightly versions allowed to determine from which version they solved the issue.

(for submit_tickets sassafras benchmark):

  • nightly-2023-10-19 => 80600 + 5226·x µs (GOOD)
  • nightly-2023-10-18 => 681000 + 35460·x µs (VERY BAD)

After further analysis of at the rust log I strongly suspect that:

So next stable will probably benefit from the speedup without explicit have to enable lto

@davxy
Copy link
Member Author

davxy commented Dec 4, 2023

@koute I tried the beta channel.

  • 1.75.0-beta.5 (1a06ac5b5 2023-12-01) => 82890 + 5102·x µs

So next stable will probably benefit from the speedup without explicit have to enable lto

So in the next stable (1.75) we can definitely benefit of the speedup


Let's keep this open until 28-dec when the new stable is released

@koute koute removed their assignment Dec 4, 2023
@davxy davxy self-assigned this Dec 4, 2023
@bkchr
Copy link
Member

bkchr commented Dec 5, 2023

I don't see any reason to keep this issue open. Especially as we run benchmarks using the production profile.

@bkchr bkchr closed this as completed Dec 5, 2023
@github-project-automation github-project-automation bot moved this from backlog to done in SDK Node Dec 5, 2023
lrazovic added a commit to Polimec/polimec-node that referenced this issue Mar 20, 2024
JuaniRios added a commit to Polimec/polimec-node that referenced this issue Mar 22, 2024
* update wip

* fix base runtime

* decrease election max values

* fix some migration issues

* fix xcm executor again

* fix test runtime

* fix node

* make integration tests build

* fix governance integration tests

* fix integration tests and properly configure xcm config with new pallet_funding

* first step benchmarks fix

* fix benchmarks

* add defaults to tests frame_system

* fix try-runtime

* fmt

* remove unused dependency

* fix warnings

* fmt

* fix integration tests and update funding cargo.toml

* feat: implement missing runtime api

* feat: use camelCase in JSON

* chore: zepter

* feat: switch to base

* fmt

* trying fix testnet chain spec

* fix std build for testing node

* fmt

* fmt

* chore: zepter

* fix: use the right runtime in the benchmarks

* chore: remove unused imports

* chore: lock upgrade

* chore: remove few unused deps from base

* chore: bump to 1.75.0

paritytech/polkadot-sdk#2590

* fix: testnet benchmarks

* fix: use camelCase in testnet

* chore: add chain flag to justfile

* benchmark fixes

* fmt

* feat: bump `spec_version` and `transaction_version`

* fix: post merge

* fix: restore integration tests

* chore: remove unused deps

* chore: fat fingers

* chore: zepter

* chore: fmt

* fic: partially fix build-spec test

* feat: use production profile in srtool

---------

Co-authored-by: Leonardo Razovic <[email protected]>
Co-authored-by: Juan Ignacio Rios <[email protected]>
bkchr pushed a commit that referenced this issue Apr 10, 2024
* Asynchronous backing PR (#2300)

* Update substrate & polkadot

* min changes to make async backing compile

* (async backing) parachain-system: track limitations for unincluded blocks (#2438)

* unincluded segment draft

* read para head from storage proof

* read_para_head -> read_included_para_head

* Provide pub interface

* add errors

* fix unincluded segment update

* BlockTracker -> Ancestor

* add a dmp limit

* Read para head depending on the storage switch

* doc comments

* storage items docs

* add a sanity check on block initialize

* Check watermark

* append to the segment on block finalize

* Move segment update into set_validation_data

* Resolve para head todo

* option watermark

* fix comment

* Drop dmq check

* fix weight

* doc-comments on inherent invariant

* Remove TODO

* add todo

* primitives tests

* pallet tests

* doc comments

* refactor unincluded segment length into a ConsensusHook (#2501)

* refactor unincluded segment length into a ConsensusHook

* add docs

* refactor bandwidth_out calculation

Co-authored-by: Chris Sosnin <[email protected]>

* test for limits from impl

* fmt

* make tests compile

* update comment

* uncomment test

* fix collator test by adding parent to state proof

* patch HRMP watermark rules for unincluded segment

* get consensus-common tests to pass, using unincluded segment

* fix unincluded segment tests

* get all tests passing

* fmt

* rustdoc CI

* aura-ext: limit the number of authored blocks per slot (#2551)

* aura_ext consensus hook

* reverse dependency

* include weight into hook

* fix tests

* remove stray println

Co-authored-by: Chris Sosnin <[email protected]>

* fix test warning

* fix doc link

---------

Co-authored-by: Chris Sosnin <[email protected]>
Co-authored-by: Chris Sosnin <[email protected]>

* parachain-system: ignore go ahead signal once upgrade is processed (#2594)

* handle goahead signal for unincluded segment

* doc comment

* add test

* parachain-system: drop processed messages from inherent data (#2590)

* implement `drop_processed_messages`

* drop messages based on relay parent number

* adjust tests

* drop changes to mqc

* fix comment

* drop test

* drop more dead code

* clippy

* aura-ext: check slot in consensus hook and remove all `CheckInherents` logic (#2658)

* aura-ext: check slot in consensus hook

* convert relay chain slot

* Make relay chain slot duration generic

* use fixed velocity hook for pallets with aura

* purge timestamp inherent

* fix warning

* adjust runtime tests

* fix slots in tests

* Make `xcm-emulator` test pass for new consensus hook (#2722)

* add pallets on_initialize

* tests pass

* add AuraExt on_init

* ".git/.scripts/commands/fmt/fmt.sh"

---------

Co-authored-by: command-bot <>

---------

Co-authored-by: Ignacio Palacios <[email protected]>

* update polkadot git refs

* CollationGenerationConfig closure is now optional (#2772)

* CollationGenerationConfig closure is now optional

* fix test

* propagate network-protocol-staging feature (#2899)

* Feature Flagging Consensus Hook Type Parameter (#2911)

* First pass

* fmt

* Added as default feature in tomls

* Changed to direct dependency feature

* Dealing with clippy error

* Update pallets/parachain-system/src/lib.rs

Co-authored-by: asynchronous rob <[email protected]>

---------

Co-authored-by: asynchronous rob <[email protected]>

* fmt

* bump deps and remove warning

* parachain-system: update RelevantMessagingState according to the unincluded segment (#2948)

* mostly address 2471 with a bug introduced

* adjust relevant messaging state after computing total

* fmt

* max -> min

* fix test implementation of xcmp source

* add test

* fix test message sending logic

* fix + test

* add more to unincluded segment test

* fmt

---------

Co-authored-by: Chris Sosnin <[email protected]>

* Integrate new Aura / Parachain Consensus Logic in Parachain-Template / Polkadot-Parachain (#2864)

* add a comment

* refactor client/service utilities

* deprecate start_collator

* update parachain-template

* update test-service in the same way

* update polkadot-parachain crate

* fmt

* wire up new SubmitCollation message

* some runtime utilities for implementing unincluded segment runtime APIs

* allow parachains to configure their level of sybil-resistance when starting the network

* make aura-ext compile

* update to specify sybil resistance levels

* fmt

* specify relay chain slot duration in milliseconds

* update Aura to explicitly produce Send futures

also, make relay_chain_slot_duration a Duration

* add authoring duration to basic collator and document params

* integrate new basic collator into parachain-template

* remove assert_send used for testing

* basic-aura: only author when parent included

* update polkadot-parachain-bin

* fmt

* some fixes

* fixes

* add a RelayNumberMonotonicallyIncreases

* add a utility function for initializing subsystems

* some logging for timestamp adjustment

* fmt

* some fixes for lookahead collator

* add a log

* update `find_potential_parents` to account for sessions

* bound the loop

* restore & deprecate old start_collator and start_full_node functions.

* remove unnecessary await calls

* fix warning

* clippy

* more clippy

* remove unneeded logic

* ci

* update comment

Co-authored-by: Marcin S. <[email protected]>

* (async backing) restore `CheckInherents` for backwards-compatibility (#2977)

* bring back timestamp

* Restore CheckInherents

* revert to empty CheckInherents

* make CheckInherents optional

* attempt

* properly end system blocks

* add some more comments

* ignore failing system parachain tests

* update refs after main feature branch merge

* comment out the offending tests because CI runs ignored tests

* fix warnings

* fmt

* revert to polkadot master

* cargo update -p polkadot-primitives -p sp-io

---------

Co-authored-by: asynchronous rob <[email protected]>
Co-authored-by: Ignacio Palacios <[email protected]>
Co-authored-by: Bradley Olson <[email protected]>
Co-authored-by: Marcin S. <[email protected]>
Co-authored-by: eskimor <[email protected]>
Co-authored-by: Andronik <[email protected]>
(cherry picked from commit 6ef1117)

* Companion: restructure macro related exports (#3015)

* restructure macro related exports

* restructure macro related exports

* wip

* wip

* update cargo lock

* refactor RuntimeDebug on unincluded segment

* fmt

* Companion: restructure `benchmarking` macro related exports (#3039)

* wip

* wip

* restructure benchmarking macro related exports

* add cargo lock

---------

Co-authored-by: parity-processbot <>
(cherry picked from commit 8349c8d)

* Add missing workspace members (#3056)

* Add dependencies

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Add missing workspace members

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Fix more

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

---------

Signed-off-by: Oliver Tale-Yazdi <[email protected]>
(cherry picked from commit 44499cf)

* Add CI for monorepo (#1145)

* Add CI for monorepo

* fix frame tests

* Format features

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* add note for skipping tests and disable test-linux-stable-all

* Fix tests and compile issues (#1152)

* Fix feature dependant import

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Bump test timeout

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Remove feature gate

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Add resolver 2

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Remove old lockfile

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Format features

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

---------

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Fix check-dependency-rules

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* rm test-runtime

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Actually fix script

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* enable cargo-check-each-crate-macos

* Run check-each-crate on 6 machines (#1163)

---------

Signed-off-by: Oliver Tale-Yazdi <[email protected]>
Co-authored-by: Oliver Tale-Yazdi <[email protected]>
(cherry picked from commit e494934)

* Fix features (#1194)

* Manually fix conflicting ?

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Remove duplicates

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Autofix feature propagation

zepter lint propagate-feature --feature try-runtime --left-side-feature-missing=ignore --workspace --fix --feature-enables-dep="try-runtime:frame-try-runtime"
zepter lint propagate-feature --feature runtime-benchmarks --left-side-feature-missing=ignore --workspace --fix --feature-enables-dep="runtime-benchmarks:frame-benchmarking"
zepter lint propagate-feature --feature std --left-side-feature-missing=ignore --workspace --fix
zepter f f

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Bump zepter

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Add some duplicates

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Revert "Add some duplicates"

This reverts commit c6ce627.

* Remove default enabled features

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Bump Zepter

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Bump in correct location 🤦

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* DNM: Add some mistakes

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* DNM: Add some mistakes

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Revert "DNM: Add some mistakes"

This reverts commit d469b3f.

* Revert "DNM: Add some mistakes"

This reverts commit d892a73.

---------

Signed-off-by: Oliver Tale-Yazdi <[email protected]>
(cherry picked from commit 0400ed9)

* Fix build profiles (#1229)

* Fix build profiles

Closes #1155

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Manually set version to 1.0.0

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Use workspace repo

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* 'Authors and Edition from workspace

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

---------

Signed-off-by: Oliver Tale-Yazdi <[email protected]>
(cherry picked from commit dcda0e5)

* Set test crates to nopublish (#1240)

* Set test crates to nopublish

* Don't publish more crates

* Set even more crates to nopublish

---------

Co-authored-by: Oliver Tale-Yazdi <[email protected]>
(cherry picked from commit 1c7ef1f)

* Add missing licenses and tune the scanning workflow (#1288)

* Add missing Cumulus licenses

* Typo

* Add missing Substrate licenses

* Single job checking the sub-repos in steps

* Remove dates

* Remove dates

* Add missing (C)

* Update FRAME UI tests

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

* Update more UI tests

Signed-off-by: Oliver Tale-Yazdi <[email protected]>

---------

Signed-off-by: Oliver Tale-Yazdi <[email protected]>
Co-authored-by: Oliver Tale-Yazdi <[email protected]>
(cherry picked from commit bfb241d)

* Restructure `dispatch` macro related exports (#1162)

* restructure dispatch macro related exports

* moved Dispatchable to lib.rs

* fix .gitignore final newline

* ".git/.scripts/commands/fmt/fmt.sh"

* fix rustdocs

* wip

---------

Co-authored-by: Liam Aharon <[email protected]>
Co-authored-by: command-bot <>
Co-authored-by: ordian <[email protected]>
(cherry picked from commit bdbe982)

* Fixes

* Fix clippy

---------

Co-authored-by: Chris Sosnin <[email protected]>
Co-authored-by: Juan <[email protected]>
Co-authored-by: Oliver Tale-Yazdi <[email protected]>
Co-authored-by: Alexander Samusev <[email protected]>
Co-authored-by: Lulu <[email protected]>
Co-authored-by: Przemek Rzad <[email protected]>
bkontur pushed a commit that referenced this issue Jun 5, 2024
* fiox overflow when computing priority boost (#2587)

* Backport changes from polkadot-sdk (#2588)

* backport #1543

* another backport

* https://gitlab.parity.io/parity/mirrors/polkadot-sdk/-/jobs/3833103
bkontur pushed a commit that referenced this issue Jun 7, 2024
* fiox overflow when computing priority boost (#2587)

* Backport changes from polkadot-sdk (#2588)

* backport #1543

* another backport

* https://gitlab.parity.io/parity/mirrors/polkadot-sdk/-/jobs/3833103
bkontur pushed a commit that referenced this issue Jul 4, 2024
* fiox overflow when computing priority boost (#2587)

* Backport changes from polkadot-sdk (#2588)

* backport #1543

* another backport

* https://gitlab.parity.io/parity/mirrors/polkadot-sdk/-/jobs/3833103
bkontur pushed a commit that referenced this issue Jul 17, 2024
* fiox overflow when computing priority boost (#2587)

* Backport changes from polkadot-sdk (#2588)

* backport #1543

* another backport

* https://gitlab.parity.io/parity/mirrors/polkadot-sdk/-/jobs/3833103
bkontur pushed a commit that referenced this issue Jul 23, 2024
* fiox overflow when computing priority boost (#2587)

* Backport changes from polkadot-sdk (#2588)

* backport #1543

* another backport

* https://gitlab.parity.io/parity/mirrors/polkadot-sdk/-/jobs/3833103
bkontur pushed a commit that referenced this issue Jul 26, 2024
* fiox overflow when computing priority boost (#2587)

* Backport changes from polkadot-sdk (#2588)

* backport #1543

* another backport

* https://gitlab.parity.io/parity/mirrors/polkadot-sdk/-/jobs/3833103
bkontur pushed a commit that referenced this issue Jul 27, 2024
* fiox overflow when computing priority boost (#2587)

* Backport changes from polkadot-sdk (#2588)

* backport #1543

* another backport

* https://gitlab.parity.io/parity/mirrors/polkadot-sdk/-/jobs/3833103
bkontur pushed a commit that referenced this issue Jul 29, 2024
* fiox overflow when computing priority boost (#2587)

* Backport changes from polkadot-sdk (#2588)

* backport #1543

* another backport

* https://gitlab.parity.io/parity/mirrors/polkadot-sdk/-/jobs/3833103
bkontur pushed a commit that referenced this issue Jul 30, 2024
* fiox overflow when computing priority boost (#2587)

* Backport changes from polkadot-sdk (#2588)

* backport #1543

* another backport

* https://gitlab.parity.io/parity/mirrors/polkadot-sdk/-/jobs/3833103
bkontur pushed a commit that referenced this issue Jul 31, 2024
* fiox overflow when computing priority boost (#2587)

* Backport changes from polkadot-sdk (#2588)

* backport #1543

* another backport

* https://gitlab.parity.io/parity/mirrors/polkadot-sdk/-/jobs/3833103
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: done
Development

No branches or pull requests

4 participants