Skip to content

Commit

Permalink
Add benchmark for system::set_code intrinsic
Browse files Browse the repository at this point in the history
  • Loading branch information
hirschenberger committed Feb 13, 2023
1 parent 67dca96 commit 7ffa15f
Show file tree
Hide file tree
Showing 5 changed files with 19 additions and 14 deletions.
3 changes: 0 additions & 3 deletions frame/system/benchmarking/runtimes/README.md

This file was deleted.

Binary file not shown.
12 changes: 10 additions & 2 deletions frame/system/benchmarking/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
use codec::Encode;
use frame_benchmarking::{benchmarks, whitelisted_caller};
use frame_support::{dispatch::DispatchClass, storage, traits::Get};
use frame_system::{Call, Pallet as System, RawOrigin};
use frame_system::{Call, EventRecord, Pallet as System, Phase, RawOrigin};
use sp_core::storage::well_known_keys;
use sp_runtime::traits::Hash;
use sp_std::{prelude::*, vec};
Expand All @@ -49,9 +49,17 @@ benchmarks! {
}: _(RawOrigin::Root, Default::default())

set_code {
let runtime_blob = include_bytes!("../runtimes/kitchensink_runtime.compact.compressed.wasm");
let runtime_blob = include_bytes!("../res/kitchensink_runtime.compact.compressed.wasm");
}: _(RawOrigin::Root, runtime_blob.to_vec())
verify {
assert_eq!(
System::<T>::events(),
vec![EventRecord {
phase: Phase::Initialization,
event: frame_system::Event::<T>::CodeUpdated.into(),
topics: vec![],
}],
);
}

#[extra]
Expand Down
12 changes: 6 additions & 6 deletions frame/system/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -404,10 +404,10 @@ pub mod pallet {
/// - 1 digest item.
/// - 1 event.
/// The weight of this function is dependent on the runtime, but generally this is very
/// expensive. We will treat this as a full block.
/// expensive.
/// # </weight>
#[pallet::call_index(2)]
#[pallet::weight((T::SystemWeightInfo::set_code(code.len() as u32), DispatchClass::Operational))]
#[pallet::weight((T::SystemWeightInfo::set_code(), DispatchClass::Operational))]
pub fn set_code(origin: OriginFor<T>, code: Vec<u8>) -> DispatchResultWithPostInfo {
ensure_root(origin)?;
Self::can_set_code(&code)?;
Expand Down Expand Up @@ -1264,7 +1264,7 @@ impl<T: Config> Pallet<T> {
let block_number = Self::block_number();
// Don't populate events on genesis.
if block_number.is_zero() {
return;
return
}

let phase = ExecutionPhase::<T>::get().unwrap_or_default();
Expand Down Expand Up @@ -1626,11 +1626,11 @@ impl<T: Config> Pallet<T> {

if new_version.spec_name != current_version.spec_name {
log::debug!("New: {new_version:?}, Current: {current_version:?}");
return Err(Error::<T>::InvalidSpecName.into());
return Err(Error::<T>::InvalidSpecName.into())
}

if new_version.spec_version <= current_version.spec_version {
return Err(Error::<T>::SpecVersionNeedsToIncrease.into());
return Err(Error::<T>::SpecVersionNeedsToIncrease.into())
}

Ok(())
Expand Down Expand Up @@ -1715,7 +1715,7 @@ impl<T: Config> StoredMap<T::AccountId, T::AccountData> for Pallet<T> {
},
}
} else if !was_providing && !is_providing {
return Ok(result);
return Ok(result)
}
Account::<T>::mutate(k, |a| a.data = some_data.unwrap_or_default());
Ok(result)
Expand Down
6 changes: 3 additions & 3 deletions frame/system/src/weights.rs
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ use sp_std::marker::PhantomData;
pub trait WeightInfo {
fn remark(b: u32, ) -> Weight;
fn remark_with_event(b: u32, ) -> Weight;
fn set_code(b: u32, ) -> Weight;
fn set_code() -> Weight;
fn set_heap_pages() -> Weight;
fn set_storage(i: u32, ) -> Weight;
fn kill_storage(i: u32, ) -> Weight;
Expand Down Expand Up @@ -90,7 +90,7 @@ impl<T: crate::Config> WeightInfo for SubstrateWeight<T> {
.saturating_add(Weight::from_ref_time(620_813 as u64).saturating_mul(i as u64))
.saturating_add(T::DbWeight::get().writes((1 as u64).saturating_mul(i as u64)))
}
fn set_code(b: u32) -> Weight {
fn set_code() -> Weight {
Weight::from_ref_time(1_000_000)
}
// Storage: Skipped Metadata (r:0 w:0)
Expand Down Expand Up @@ -130,7 +130,7 @@ impl WeightInfo for () {
.saturating_add(Weight::from_ref_time(1_424 as u64).saturating_mul(b as u64))
}

fn set_code(b: u32) -> Weight {
fn set_code() -> Weight {
Weight::from_ref_time(1_000_000)
}

Expand Down

0 comments on commit 7ffa15f

Please sign in to comment.