Add benchmarking for parachain runtime `ump` pallet (#3889)
* Claim grounds, not working yet. * still wip, nothing to see * Module visibility problem * Add benchmarks for all parachain-enabled chains * Add missing mock weights * Fix mock weight info * Add max-weight to extrinsic weight * cargo run --quiet --release --features=runtime-benchmarks -- benchmark --chain=kusama-dev --steps=50 --repeat=20 --pallet=runtime_parachains::ump --extrinsic=* --execution=wasm --wasm-execution=compiled --heap-pages=4096 --header=./file_header.txt --output=./runtime/kusama/src/weights/runtime_parachains_ump.rs * sorting declarations * Use a maximum size message to benchmark worst-case * remove warning * Fix msg size overflow in tests * Use benchmarked weight in PostInfo * Update runtime/parachains/src/ump.rs Co-authored-by:Alexander Popiak <alexander.popiak@gmail.com> * Delete obsolete file * Compile fix * Fix spelling * Add benchmark for `UmpSink::process_upward_message` It benchmarks the time to process a message, mainly the size-dependent decoding time. This is used interally for refunding weight from `service_overweight` * Fix warning * cargo run --quiet --release --features=runtime-benchmarks -- benchmark --chain=kusama-dev --steps=50 --repeat=20 --pallet=runtime_parachains::ump --extrinsic=* --execution=wasm --wasm-execution=compiled --heap-pages=4096 --header=./file_header.txt --output=./runtime/kusama/src/weights/runtime_parachains_ump.rs * cargo run --quiet --release --features=runtime-benchmarks -- benchmark --chain=westend-dev --steps=50 --repeat=20 --pallet=runtime_parachains::ump --extrinsic=* --execution=wasm --wasm-execution=compiled --heap-pages=4096 --header=./file_header.txt --output=./runtime/westend/src/weights/runtime_parachains_ump.rs * Update runtime/parachains/src/ump.rs Co-authored-by:
Kian Paimani <5588131+kianenigma@users.noreply.github.com> * Give mock weights for tests a name instead of () * Add benchmark for `initializer_on_new_session` aka. `perform_outgoing_para_cleanup` * Remove unnescessary pub specifier and change folding to a for loop suggestions by @pepyakin * Update runtime/parachains/src/ump.rs Co-authored-by:
Kian Paimani <5588131+kianenigma@users.noreply.github.com> * Update runtime/parachains/src/ump.rs Co-authored-by:
Kian Paimani <5588131+kianenigma@users.noreply.github.com> * Add comment on weight calculation and expected slight overestimation * Introduce a size bound constant for upward messages * Use KiB not kB for message size bound * Enforce max-message size bound * Use a const for upward message size bound. * Decrease max_upward_message_sizes to 50KiB as suggested by @pepyakin * Fix creating overweight messages * cargo run --quiet --profile=production --features=runtime-benchmarks -- benchmark --chain=rococo-dev --steps=50 --repeat=20 --pallet=runtime_parachains::ump --extrinsic=* --execution=wasm --wasm-execution=compiled --heap-pages=4096 --header=./file_header.txt --output=./runtime/rococo/src/weights/runtime_parachains_ump.rs * cargo run --quiet --profile=production --features=runtime-benchmarks -- benchmark --chain=westend-dev --steps=50 --repeat=20 --pallet=runtime_parachains::ump --extrinsic=* --execution=wasm --wasm-execution=compiled --heap-pages=4096 --header=./file_header.txt --output=./runtime/westend/src/weights/runtime_parachains_ump.rs * cargo run --quiet --profile=production --features=runtime-benchmarks -- benchmark --chain=kusama-dev --steps=50 --repeat=20 --pallet=runtime_parachains::ump --extrinsic=* --execution=wasm --wasm-execution=compiled --heap-pages=4096 --header=./file_header.txt --output=./runtime/kusama/src/weights/runtime_parachains_ump.rs * Remove unused variable * Rename benchmark function to the function actually benchmarked and some code cleanup * cargo run --quiet --profile=production --features=runtime-benchmarks -- benchmark --chain=kusama-dev --steps=50 --repeat=20 --pallet=runtime_parachains::ump --extrinsic=* --execution=wasm --wasm-execution=compiled --heap-pages=4096 --header=./file_header.txt --output=./runtime/kusama/src/weights/runtime_parachains_ump.rs * cargo run --quiet --profile=production --features=runtime-benchmarks -- benchmark --chain=rococo-dev --steps=50 --repeat=20 --pallet=runtime_parachains::ump --extrinsic=* --execution=wasm --wasm-execution=compiled --heap-pages=4096 --header=./file_header.txt --output=./runtime/rococo/src/weights/runtime_parachains_ump.rs * cargo run --quiet --profile=production --features=runtime-benchmarks -- benchmark --chain=westend-dev --steps=50 --repeat=20 --pallet=runtime_parachains::ump --extrinsic=* --execution=wasm --wasm-execution=compiled --heap-pages=4096 --header=./file_header.txt --output=./runtime/westend/src/weights/runtime_parachains_ump.rs * Better variable naming * Fix build * Fix build * Fix some remarks from @pepyakin Co-authored-by:
Parity Bot <admin@parity.io> Co-authored-by:
Alexander Popiak <alexander.popiak@gmail.com> Co-authored-by:
Kian Paimani <5588131+kianenigma@users.noreply.github.com> Co-authored-by:
emostov <32168567+emostov@users.noreply.github.com>
Showing
- polkadot/bridges/bin/rialto/node/src/chain_spec.rs 1 addition, 1 deletionpolkadot/bridges/bin/rialto/node/src/chain_spec.rs
- polkadot/node/service/src/chain_spec.rs 1 addition, 1 deletionpolkadot/node/service/src/chain_spec.rs
- polkadot/runtime/kusama/src/lib.rs 2 additions, 0 deletionspolkadot/runtime/kusama/src/lib.rs
- polkadot/runtime/kusama/src/weights/mod.rs 1 addition, 0 deletionspolkadot/runtime/kusama/src/weights/mod.rs
- polkadot/runtime/kusama/src/weights/runtime_parachains_ump.rs 66 additions, 0 deletions...adot/runtime/kusama/src/weights/runtime_parachains_ump.rs
- polkadot/runtime/parachains/src/configuration.rs 8 additions, 0 deletionspolkadot/runtime/parachains/src/configuration.rs
- polkadot/runtime/parachains/src/mock.rs 1 addition, 0 deletionspolkadot/runtime/parachains/src/mock.rs
- polkadot/runtime/parachains/src/ump.rs 63 additions, 15 deletionspolkadot/runtime/parachains/src/ump.rs
- polkadot/runtime/parachains/src/ump/benchmarking.rs 139 additions, 0 deletionspolkadot/runtime/parachains/src/ump/benchmarking.rs
- polkadot/runtime/parachains/src/ump/tests.rs 2 additions, 2 deletionspolkadot/runtime/parachains/src/ump/tests.rs
- polkadot/runtime/polkadot/src/lib.rs 3 additions, 0 deletionspolkadot/runtime/polkadot/src/lib.rs
- polkadot/runtime/rococo/src/lib.rs 2 additions, 0 deletionspolkadot/runtime/rococo/src/lib.rs
- polkadot/runtime/rococo/src/weights/mod.rs 1 addition, 0 deletionspolkadot/runtime/rococo/src/weights/mod.rs
- polkadot/runtime/rococo/src/weights/runtime_parachains_ump.rs 66 additions, 0 deletions...adot/runtime/rococo/src/weights/runtime_parachains_ump.rs
- polkadot/runtime/test-runtime/src/lib.rs 1 addition, 0 deletionspolkadot/runtime/test-runtime/src/lib.rs
- polkadot/runtime/westend/src/lib.rs 2 additions, 0 deletionspolkadot/runtime/westend/src/lib.rs
- polkadot/runtime/westend/src/weights/mod.rs 1 addition, 0 deletionspolkadot/runtime/westend/src/weights/mod.rs
- polkadot/runtime/westend/src/weights/runtime_parachains_ump.rs 66 additions, 0 deletions...dot/runtime/westend/src/weights/runtime_parachains_ump.rs
- polkadot/xcm/xcm-simulator/example/src/relay_chain.rs 1 addition, 0 deletionspolkadot/xcm/xcm-simulator/example/src/relay_chain.rs
- polkadot/xcm/xcm-simulator/fuzzer/src/relay_chain.rs 1 addition, 0 deletionspolkadot/xcm/xcm-simulator/fuzzer/src/relay_chain.rs
Please register or sign in to comment