mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-26 12:17:58 +00:00
002d9260f9
**Update:** Pushed additional changes based on the review comments. **This pull request fixes various spelling mistakes in this repository.** Most of the changes are contained in the first **3** commits: - `Fix spelling mistakes in comments and docs` - `Fix spelling mistakes in test names` - `Fix spelling mistakes in error messages, panic messages, logs and tracing` Other source code spelling mistakes are separated into individual commits for easier reviewing: - `Fix the spelling of 'authority'` - `Fix the spelling of 'REASONABLE_HEADERS_IN_JUSTIFICATION_ANCESTRY'` - `Fix the spelling of 'prev_enqueud_messages'` - `Fix the spelling of 'endpoint'` - `Fix the spelling of 'children'` - `Fix the spelling of 'PenpalSiblingSovereignAccount'` - `Fix the spelling of 'PenpalSudoAccount'` - `Fix the spelling of 'insufficient'` - `Fix the spelling of 'PalletXcmExtrinsicsBenchmark'` - `Fix the spelling of 'subtracted'` - `Fix the spelling of 'CandidatePendingAvailability'` - `Fix the spelling of 'exclusive'` - `Fix the spelling of 'until'` - `Fix the spelling of 'discriminator'` - `Fix the spelling of 'nonexistent'` - `Fix the spelling of 'subsystem'` - `Fix the spelling of 'indices'` - `Fix the spelling of 'committed'` - `Fix the spelling of 'topology'` - `Fix the spelling of 'response'` - `Fix the spelling of 'beneficiary'` - `Fix the spelling of 'formatted'` - `Fix the spelling of 'UNKNOWN_PROOF_REQUEST'` - `Fix the spelling of 'succeeded'` - `Fix the spelling of 'reopened'` - `Fix the spelling of 'proposer'` - `Fix the spelling of 'InstantiationNonce'` - `Fix the spelling of 'depositor'` - `Fix the spelling of 'expiration'` - `Fix the spelling of 'phantom'` - `Fix the spelling of 'AggregatedKeyValue'` - `Fix the spelling of 'randomness'` - `Fix the spelling of 'defendant'` - `Fix the spelling of 'AquaticMammal'` - `Fix the spelling of 'transactions'` - `Fix the spelling of 'PassingTracingSubscriber'` - `Fix the spelling of 'TxSignaturePayload'` - `Fix the spelling of 'versioning'` - `Fix the spelling of 'descendant'` - `Fix the spelling of 'overridden'` - `Fix the spelling of 'network'` Let me know if this structure is adequate. **Note:** The usage of the words `Merkle`, `Merkelize`, `Merklization`, `Merkelization`, `Merkleization`, is somewhat inconsistent but I left it as it is. ~~**Note:** In some places the term `Receival` is used to refer to message reception, IMO `Reception` is the correct word here, but I left it as it is.~~ ~~**Note:** In some places the term `Overlayed` is used instead of the more acceptable version `Overlaid` but I also left it as it is.~~ ~~**Note:** In some places the term `Applyable` is used instead of the correct version `Applicable` but I also left it as it is.~~ **Note:** Some usage of British vs American english e.g. `judgement` vs `judgment`, `initialise` vs `initialize`, `optimise` vs `optimize` etc. are both present in different places, but I suppose that's understandable given the number of contributors. ~~**Note:** There is a spelling mistake in `.github/CODEOWNERS` but it triggers errors in CI when I make changes to it, so I left it as it is.~~
444 lines
14 KiB
Rust
444 lines
14 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) Parity Technologies (UK) Ltd.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
//! This module contains the cost schedule and supporting code that constructs a
|
|
//! sane default schedule from a `WeightInfo` implementation.
|
|
|
|
use crate::{weights::WeightInfo, Config};
|
|
|
|
use codec::{Decode, Encode};
|
|
use core::marker::PhantomData;
|
|
use frame_support::{weights::Weight, DefaultNoBound};
|
|
use scale_info::TypeInfo;
|
|
#[cfg(feature = "std")]
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
/// Definition of the cost schedule and other parameterizations for the wasm vm.
|
|
///
|
|
/// Its [`Default`] implementation is the designated way to initialize this type. It uses
|
|
/// the benchmarked information supplied by [`Config::WeightInfo`]. All of its fields are
|
|
/// public and can therefore be modified. For example in order to change some of the limits
|
|
/// and set a custom instruction weight version the following code could be used:
|
|
/// ```rust
|
|
/// use pallet_contracts::{Schedule, Limits, InstructionWeights, Config};
|
|
///
|
|
/// fn create_schedule<T: Config>() -> Schedule<T> {
|
|
/// Schedule {
|
|
/// limits: Limits {
|
|
/// memory_pages: 16,
|
|
/// .. Default::default()
|
|
/// },
|
|
/// instruction_weights: InstructionWeights {
|
|
/// .. Default::default()
|
|
/// },
|
|
/// .. Default::default()
|
|
/// }
|
|
/// }
|
|
/// ```
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize))]
|
|
#[cfg_attr(feature = "std", serde(bound(serialize = "", deserialize = "")))]
|
|
#[cfg_attr(feature = "runtime-benchmarks", derive(frame_support::DebugNoBound))]
|
|
#[derive(Clone, Encode, Decode, PartialEq, Eq, DefaultNoBound, TypeInfo)]
|
|
#[scale_info(skip_type_params(T))]
|
|
pub struct Schedule<T: Config> {
|
|
/// Describes the upper limits on various metrics.
|
|
pub limits: Limits,
|
|
|
|
/// The weights for individual wasm instructions.
|
|
pub instruction_weights: InstructionWeights<T>,
|
|
|
|
/// The weights for each imported function a contract is allowed to call.
|
|
pub host_fn_weights: HostFnWeights<T>,
|
|
}
|
|
|
|
/// Describes the upper limits on various metrics.
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize))]
|
|
#[cfg_attr(feature = "runtime-benchmarks", derive(Debug))]
|
|
#[derive(Clone, Encode, Decode, PartialEq, Eq, TypeInfo)]
|
|
pub struct Limits {
|
|
/// The maximum number of topics supported by an event.
|
|
pub event_topics: u32,
|
|
|
|
/// Maximum number of memory pages allowed for a contract.
|
|
pub memory_pages: u32,
|
|
|
|
/// The maximum length of a subject in bytes used for PRNG generation.
|
|
pub subject_len: u32,
|
|
|
|
/// The maximum size of a storage value and event payload in bytes.
|
|
pub payload_len: u32,
|
|
|
|
/// The maximum node runtime memory. This is for integrity checks only and does not affect the
|
|
/// real setting.
|
|
pub runtime_memory: u32,
|
|
}
|
|
|
|
impl Limits {
|
|
/// The maximum memory size in bytes that a contract can occupy.
|
|
pub fn max_memory_size(&self) -> u32 {
|
|
self.memory_pages * 64 * 1024
|
|
}
|
|
}
|
|
|
|
/// Gas metering of Wasm executed instructions is being done on the engine side.
|
|
/// This struct holds a reference value used to gas units scaling between host and engine.
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize))]
|
|
#[cfg_attr(feature = "runtime-benchmarks", derive(frame_support::DebugNoBound))]
|
|
#[derive(Clone, Encode, Decode, PartialEq, Eq, TypeInfo)]
|
|
#[scale_info(skip_type_params(T))]
|
|
pub struct InstructionWeights<T: Config> {
|
|
/// Base instruction `ref_time` Weight.
|
|
/// Should match to wasmi's `1` fuel (see <https://github.com/paritytech/wasmi/issues/701>).
|
|
pub base: u32,
|
|
/// The type parameter is used in the default implementation.
|
|
#[codec(skip)]
|
|
pub _phantom: PhantomData<T>,
|
|
}
|
|
|
|
/// Describes the weight for each imported function that a contract is allowed to call.
|
|
#[cfg_attr(feature = "std", derive(Serialize, Deserialize))]
|
|
#[cfg_attr(feature = "runtime-benchmarks", derive(pallet_contracts_proc_macro::WeightDebug))]
|
|
#[derive(Clone, Encode, Decode, PartialEq, Eq, TypeInfo)]
|
|
#[scale_info(skip_type_params(T))]
|
|
pub struct HostFnWeights<T: Config> {
|
|
/// Weight of calling `seal_caller`.
|
|
pub caller: Weight,
|
|
|
|
/// Weight of calling `seal_is_contract`.
|
|
pub is_contract: Weight,
|
|
|
|
/// Weight of calling `seal_code_hash`.
|
|
pub code_hash: Weight,
|
|
|
|
/// Weight of calling `seal_own_code_hash`.
|
|
pub own_code_hash: Weight,
|
|
|
|
/// Weight of calling `seal_caller_is_origin`.
|
|
pub caller_is_origin: Weight,
|
|
|
|
/// Weight of calling `seal_caller_is_root`.
|
|
pub caller_is_root: Weight,
|
|
|
|
/// Weight of calling `seal_address`.
|
|
pub address: Weight,
|
|
|
|
/// Weight of calling `seal_gas_left`.
|
|
pub gas_left: Weight,
|
|
|
|
/// Weight of calling `seal_balance`.
|
|
pub balance: Weight,
|
|
|
|
/// Weight of calling `seal_value_transferred`.
|
|
pub value_transferred: Weight,
|
|
|
|
/// Weight of calling `seal_minimum_balance`.
|
|
pub minimum_balance: Weight,
|
|
|
|
/// Weight of calling `seal_block_number`.
|
|
pub block_number: Weight,
|
|
|
|
/// Weight of calling `seal_now`.
|
|
pub now: Weight,
|
|
|
|
/// Weight of calling `seal_weight_to_fee`.
|
|
pub weight_to_fee: Weight,
|
|
|
|
/// Weight of calling `seal_input`.
|
|
pub input: Weight,
|
|
|
|
/// Weight per input byte copied to contract memory by `seal_input`.
|
|
pub input_per_byte: Weight,
|
|
|
|
/// Weight of calling `seal_return`.
|
|
pub r#return: Weight,
|
|
|
|
/// Weight per byte returned through `seal_return`.
|
|
pub return_per_byte: Weight,
|
|
|
|
/// Weight of calling `seal_terminate`.
|
|
pub terminate: Weight,
|
|
|
|
/// Weight of calling `seal_random`.
|
|
pub random: Weight,
|
|
|
|
/// Weight of calling `seal_reposit_event`.
|
|
pub deposit_event: Weight,
|
|
|
|
/// Weight per topic supplied to `seal_deposit_event`.
|
|
pub deposit_event_per_topic: Weight,
|
|
|
|
/// Weight per byte of an event deposited through `seal_deposit_event`.
|
|
pub deposit_event_per_byte: Weight,
|
|
|
|
/// Weight of calling `seal_debug_message`.
|
|
pub debug_message: Weight,
|
|
|
|
/// Weight of calling `seal_debug_message` per byte of the message.
|
|
pub debug_message_per_byte: Weight,
|
|
|
|
/// Weight of calling `seal_set_storage`.
|
|
pub set_storage: Weight,
|
|
|
|
/// Weight per written byte of an item stored with `seal_set_storage`.
|
|
pub set_storage_per_new_byte: Weight,
|
|
|
|
/// Weight per overwritten byte of an item stored with `seal_set_storage`.
|
|
pub set_storage_per_old_byte: Weight,
|
|
|
|
/// Weight of calling `seal_set_code_hash`.
|
|
pub set_code_hash: Weight,
|
|
|
|
/// Weight of calling `seal_clear_storage`.
|
|
pub clear_storage: Weight,
|
|
|
|
/// Weight of calling `seal_clear_storage` per byte of the stored item.
|
|
pub clear_storage_per_byte: Weight,
|
|
|
|
/// Weight of calling `seal_contains_storage`.
|
|
pub contains_storage: Weight,
|
|
|
|
/// Weight of calling `seal_contains_storage` per byte of the stored item.
|
|
pub contains_storage_per_byte: Weight,
|
|
|
|
/// Weight of calling `seal_get_storage`.
|
|
pub get_storage: Weight,
|
|
|
|
/// Weight per byte of an item received via `seal_get_storage`.
|
|
pub get_storage_per_byte: Weight,
|
|
|
|
/// Weight of calling `seal_take_storage`.
|
|
pub take_storage: Weight,
|
|
|
|
/// Weight per byte of an item received via `seal_take_storage`.
|
|
pub take_storage_per_byte: Weight,
|
|
|
|
/// Weight of calling `seal_transfer`.
|
|
pub transfer: Weight,
|
|
|
|
/// Weight of calling `seal_call`.
|
|
pub call: Weight,
|
|
|
|
/// Weight of calling `seal_delegate_call`.
|
|
pub delegate_call: Weight,
|
|
|
|
/// Weight surcharge that is claimed if `seal_call` does a balance transfer.
|
|
pub call_transfer_surcharge: Weight,
|
|
|
|
/// Weight per byte that is cloned by supplying the `CLONE_INPUT` flag.
|
|
pub call_per_cloned_byte: Weight,
|
|
|
|
/// Weight of calling `seal_instantiate`.
|
|
pub instantiate: Weight,
|
|
|
|
/// Weight surcharge that is claimed if `seal_instantiate` does a balance transfer.
|
|
pub instantiate_transfer_surcharge: Weight,
|
|
|
|
/// Weight per input byte supplied to `seal_instantiate`.
|
|
pub instantiate_per_input_byte: Weight,
|
|
|
|
/// Weight per salt byte supplied to `seal_instantiate`.
|
|
pub instantiate_per_salt_byte: Weight,
|
|
|
|
/// Weight of calling `seal_hash_sha_256`.
|
|
pub hash_sha2_256: Weight,
|
|
|
|
/// Weight per byte hashed by `seal_hash_sha_256`.
|
|
pub hash_sha2_256_per_byte: Weight,
|
|
|
|
/// Weight of calling `seal_hash_keccak_256`.
|
|
pub hash_keccak_256: Weight,
|
|
|
|
/// Weight per byte hashed by `seal_hash_keccak_256`.
|
|
pub hash_keccak_256_per_byte: Weight,
|
|
|
|
/// Weight of calling `seal_hash_blake2_256`.
|
|
pub hash_blake2_256: Weight,
|
|
|
|
/// Weight per byte hashed by `seal_hash_blake2_256`.
|
|
pub hash_blake2_256_per_byte: Weight,
|
|
|
|
/// Weight of calling `seal_hash_blake2_128`.
|
|
pub hash_blake2_128: Weight,
|
|
|
|
/// Weight per byte hashed by `seal_hash_blake2_128`.
|
|
pub hash_blake2_128_per_byte: Weight,
|
|
|
|
/// Weight of calling `seal_ecdsa_recover`.
|
|
pub ecdsa_recover: Weight,
|
|
|
|
/// Weight of calling `seal_ecdsa_to_eth_address`.
|
|
pub ecdsa_to_eth_address: Weight,
|
|
|
|
/// Weight of calling `sr25519_verify`.
|
|
pub sr25519_verify: Weight,
|
|
|
|
/// Weight per byte of calling `sr25519_verify`.
|
|
pub sr25519_verify_per_byte: Weight,
|
|
|
|
/// Weight of calling `reentrance_count`.
|
|
pub reentrance_count: Weight,
|
|
|
|
/// Weight of calling `account_reentrance_count`.
|
|
pub account_reentrance_count: Weight,
|
|
|
|
/// Weight of calling `instantiation_nonce`.
|
|
pub instantiation_nonce: Weight,
|
|
|
|
/// Weight of calling `lock_delegate_dependency`.
|
|
pub lock_delegate_dependency: Weight,
|
|
|
|
/// Weight of calling `unlock_delegate_dependency`.
|
|
pub unlock_delegate_dependency: Weight,
|
|
|
|
/// The type parameter is used in the default implementation.
|
|
#[codec(skip)]
|
|
pub _phantom: PhantomData<T>,
|
|
}
|
|
|
|
macro_rules! replace_token {
|
|
($_in:tt $replacement:tt) => {
|
|
$replacement
|
|
};
|
|
}
|
|
|
|
macro_rules! call_zero {
|
|
($name:ident, $( $arg:expr ),*) => {
|
|
T::WeightInfo::$name($( replace_token!($arg 0) ),*)
|
|
};
|
|
}
|
|
|
|
macro_rules! cost_args {
|
|
($name:ident, $( $arg: expr ),+) => {
|
|
(T::WeightInfo::$name($( $arg ),+).saturating_sub(call_zero!($name, $( $arg ),+)))
|
|
}
|
|
}
|
|
|
|
macro_rules! cost {
|
|
($name:ident) => {
|
|
cost_args!($name, 1)
|
|
};
|
|
}
|
|
|
|
impl Default for Limits {
|
|
fn default() -> Self {
|
|
Self {
|
|
event_topics: 4,
|
|
memory_pages: 16,
|
|
subject_len: 32,
|
|
payload_len: 16 * 1024,
|
|
runtime_memory: 1024 * 1024 * 128,
|
|
}
|
|
}
|
|
}
|
|
|
|
impl<T: Config> Default for InstructionWeights<T> {
|
|
/// We execute 6 different instructions therefore we have to divide the actual
|
|
/// computed gas costs by 6 to have a rough estimate as to how expensive each
|
|
/// single executed instruction is going to be.
|
|
fn default() -> Self {
|
|
let instr_cost = cost!(instr_i64_load_store).ref_time() as u32;
|
|
let base = instr_cost / 6;
|
|
Self { base, _phantom: PhantomData }
|
|
}
|
|
}
|
|
|
|
impl<T: Config> Default for HostFnWeights<T> {
|
|
fn default() -> Self {
|
|
Self {
|
|
caller: cost!(seal_caller),
|
|
is_contract: cost!(seal_is_contract),
|
|
code_hash: cost!(seal_code_hash),
|
|
own_code_hash: cost!(seal_own_code_hash),
|
|
caller_is_origin: cost!(seal_caller_is_origin),
|
|
caller_is_root: cost!(seal_caller_is_root),
|
|
address: cost!(seal_address),
|
|
gas_left: cost!(seal_gas_left),
|
|
balance: cost!(seal_balance),
|
|
value_transferred: cost!(seal_value_transferred),
|
|
minimum_balance: cost!(seal_minimum_balance),
|
|
block_number: cost!(seal_block_number),
|
|
now: cost!(seal_now),
|
|
weight_to_fee: cost!(seal_weight_to_fee),
|
|
input: cost!(seal_input),
|
|
input_per_byte: cost!(seal_input_per_byte),
|
|
r#return: cost!(seal_return),
|
|
return_per_byte: cost!(seal_return_per_byte),
|
|
terminate: cost!(seal_terminate),
|
|
random: cost!(seal_random),
|
|
deposit_event: cost!(seal_deposit_event),
|
|
deposit_event_per_topic: cost_args!(seal_deposit_event_per_topic_and_byte, 1, 0),
|
|
deposit_event_per_byte: cost_args!(seal_deposit_event_per_topic_and_byte, 0, 1),
|
|
debug_message: cost!(seal_debug_message),
|
|
debug_message_per_byte: cost!(seal_debug_message_per_byte),
|
|
set_storage: cost!(seal_set_storage),
|
|
set_code_hash: cost!(seal_set_code_hash),
|
|
set_storage_per_new_byte: cost!(seal_set_storage_per_new_byte),
|
|
set_storage_per_old_byte: cost!(seal_set_storage_per_old_byte),
|
|
clear_storage: cost!(seal_clear_storage),
|
|
clear_storage_per_byte: cost!(seal_clear_storage_per_byte),
|
|
contains_storage: cost!(seal_contains_storage),
|
|
contains_storage_per_byte: cost!(seal_contains_storage_per_byte),
|
|
get_storage: cost!(seal_get_storage),
|
|
get_storage_per_byte: cost!(seal_get_storage_per_byte),
|
|
take_storage: cost!(seal_take_storage),
|
|
take_storage_per_byte: cost!(seal_take_storage_per_byte),
|
|
transfer: cost!(seal_transfer),
|
|
call: cost!(seal_call),
|
|
delegate_call: cost!(seal_delegate_call),
|
|
call_transfer_surcharge: cost_args!(seal_call_per_transfer_clone_byte, 1, 0),
|
|
call_per_cloned_byte: cost_args!(seal_call_per_transfer_clone_byte, 0, 1),
|
|
instantiate: cost!(seal_instantiate),
|
|
instantiate_transfer_surcharge: cost_args!(
|
|
seal_instantiate_per_transfer_input_salt_byte,
|
|
1,
|
|
0,
|
|
0
|
|
),
|
|
instantiate_per_input_byte: cost_args!(
|
|
seal_instantiate_per_transfer_input_salt_byte,
|
|
0,
|
|
1,
|
|
0
|
|
),
|
|
instantiate_per_salt_byte: cost_args!(
|
|
seal_instantiate_per_transfer_input_salt_byte,
|
|
0,
|
|
0,
|
|
1
|
|
),
|
|
hash_sha2_256: cost!(seal_hash_sha2_256),
|
|
hash_sha2_256_per_byte: cost!(seal_hash_sha2_256_per_byte),
|
|
hash_keccak_256: cost!(seal_hash_keccak_256),
|
|
hash_keccak_256_per_byte: cost!(seal_hash_keccak_256_per_byte),
|
|
hash_blake2_256: cost!(seal_hash_blake2_256),
|
|
hash_blake2_256_per_byte: cost!(seal_hash_blake2_256_per_byte),
|
|
hash_blake2_128: cost!(seal_hash_blake2_128),
|
|
hash_blake2_128_per_byte: cost!(seal_hash_blake2_128_per_byte),
|
|
ecdsa_recover: cost!(seal_ecdsa_recover),
|
|
sr25519_verify: cost!(seal_sr25519_verify),
|
|
sr25519_verify_per_byte: cost!(seal_sr25519_verify_per_byte),
|
|
ecdsa_to_eth_address: cost!(seal_ecdsa_to_eth_address),
|
|
reentrance_count: cost!(seal_reentrance_count),
|
|
account_reentrance_count: cost!(seal_account_reentrance_count),
|
|
instantiation_nonce: cost!(seal_instantiation_nonce),
|
|
lock_delegate_dependency: cost!(lock_delegate_dependency),
|
|
unlock_delegate_dependency: cost!(unlock_delegate_dependency),
|
|
_phantom: PhantomData,
|
|
}
|
|
}
|
|
}
|