diff --git a/prdoc/pr_6926.prdoc b/prdoc/pr_6926.prdoc
new file mode 100644
index 0000000000000000000000000000000000000000..788d6c110873ab39bb86ba3ce530c0b6fa230cb8
--- /dev/null
+++ b/prdoc/pr_6926.prdoc
@@ -0,0 +1,13 @@
+title: '[pallet-revive] implement the gas limit API'
+doc:
+- audience: Runtime Dev
+  description: This PR implements the gas limit API, returning the maximum ref_time
+    per block. Solidity contracts only know a single weight dimension and can use
+    this method to get the block ref_time limit.
+crates:
+- name: pallet-revive-fixtures
+  bump: major
+- name: pallet-revive
+  bump: major
+- name: pallet-revive-uapi
+  bump: major
diff --git a/substrate/frame/revive/fixtures/contracts/create_transient_storage_and_call.rs b/substrate/frame/revive/fixtures/contracts/create_transient_storage_and_call.rs
index d2efb26e5cebcc41febe22822c7a18036ae2b331..cf12fed27563a960840cd2e31c1a7a28979d4738 100644
--- a/substrate/frame/revive/fixtures/contracts/create_transient_storage_and_call.rs
+++ b/substrate/frame/revive/fixtures/contracts/create_transient_storage_and_call.rs
@@ -22,7 +22,7 @@
 use common::input;
 use uapi::{HostFn, HostFnImpl as api, StorageFlags};
 
-static BUFFER: [u8; 512] = [0u8; 512];
+static BUFFER: [u8; 448] = [0u8; 448];
 
 #[no_mangle]
 #[polkavm_derive::polkavm_export]
diff --git a/substrate/frame/revive/fixtures/contracts/gas_limit.rs b/substrate/frame/revive/fixtures/contracts/gas_limit.rs
new file mode 100644
index 0000000000000000000000000000000000000000..9ce82227b64da38937513678620496634bf5fe94
--- /dev/null
+++ b/substrate/frame/revive/fixtures/contracts/gas_limit.rs
@@ -0,0 +1,34 @@
+// 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.
+
+//! Returns the block ref_time limit back to the caller.
+
+#![no_std]
+#![no_main]
+
+extern crate common;
+use uapi::{HostFn, HostFnImpl as api, ReturnFlags};
+
+#[no_mangle]
+#[polkavm_derive::polkavm_export]
+pub extern "C" fn deploy() {}
+
+#[no_mangle]
+#[polkavm_derive::polkavm_export]
+pub extern "C" fn call() {
+	api::return_value(ReturnFlags::empty(), &api::gas_limit().to_le_bytes());
+}
diff --git a/substrate/frame/revive/src/benchmarking/mod.rs b/substrate/frame/revive/src/benchmarking/mod.rs
index 6f84ecdd1525e3cfbe1fc88a1569c9e40ef67aea..4ddd6dfbc3720ff98d43b5ed81f64c7085557820 100644
--- a/substrate/frame/revive/src/benchmarking/mod.rs
+++ b/substrate/frame/revive/src/benchmarking/mod.rs
@@ -809,6 +809,17 @@ mod benchmarks {
 		assert_eq!(result.unwrap(), 128);
 	}
 
+	#[benchmark(pov_mode = Measured)]
+	fn seal_gas_limit() {
+		build_runtime!(runtime, memory: []);
+		let result;
+		#[block]
+		{
+			result = runtime.bench_gas_limit(&mut memory);
+		}
+		assert_eq!(result.unwrap(), T::BlockWeights::get().max_block.ref_time());
+	}
+
 	#[benchmark(pov_mode = Measured)]
 	fn seal_block_number() {
 		build_runtime!(runtime, memory: [[0u8;32], ]);
diff --git a/substrate/frame/revive/src/limits.rs b/substrate/frame/revive/src/limits.rs
index 2e112baae30129c195f30832822a3637906a13fb..3b55106c67d8ca45ebe6dcf6ce6b33c7e4d0fc68 100644
--- a/substrate/frame/revive/src/limits.rs
+++ b/substrate/frame/revive/src/limits.rs
@@ -47,7 +47,7 @@ pub const NUM_EVENT_TOPICS: u32 = 4;
 pub const DELEGATE_DEPENDENCIES: u32 = 32;
 
 /// Maximum size of events (including topics) and storage values.
-pub const PAYLOAD_BYTES: u32 = 512;
+pub const PAYLOAD_BYTES: u32 = 448;
 
 /// The maximum size of the transient storage in bytes.
 ///
diff --git a/substrate/frame/revive/src/tests.rs b/substrate/frame/revive/src/tests.rs
index 90c032bd084055b9739891b93a8bfaa227a6adc0..b863b52af2af67150d39461abaeb9d48a6dc240f 100644
--- a/substrate/frame/revive/src/tests.rs
+++ b/substrate/frame/revive/src/tests.rs
@@ -374,7 +374,7 @@ impl RegisteredChainExtension<Test> for TempStorageExtension {
 parameter_types! {
 	pub BlockWeights: frame_system::limits::BlockWeights =
 		frame_system::limits::BlockWeights::simple_max(
-			Weight::from_parts(2u64 * WEIGHT_REF_TIME_PER_SECOND, u64::MAX),
+			Weight::from_parts(2 * WEIGHT_REF_TIME_PER_SECOND, u64::MAX),
 		);
 	pub static ExistentialDeposit: u64 = 1;
 }
@@ -382,6 +382,7 @@ parameter_types! {
 #[derive_impl(frame_system::config_preludes::TestDefaultConfig)]
 impl frame_system::Config for Test {
 	type Block = Block;
+	type BlockWeights = BlockWeights;
 	type AccountId = AccountId32;
 	type Lookup = IdentityLookup<Self::AccountId>;
 	type AccountData = pallet_balances::AccountData<u64>;
@@ -438,7 +439,7 @@ parameter_types! {
 	pub static DepositPerByte: BalanceOf<Test> = 1;
 	pub const DepositPerItem: BalanceOf<Test> = 2;
 	pub static CodeHashLockupDepositPercent: Perbill = Perbill::from_percent(0);
-	pub static ChainId: u64 = 384;
+	pub static ChainId: u64 = 448;
 }
 
 impl Convert<Weight, BalanceOf<Self>> for Test {
@@ -3504,7 +3505,7 @@ fn deposit_limit_in_nested_calls() {
 		// Require more than the sender's balance.
 		// Limit the sub call to little balance so it should fail in there
 		let ret = builder::bare_call(addr_caller)
-			.data((512u32, &addr_callee, U256::from(1u64)).encode())
+			.data((448, &addr_callee, U256::from(1u64)).encode())
 			.build_and_unwrap_result();
 		assert_return_code!(ret, RuntimeReturnCode::OutOfResources);
 
@@ -4855,6 +4856,27 @@ fn skip_transfer_works() {
 	});
 }
 
+#[test]
+fn gas_limit_api_works() {
+	let (code, _) = compile_module("gas_limit").unwrap();
+
+	ExtBuilder::default().existential_deposit(100).build().execute_with(|| {
+		let _ = <Test as Config>::Currency::set_balance(&ALICE, 1_000_000);
+
+		// Create fixture: Constructor does nothing
+		let Contract { addr, .. } =
+			builder::bare_instantiate(Code::Upload(code)).build_and_unwrap_contract();
+
+		// Call the contract: It echoes back the value returned by the gas limit API.
+		let received = builder::bare_call(addr).build_and_unwrap_result();
+		assert_eq!(received.flags, ReturnFlags::empty());
+		assert_eq!(
+			u64::from_le_bytes(received.data[..].try_into().unwrap()),
+			<Test as frame_system::Config>::BlockWeights::get().max_block.ref_time()
+		);
+	});
+}
+
 #[test]
 fn unknown_syscall_rejected() {
 	let (code, _) = compile_module("unknown_syscall").unwrap();
diff --git a/substrate/frame/revive/src/wasm/runtime.rs b/substrate/frame/revive/src/wasm/runtime.rs
index d1a14ca1a93a572bdc8ae8130add57868fd8c52a..cdf6b3b08fdc3391a9b24b2091961af179b11559 100644
--- a/substrate/frame/revive/src/wasm/runtime.rs
+++ b/substrate/frame/revive/src/wasm/runtime.rs
@@ -326,6 +326,8 @@ pub enum RuntimeCosts {
 	BlockHash,
 	/// Weight of calling `seal_now`.
 	Now,
+	/// Weight of calling `seal_gas_limit`.
+	GasLimit,
 	/// Weight of calling `seal_weight_to_fee`.
 	WeightToFee,
 	/// Weight of calling `seal_terminate`, passing the number of locked dependencies.
@@ -476,6 +478,7 @@ impl<T: Config> Token<T> for RuntimeCosts {
 			BlockNumber => T::WeightInfo::seal_block_number(),
 			BlockHash => T::WeightInfo::seal_block_hash(),
 			Now => T::WeightInfo::seal_now(),
+			GasLimit => T::WeightInfo::seal_gas_limit(),
 			WeightToFee => T::WeightInfo::seal_weight_to_fee(),
 			Terminate(locked_dependencies) => T::WeightInfo::seal_terminate(locked_dependencies),
 			DepositEvent { num_topic, len } => T::WeightInfo::seal_deposit_event(num_topic, len),
@@ -1538,6 +1541,14 @@ pub mod env {
 		)?)
 	}
 
+	/// Returns the block ref_time limit.
+	/// See [`pallet_revive_uapi::HostFn::gas_limit`].
+	#[stable]
+	fn gas_limit(&mut self, memory: &mut M) -> Result<u64, TrapReason> {
+		self.charge_gas(RuntimeCosts::GasLimit)?;
+		Ok(<E::T as frame_system::Config>::BlockWeights::get().max_block.ref_time())
+	}
+
 	/// Stores the value transferred along with this call/instantiate into the supplied buffer.
 	/// See [`pallet_revive_uapi::HostFn::value_transferred`].
 	#[stable]
diff --git a/substrate/frame/revive/src/weights.rs b/substrate/frame/revive/src/weights.rs
index db3c34a75878b2ef2da63b9dc4decdf07e0a8bc1..3f7ede275928e8806933248b75ba45af31490e2a 100644
--- a/substrate/frame/revive/src/weights.rs
+++ b/substrate/frame/revive/src/weights.rs
@@ -20,7 +20,7 @@
 //! THIS FILE WAS AUTO-GENERATED USING THE SUBSTRATE BENCHMARK CLI VERSION 32.0.0
 //! DATE: 2024-12-18, STEPS: `50`, REPEAT: `20`, LOW RANGE: `[]`, HIGH RANGE: `[]`
 //! WORST CASE MAP SIZE: `1000000`
-//! HOSTNAME: `28f02a6d927a`, CPU: `Intel(R) Xeon(R) CPU @ 2.60GHz`
+//! HOSTNAME: `c3bb6290af79`, CPU: `Intel(R) Xeon(R) CPU @ 2.60GHz`
 //! WASM-EXECUTION: `Compiled`, CHAIN: `Some("dev")`, DB CACHE: `1024`
 
 // Executed Command:
@@ -83,6 +83,7 @@ pub trait WeightInfo {
 	fn seal_minimum_balance() -> Weight;
 	fn seal_return_data_size() -> Weight;
 	fn seal_call_data_size() -> Weight;
+	fn seal_gas_limit() -> Weight;
 	fn seal_block_number() -> Weight;
 	fn seal_block_hash() -> Weight;
 	fn seal_now() -> Weight;
@@ -138,8 +139,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `109`
 		//  Estimated: `1594`
-		// Minimum execution time: 2_752_000 picoseconds.
-		Weight::from_parts(2_990_000, 1594)
+		// Minimum execution time: 2_749_000 picoseconds.
+		Weight::from_parts(2_844_000, 1594)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
@@ -149,10 +150,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `425 + k * (69 ±0)`
 		//  Estimated: `415 + k * (70 ±0)`
-		// Minimum execution time: 16_130_000 picoseconds.
-		Weight::from_parts(3_413_527, 415)
-			// Standard Error: 1_190
-			.saturating_add(Weight::from_parts(1_184_912, 0).saturating_mul(k.into()))
+		// Minimum execution time: 15_364_000 picoseconds.
+		Weight::from_parts(3_092_479, 415)
+			// Standard Error: 1_592
+			.saturating_add(Weight::from_parts(1_189_460, 0).saturating_mul(k.into()))
 			.saturating_add(T::DbWeight::get().reads(2_u64))
 			.saturating_add(T::DbWeight::get().reads((1_u64).saturating_mul(k.into())))
 			.saturating_add(T::DbWeight::get().writes(2_u64))
@@ -176,8 +177,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `1465`
 		//  Estimated: `7405`
-		// Minimum execution time: 91_977_000 picoseconds.
-		Weight::from_parts(96_482_355, 7405)
+		// Minimum execution time: 92_898_000 picoseconds.
+		Weight::from_parts(97_241_513, 7405)
 			.saturating_add(T::DbWeight::get().reads(7_u64))
 			.saturating_add(T::DbWeight::get().writes(2_u64))
 	}
@@ -197,14 +198,16 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 	/// Proof: `Revive::PristineCode` (`max_values`: None, `max_size`: Some(262180), added: 264655, mode: `Measured`)
 	/// The range of component `c` is `[0, 262144]`.
 	/// The range of component `i` is `[0, 262144]`.
-	fn instantiate_with_code(_c: u32, i: u32, ) -> Weight {
+	fn instantiate_with_code(c: u32, i: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `416`
 		//  Estimated: `6348`
-		// Minimum execution time: 197_911_000 picoseconds.
-		Weight::from_parts(185_839_401, 6348)
-			// Standard Error: 9
-			.saturating_add(Weight::from_parts(4_419, 0).saturating_mul(i.into()))
+		// Minimum execution time: 196_248_000 picoseconds.
+		Weight::from_parts(162_338_484, 6348)
+			// Standard Error: 16
+			.saturating_add(Weight::from_parts(71, 0).saturating_mul(c.into()))
+			// Standard Error: 16
+			.saturating_add(Weight::from_parts(4_579, 0).saturating_mul(i.into()))
 			.saturating_add(T::DbWeight::get().reads(7_u64))
 			.saturating_add(T::DbWeight::get().writes(6_u64))
 	}
@@ -227,10 +230,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `1309`
 		//  Estimated: `4760`
-		// Minimum execution time: 162_062_000 picoseconds.
-		Weight::from_parts(146_040_237, 4760)
+		// Minimum execution time: 162_002_000 picoseconds.
+		Weight::from_parts(146_333_459, 4760)
 			// Standard Error: 15
-			.saturating_add(Weight::from_parts(4_410, 0).saturating_mul(i.into()))
+			.saturating_add(Weight::from_parts(4_482, 0).saturating_mul(i.into()))
 			.saturating_add(T::DbWeight::get().reads(7_u64))
 			.saturating_add(T::DbWeight::get().writes(4_u64))
 	}
@@ -250,8 +253,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `1465`
 		//  Estimated: `7405`
-		// Minimum execution time: 143_737_000 picoseconds.
-		Weight::from_parts(151_572_000, 7405)
+		// Minimum execution time: 144_493_000 picoseconds.
+		Weight::from_parts(150_783_000, 7405)
 			.saturating_add(T::DbWeight::get().reads(7_u64))
 			.saturating_add(T::DbWeight::get().writes(2_u64))
 	}
@@ -262,12 +265,14 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 	/// Storage: `Revive::PristineCode` (r:0 w:1)
 	/// Proof: `Revive::PristineCode` (`max_values`: None, `max_size`: Some(262180), added: 264655, mode: `Measured`)
 	/// The range of component `c` is `[0, 262144]`.
-	fn upload_code(_c: u32, ) -> Weight {
+	fn upload_code(c: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `109`
 		//  Estimated: `3574`
-		// Minimum execution time: 52_301_000 picoseconds.
-		Weight::from_parts(54_773_649, 3574)
+		// Minimum execution time: 51_261_000 picoseconds.
+		Weight::from_parts(53_656_457, 3574)
+			// Standard Error: 0
+			.saturating_add(Weight::from_parts(2, 0).saturating_mul(c.into()))
 			.saturating_add(T::DbWeight::get().reads(2_u64))
 			.saturating_add(T::DbWeight::get().writes(3_u64))
 	}
@@ -281,8 +286,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `285`
 		//  Estimated: `3750`
-		// Minimum execution time: 45_699_000 picoseconds.
-		Weight::from_parts(46_961_000, 3750)
+		// Minimum execution time: 44_921_000 picoseconds.
+		Weight::from_parts(46_970_000, 3750)
 			.saturating_add(T::DbWeight::get().reads(2_u64))
 			.saturating_add(T::DbWeight::get().writes(3_u64))
 	}
@@ -294,8 +299,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `529`
 		//  Estimated: `6469`
-		// Minimum execution time: 26_501_000 picoseconds.
-		Weight::from_parts(27_913_000, 6469)
+		// Minimum execution time: 27_070_000 picoseconds.
+		Weight::from_parts(27_897_000, 6469)
 			.saturating_add(T::DbWeight::get().reads(3_u64))
 			.saturating_add(T::DbWeight::get().writes(3_u64))
 	}
@@ -307,8 +312,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `109`
 		//  Estimated: `3574`
-		// Minimum execution time: 41_673_000 picoseconds.
-		Weight::from_parts(42_360_000, 3574)
+		// Minimum execution time: 40_939_000 picoseconds.
+		Weight::from_parts(42_250_000, 3574)
 			.saturating_add(T::DbWeight::get().reads(2_u64))
 			.saturating_add(T::DbWeight::get().writes(2_u64))
 	}
@@ -320,8 +325,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `56`
 		//  Estimated: `3521`
-		// Minimum execution time: 32_530_000 picoseconds.
-		Weight::from_parts(33_997_000, 3521)
+		// Minimum execution time: 32_804_000 picoseconds.
+		Weight::from_parts(33_965_000, 3521)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(2_u64))
 	}
@@ -333,8 +338,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `145`
 		//  Estimated: `3610`
-		// Minimum execution time: 13_327_000 picoseconds.
-		Weight::from_parts(13_976_000, 3610)
+		// Minimum execution time: 13_616_000 picoseconds.
+		Weight::from_parts(14_164_000, 3610)
 			.saturating_add(T::DbWeight::get().reads(2_u64))
 	}
 	/// The range of component `r` is `[0, 1600]`.
@@ -342,24 +347,24 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 7_317_000 picoseconds.
-		Weight::from_parts(7_742_783, 0)
-			// Standard Error: 274
-			.saturating_add(Weight::from_parts(166_272, 0).saturating_mul(r.into()))
+		// Minimum execution time: 7_403_000 picoseconds.
+		Weight::from_parts(8_174_105, 0)
+			// Standard Error: 181
+			.saturating_add(Weight::from_parts(162_824, 0).saturating_mul(r.into()))
 	}
 	fn seal_caller() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 300_000 picoseconds.
-		Weight::from_parts(349_000, 0)
+		// Minimum execution time: 278_000 picoseconds.
+		Weight::from_parts(312_000, 0)
 	}
 	fn seal_origin() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 248_000 picoseconds.
-		Weight::from_parts(293_000, 0)
+		// Minimum execution time: 232_000 picoseconds.
+		Weight::from_parts(252_000, 0)
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
 	/// Proof: `Revive::ContractInfoOf` (`max_values`: None, `max_size`: Some(1779), added: 4254, mode: `Measured`)
@@ -367,8 +372,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `306`
 		//  Estimated: `3771`
-		// Minimum execution time: 10_018_000 picoseconds.
-		Weight::from_parts(10_399_000, 3771)
+		// Minimum execution time: 10_239_000 picoseconds.
+		Weight::from_parts(10_730_000, 3771)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
@@ -377,16 +382,16 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `403`
 		//  Estimated: `3868`
-		// Minimum execution time: 11_209_000 picoseconds.
-		Weight::from_parts(11_640_000, 3868)
+		// Minimum execution time: 11_016_000 picoseconds.
+		Weight::from_parts(11_331_000, 3868)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 	}
 	fn seal_own_code_hash() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 280_000 picoseconds.
-		Weight::from_parts(309_000, 0)
+		// Minimum execution time: 261_000 picoseconds.
+		Weight::from_parts(298_000, 0)
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
 	/// Proof: `Revive::ContractInfoOf` (`max_values`: None, `max_size`: Some(1779), added: 4254, mode: `Measured`)
@@ -396,51 +401,51 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `473`
 		//  Estimated: `3938`
-		// Minimum execution time: 14_718_000 picoseconds.
-		Weight::from_parts(15_292_000, 3938)
+		// Minimum execution time: 14_413_000 picoseconds.
+		Weight::from_parts(15_066_000, 3938)
 			.saturating_add(T::DbWeight::get().reads(2_u64))
 	}
 	fn seal_caller_is_origin() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 336_000 picoseconds.
-		Weight::from_parts(391_000, 0)
+		// Minimum execution time: 303_000 picoseconds.
+		Weight::from_parts(340_000, 0)
 	}
 	fn seal_caller_is_root() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 275_000 picoseconds.
-		Weight::from_parts(296_000, 0)
+		// Minimum execution time: 246_000 picoseconds.
+		Weight::from_parts(266_000, 0)
 	}
 	fn seal_address() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 262_000 picoseconds.
-		Weight::from_parts(304_000, 0)
+		// Minimum execution time: 260_000 picoseconds.
+		Weight::from_parts(287_000, 0)
 	}
 	fn seal_weight_left() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 628_000 picoseconds.
-		Weight::from_parts(714_000, 0)
+		// Minimum execution time: 616_000 picoseconds.
+		Weight::from_parts(726_000, 0)
 	}
 	fn seal_ref_time_left() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 246_000 picoseconds.
-		Weight::from_parts(265_000, 0)
+		// Minimum execution time: 253_000 picoseconds.
+		Weight::from_parts(282_000, 0)
 	}
 	fn seal_balance() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `140`
 		//  Estimated: `0`
-		// Minimum execution time: 5_605_000 picoseconds.
-		Weight::from_parts(5_769_000, 0)
+		// Minimum execution time: 5_380_000 picoseconds.
+		Weight::from_parts(5_740_000, 0)
 	}
 	/// Storage: `Revive::AddressSuffix` (r:1 w:0)
 	/// Proof: `Revive::AddressSuffix` (`max_values`: None, `max_size`: Some(32), added: 2507, mode: `Measured`)
@@ -450,8 +455,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `264`
 		//  Estimated: `3729`
-		// Minimum execution time: 8_990_000 picoseconds.
-		Weight::from_parts(9_223_000, 3729)
+		// Minimum execution time: 8_826_000 picoseconds.
+		Weight::from_parts(9_166_000, 3729)
 			.saturating_add(T::DbWeight::get().reads(2_u64))
 	}
 	/// Storage: `Revive::ImmutableDataOf` (r:1 w:0)
@@ -461,10 +466,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `238 + n * (1 ±0)`
 		//  Estimated: `3703 + n * (1 ±0)`
-		// Minimum execution time: 6_001_000 picoseconds.
-		Weight::from_parts(6_630_017, 3703)
+		// Minimum execution time: 5_971_000 picoseconds.
+		Weight::from_parts(6_578_727, 3703)
 			// Standard Error: 4
-			.saturating_add(Weight::from_parts(622, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(732, 0).saturating_mul(n.into()))
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
@@ -475,46 +480,53 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 2_026_000 picoseconds.
-		Weight::from_parts(2_271_985, 0)
-			// Standard Error: 2
-			.saturating_add(Weight::from_parts(537, 0).saturating_mul(n.into()))
+		// Minimum execution time: 1_866_000 picoseconds.
+		Weight::from_parts(2_158_746, 0)
+			// Standard Error: 1
+			.saturating_add(Weight::from_parts(637, 0).saturating_mul(n.into()))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 	}
 	fn seal_value_transferred() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 287_000 picoseconds.
-		Weight::from_parts(323_000, 0)
+		// Minimum execution time: 223_000 picoseconds.
+		Weight::from_parts(279_000, 0)
 	}
 	fn seal_minimum_balance() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 230_000 picoseconds.
-		Weight::from_parts(275_000, 0)
+		// Minimum execution time: 220_000 picoseconds.
+		Weight::from_parts(245_000, 0)
 	}
 	fn seal_return_data_size() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 242_000 picoseconds.
-		Weight::from_parts(268_000, 0)
+		// Minimum execution time: 208_000 picoseconds.
+		Weight::from_parts(245_000, 0)
 	}
 	fn seal_call_data_size() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 244_000 picoseconds.
-		Weight::from_parts(271_000, 0)
+		// Minimum execution time: 211_000 picoseconds.
+		Weight::from_parts(252_000, 0)
+	}
+	fn seal_gas_limit() -> Weight {
+		// Proof Size summary in bytes:
+		//  Measured:  `0`
+		//  Estimated: `0`
+		// Minimum execution time: 282_000 picoseconds.
+		Weight::from_parts(310_000, 0)
 	}
 	fn seal_block_number() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 266_000 picoseconds.
-		Weight::from_parts(304_000, 0)
+		// Minimum execution time: 216_000 picoseconds.
+		Weight::from_parts(242_000, 0)
 	}
 	/// Storage: `System::BlockHash` (r:1 w:0)
 	/// Proof: `System::BlockHash` (`max_values`: None, `max_size`: Some(44), added: 2519, mode: `Measured`)
@@ -522,60 +534,60 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `30`
 		//  Estimated: `3495`
-		// Minimum execution time: 3_559_000 picoseconds.
-		Weight::from_parts(3_697_000, 3495)
+		// Minimum execution time: 3_410_000 picoseconds.
+		Weight::from_parts(3_595_000, 3495)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 	}
 	fn seal_now() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 242_000 picoseconds.
-		Weight::from_parts(294_000, 0)
+		// Minimum execution time: 214_000 picoseconds.
+		Weight::from_parts(234_000, 0)
 	}
 	fn seal_weight_to_fee() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_222_000 picoseconds.
-		Weight::from_parts(1_387_000, 0)
+		// Minimum execution time: 1_344_000 picoseconds.
+		Weight::from_parts(1_503_000, 0)
 	}
 	/// The range of component `n` is `[0, 262140]`.
 	fn seal_copy_to_contract(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 392_000 picoseconds.
-		Weight::from_parts(397_500, 0)
+		// Minimum execution time: 372_000 picoseconds.
+		Weight::from_parts(613_654, 0)
 			// Standard Error: 0
-			.saturating_add(Weight::from_parts(206, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(295, 0).saturating_mul(n.into()))
 	}
 	fn seal_call_data_load() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 267_000 picoseconds.
-		Weight::from_parts(322_000, 0)
+		// Minimum execution time: 213_000 picoseconds.
+		Weight::from_parts(243_000, 0)
 	}
 	/// The range of component `n` is `[0, 262144]`.
 	fn seal_call_data_copy(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 234_000 picoseconds.
-		Weight::from_parts(291_182, 0)
+		// Minimum execution time: 230_000 picoseconds.
+		Weight::from_parts(252_625, 0)
 			// Standard Error: 0
-			.saturating_add(Weight::from_parts(113, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(150, 0).saturating_mul(n.into()))
 	}
 	/// The range of component `n` is `[0, 262140]`.
 	fn seal_return(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 253_000 picoseconds.
-		Weight::from_parts(271_000, 0)
+		// Minimum execution time: 231_000 picoseconds.
+		Weight::from_parts(378_784, 0)
 			// Standard Error: 0
-			.saturating_add(Weight::from_parts(212, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(296, 0).saturating_mul(n.into()))
 	}
 	/// Storage: `Revive::AddressSuffix` (r:1 w:0)
 	/// Proof: `Revive::AddressSuffix` (`max_values`: None, `max_size`: Some(32), added: 2507, mode: `Measured`)
@@ -592,10 +604,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `324 + n * (88 ±0)`
 		//  Estimated: `3790 + n * (2563 ±0)`
-		// Minimum execution time: 22_082_000 picoseconds.
-		Weight::from_parts(22_815_417, 3790)
-			// Standard Error: 9_515
-			.saturating_add(Weight::from_parts(4_283_767, 0).saturating_mul(n.into()))
+		// Minimum execution time: 22_246_000 picoseconds.
+		Weight::from_parts(22_824_813, 3790)
+			// Standard Error: 11_423
+			.saturating_add(Weight::from_parts(4_328_279, 0).saturating_mul(n.into()))
 			.saturating_add(T::DbWeight::get().reads(3_u64))
 			.saturating_add(T::DbWeight::get().reads((1_u64).saturating_mul(n.into())))
 			.saturating_add(T::DbWeight::get().writes(4_u64))
@@ -603,56 +615,56 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 			.saturating_add(Weight::from_parts(0, 2563).saturating_mul(n.into()))
 	}
 	/// The range of component `t` is `[0, 4]`.
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_deposit_event(t: u32, n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 4_242_000 picoseconds.
-		Weight::from_parts(4_360_337, 0)
-			// Standard Error: 3_223
-			.saturating_add(Weight::from_parts(201_105, 0).saturating_mul(t.into()))
-			// Standard Error: 28
-			.saturating_add(Weight::from_parts(723, 0).saturating_mul(n.into()))
+		// Minimum execution time: 4_199_000 picoseconds.
+		Weight::from_parts(4_174_861, 0)
+			// Standard Error: 2_974
+			.saturating_add(Weight::from_parts(211_154, 0).saturating_mul(t.into()))
+			// Standard Error: 30
+			.saturating_add(Weight::from_parts(1_037, 0).saturating_mul(n.into()))
 	}
 	/// The range of component `i` is `[0, 262144]`.
 	fn seal_debug_message(i: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 340_000 picoseconds.
-		Weight::from_parts(773_824, 0)
-			// Standard Error: 1
-			.saturating_add(Weight::from_parts(722, 0).saturating_mul(i.into()))
+		// Minimum execution time: 311_000 picoseconds.
+		Weight::from_parts(326_000, 0)
+			// Standard Error: 0
+			.saturating_add(Weight::from_parts(815, 0).saturating_mul(i.into()))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
 	fn get_storage_empty() -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `744`
-		//  Estimated: `744`
-		// Minimum execution time: 7_741_000 picoseconds.
-		Weight::from_parts(8_048_000, 744)
+		//  Measured:  `680`
+		//  Estimated: `680`
+		// Minimum execution time: 7_584_000 picoseconds.
+		Weight::from_parts(8_006_000, 680)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
 	fn get_storage_full() -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `10754`
-		//  Estimated: `10754`
-		// Minimum execution time: 42_314_000 picoseconds.
-		Weight::from_parts(43_255_000, 10754)
+		//  Measured:  `10690`
+		//  Estimated: `10690`
+		// Minimum execution time: 42_716_000 picoseconds.
+		Weight::from_parts(43_583_000, 10690)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
 	fn set_storage_empty() -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `744`
-		//  Estimated: `744`
-		// Minimum execution time: 8_741_000 picoseconds.
-		Weight::from_parts(9_123_000, 744)
+		//  Measured:  `680`
+		//  Estimated: `680`
+		// Minimum execution time: 8_727_000 picoseconds.
+		Weight::from_parts(9_056_000, 680)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 	}
@@ -660,85 +672,85 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
 	fn set_storage_full() -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `10754`
-		//  Estimated: `10754`
-		// Minimum execution time: 44_703_000 picoseconds.
-		Weight::from_parts(46_403_000, 10754)
+		//  Measured:  `10690`
+		//  Estimated: `10690`
+		// Minimum execution time: 44_882_000 picoseconds.
+		Weight::from_parts(45_933_000, 10690)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
-	/// The range of component `n` is `[0, 512]`.
-	/// The range of component `o` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
+	/// The range of component `o` is `[0, 448]`.
 	fn seal_set_storage(n: u32, o: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + o * (1 ±0)`
 		//  Estimated: `247 + o * (1 ±0)`
-		// Minimum execution time: 9_285_000 picoseconds.
-		Weight::from_parts(10_046_720, 247)
-			// Standard Error: 37
-			.saturating_add(Weight::from_parts(365, 0).saturating_mul(n.into()))
-			// Standard Error: 37
-			.saturating_add(Weight::from_parts(273, 0).saturating_mul(o.into()))
+		// Minimum execution time: 9_150_000 picoseconds.
+		Weight::from_parts(9_621_151, 247)
+			// Standard Error: 43
+			.saturating_add(Weight::from_parts(554, 0).saturating_mul(n.into()))
+			// Standard Error: 43
+			.saturating_add(Weight::from_parts(645, 0).saturating_mul(o.into()))
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(o.into()))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_clear_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// Minimum execution time: 8_879_000 picoseconds.
-		Weight::from_parts(9_736_050, 247)
-			// Standard Error: 48
-			.saturating_add(Weight::from_parts(514, 0).saturating_mul(n.into()))
+		// Minimum execution time: 8_670_000 picoseconds.
+		Weight::from_parts(9_528_913, 247)
+			// Standard Error: 56
+			.saturating_add(Weight::from_parts(805, 0).saturating_mul(n.into()))
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_get_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// Minimum execution time: 8_475_000 picoseconds.
-		Weight::from_parts(9_410_206, 247)
-			// Standard Error: 58
-			.saturating_add(Weight::from_parts(1_409, 0).saturating_mul(n.into()))
+		// Minimum execution time: 8_214_000 picoseconds.
+		Weight::from_parts(9_195_285, 247)
+			// Standard Error: 70
+			.saturating_add(Weight::from_parts(1_452, 0).saturating_mul(n.into()))
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_contains_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// Minimum execution time: 8_017_000 picoseconds.
-		Weight::from_parts(8_879_089, 247)
-			// Standard Error: 51
-			.saturating_add(Weight::from_parts(512, 0).saturating_mul(n.into()))
+		// Minimum execution time: 7_947_000 picoseconds.
+		Weight::from_parts(8_633_252, 247)
+			// Standard Error: 53
+			.saturating_add(Weight::from_parts(832, 0).saturating_mul(n.into()))
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_take_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// Minimum execution time: 9_196_000 picoseconds.
-		Weight::from_parts(10_285_787, 247)
-			// Standard Error: 65
-			.saturating_add(Weight::from_parts(1_553, 0).saturating_mul(n.into()))
+		// Minimum execution time: 9_414_000 picoseconds.
+		Weight::from_parts(10_289_881, 247)
+			// Standard Error: 66
+			.saturating_add(Weight::from_parts(1_325, 0).saturating_mul(n.into()))
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
@@ -747,87 +759,87 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_456_000 picoseconds.
-		Weight::from_parts(1_593_000, 0)
+		// Minimum execution time: 1_424_000 picoseconds.
+		Weight::from_parts(1_511_000, 0)
 	}
 	fn set_transient_storage_full() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_897_000 picoseconds.
-		Weight::from_parts(2_059_000, 0)
+		// Minimum execution time: 1_797_000 picoseconds.
+		Weight::from_parts(1_961_000, 0)
 	}
 	fn get_transient_storage_empty() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_487_000 picoseconds.
-		Weight::from_parts(1_588_000, 0)
+		// Minimum execution time: 1_498_000 picoseconds.
+		Weight::from_parts(1_562_000, 0)
 	}
 	fn get_transient_storage_full() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_622_000 picoseconds.
-		Weight::from_parts(1_732_000, 0)
+		// Minimum execution time: 1_610_000 picoseconds.
+		Weight::from_parts(1_703_000, 0)
 	}
 	fn rollback_transient_storage() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_188_000 picoseconds.
-		Weight::from_parts(1_239_000, 0)
+		// Minimum execution time: 1_100_000 picoseconds.
+		Weight::from_parts(1_197_000, 0)
 	}
-	/// The range of component `n` is `[0, 512]`.
-	/// The range of component `o` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
+	/// The range of component `o` is `[0, 448]`.
 	fn seal_set_transient_storage(n: u32, o: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 2_269_000 picoseconds.
-		Weight::from_parts(2_528_717, 0)
-			// Standard Error: 12
-			.saturating_add(Weight::from_parts(163, 0).saturating_mul(n.into()))
-			// Standard Error: 12
-			.saturating_add(Weight::from_parts(332, 0).saturating_mul(o.into()))
+		// Minimum execution time: 2_232_000 picoseconds.
+		Weight::from_parts(2_371_207, 0)
+			// Standard Error: 13
+			.saturating_add(Weight::from_parts(385, 0).saturating_mul(n.into()))
+			// Standard Error: 13
+			.saturating_add(Weight::from_parts(471, 0).saturating_mul(o.into()))
 	}
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_clear_transient_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 2_051_000 picoseconds.
-		Weight::from_parts(2_507_009, 0)
-			// Standard Error: 20
-			.saturating_add(Weight::from_parts(309, 0).saturating_mul(n.into()))
+		// Minimum execution time: 2_015_000 picoseconds.
+		Weight::from_parts(2_374_096, 0)
+			// Standard Error: 18
+			.saturating_add(Weight::from_parts(462, 0).saturating_mul(n.into()))
 	}
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_get_transient_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_829_000 picoseconds.
-		Weight::from_parts(2_052_749, 0)
-			// Standard Error: 14
-			.saturating_add(Weight::from_parts(350, 0).saturating_mul(n.into()))
+		// Minimum execution time: 1_788_000 picoseconds.
+		Weight::from_parts(1_983_300, 0)
+			// Standard Error: 17
+			.saturating_add(Weight::from_parts(404, 0).saturating_mul(n.into()))
 	}
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_contains_transient_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_717_000 picoseconds.
-		Weight::from_parts(1_930_820, 0)
-			// Standard Error: 12
-			.saturating_add(Weight::from_parts(161, 0).saturating_mul(n.into()))
+		// Minimum execution time: 1_678_000 picoseconds.
+		Weight::from_parts(1_845_442, 0)
+			// Standard Error: 15
+			.saturating_add(Weight::from_parts(228, 0).saturating_mul(n.into()))
 	}
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_take_transient_storage(_n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 2_502_000 picoseconds.
-		Weight::from_parts(2_829_951, 0)
+		// Minimum execution time: 2_489_000 picoseconds.
+		Weight::from_parts(2_786_607, 0)
 	}
 	/// Storage: `Revive::AddressSuffix` (r:1 w:0)
 	/// Proof: `Revive::AddressSuffix` (`max_values`: None, `max_size`: Some(32), added: 2507, mode: `Measured`)
@@ -845,10 +857,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `1292 + t * (280 ±0)`
 		//  Estimated: `4757 + t * (2518 ±0)`
-		// Minimum execution time: 40_791_000 picoseconds.
-		Weight::from_parts(42_421_336, 4757)
-			// Standard Error: 53_086
-			.saturating_add(Weight::from_parts(2_057_850, 0).saturating_mul(t.into()))
+		// Minimum execution time: 41_653_000 picoseconds.
+		Weight::from_parts(43_075_070, 4757)
+			// Standard Error: 42_656
+			.saturating_add(Weight::from_parts(1_667_094, 0).saturating_mul(t.into()))
 			// Standard Error: 0
 			.saturating_add(Weight::from_parts(1, 0).saturating_mul(i.into()))
 			.saturating_add(T::DbWeight::get().reads(4_u64))
@@ -866,8 +878,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `1237`
 		//  Estimated: `4702`
-		// Minimum execution time: 35_825_000 picoseconds.
-		Weight::from_parts(37_377_000, 4702)
+		// Minimum execution time: 36_908_000 picoseconds.
+		Weight::from_parts(37_754_000, 4702)
 			.saturating_add(T::DbWeight::get().reads(3_u64))
 	}
 	/// Storage: `Revive::CodeInfoOf` (r:1 w:1)
@@ -883,10 +895,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `1310`
 		//  Estimated: `4769`
-		// Minimum execution time: 121_920_000 picoseconds.
-		Weight::from_parts(115_842_357, 4769)
+		// Minimum execution time: 120_576_000 picoseconds.
+		Weight::from_parts(112_786_790, 4769)
 			// Standard Error: 10
-			.saturating_add(Weight::from_parts(4_062, 0).saturating_mul(i.into()))
+			.saturating_add(Weight::from_parts(4_192, 0).saturating_mul(i.into()))
 			.saturating_add(T::DbWeight::get().reads(4_u64))
 			.saturating_add(T::DbWeight::get().writes(3_u64))
 	}
@@ -895,64 +907,64 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 657_000 picoseconds.
-		Weight::from_parts(2_219_539, 0)
+		// Minimum execution time: 621_000 picoseconds.
+		Weight::from_parts(3_506_910, 0)
 			// Standard Error: 3
-			.saturating_add(Weight::from_parts(1_413, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(1_489, 0).saturating_mul(n.into()))
 	}
 	/// The range of component `n` is `[0, 262144]`.
 	fn seal_hash_keccak_256(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_091_000 picoseconds.
-		Weight::from_parts(4_036_613, 0)
+		// Minimum execution time: 1_054_000 picoseconds.
+		Weight::from_parts(5_395_465, 0)
 			// Standard Error: 3
-			.saturating_add(Weight::from_parts(3_600, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(3_688, 0).saturating_mul(n.into()))
 	}
 	/// The range of component `n` is `[0, 262144]`.
 	fn seal_hash_blake2_256(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 635_000 picoseconds.
-		Weight::from_parts(4_636_213, 0)
+		// Minimum execution time: 626_000 picoseconds.
+		Weight::from_parts(3_549_376, 0)
 			// Standard Error: 3
-			.saturating_add(Weight::from_parts(1_514, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(1_596, 0).saturating_mul(n.into()))
 	}
 	/// The range of component `n` is `[0, 262144]`.
 	fn seal_hash_blake2_128(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 648_000 picoseconds.
-		Weight::from_parts(3_658_083, 0)
-			// Standard Error: 3
-			.saturating_add(Weight::from_parts(1_516, 0).saturating_mul(n.into()))
+		// Minimum execution time: 598_000 picoseconds.
+		Weight::from_parts(2_618_039, 0)
+			// Standard Error: 2
+			.saturating_add(Weight::from_parts(1_616, 0).saturating_mul(n.into()))
 	}
 	/// The range of component `n` is `[0, 261889]`.
 	fn seal_sr25519_verify(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 42_722_000 picoseconds.
-		Weight::from_parts(28_496_037, 0)
+		// Minimum execution time: 42_715_000 picoseconds.
+		Weight::from_parts(25_484_960, 0)
 			// Standard Error: 13
-			.saturating_add(Weight::from_parts(5_235, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(5_315, 0).saturating_mul(n.into()))
 	}
 	fn seal_ecdsa_recover() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 46_924_000 picoseconds.
-		Weight::from_parts(48_639_000, 0)
+		// Minimum execution time: 47_123_000 picoseconds.
+		Weight::from_parts(48_956_000, 0)
 	}
 	fn seal_ecdsa_to_eth_address() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 12_882_000 picoseconds.
-		Weight::from_parts(13_108_000, 0)
+		// Minimum execution time: 12_650_000 picoseconds.
+		Weight::from_parts(12_768_000, 0)
 	}
 	/// Storage: `Revive::CodeInfoOf` (r:1 w:1)
 	/// Proof: `Revive::CodeInfoOf` (`max_values`: None, `max_size`: Some(96), added: 2571, mode: `Measured`)
@@ -960,8 +972,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `300`
 		//  Estimated: `3765`
-		// Minimum execution time: 17_907_000 picoseconds.
-		Weight::from_parts(18_634_000, 3765)
+		// Minimum execution time: 18_061_000 picoseconds.
+		Weight::from_parts(18_851_000, 3765)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 	}
@@ -971,8 +983,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `338`
 		//  Estimated: `3803`
-		// Minimum execution time: 14_091_000 picoseconds.
-		Weight::from_parts(14_393_000, 3803)
+		// Minimum execution time: 13_779_000 picoseconds.
+		Weight::from_parts(14_320_000, 3803)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 	}
@@ -982,8 +994,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `338`
 		//  Estimated: `3561`
-		// Minimum execution time: 12_824_000 picoseconds.
-		Weight::from_parts(13_304_000, 3561)
+		// Minimum execution time: 12_327_000 picoseconds.
+		Weight::from_parts(13_156_000, 3561)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 	}
@@ -992,10 +1004,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 9_185_000 picoseconds.
-		Weight::from_parts(10_532_230, 0)
-			// Standard Error: 189
-			.saturating_add(Weight::from_parts(71_786, 0).saturating_mul(r.into()))
+		// Minimum execution time: 9_048_000 picoseconds.
+		Weight::from_parts(10_590_154, 0)
+			// Standard Error: 82
+			.saturating_add(Weight::from_parts(72_658, 0).saturating_mul(r.into()))
 	}
 }
 
@@ -1007,8 +1019,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `109`
 		//  Estimated: `1594`
-		// Minimum execution time: 2_752_000 picoseconds.
-		Weight::from_parts(2_990_000, 1594)
+		// Minimum execution time: 2_749_000 picoseconds.
+		Weight::from_parts(2_844_000, 1594)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
@@ -1018,10 +1030,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `425 + k * (69 ±0)`
 		//  Estimated: `415 + k * (70 ±0)`
-		// Minimum execution time: 16_130_000 picoseconds.
-		Weight::from_parts(3_413_527, 415)
-			// Standard Error: 1_190
-			.saturating_add(Weight::from_parts(1_184_912, 0).saturating_mul(k.into()))
+		// Minimum execution time: 15_364_000 picoseconds.
+		Weight::from_parts(3_092_479, 415)
+			// Standard Error: 1_592
+			.saturating_add(Weight::from_parts(1_189_460, 0).saturating_mul(k.into()))
 			.saturating_add(RocksDbWeight::get().reads(2_u64))
 			.saturating_add(RocksDbWeight::get().reads((1_u64).saturating_mul(k.into())))
 			.saturating_add(RocksDbWeight::get().writes(2_u64))
@@ -1045,8 +1057,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `1465`
 		//  Estimated: `7405`
-		// Minimum execution time: 91_977_000 picoseconds.
-		Weight::from_parts(96_482_355, 7405)
+		// Minimum execution time: 92_898_000 picoseconds.
+		Weight::from_parts(97_241_513, 7405)
 			.saturating_add(RocksDbWeight::get().reads(7_u64))
 			.saturating_add(RocksDbWeight::get().writes(2_u64))
 	}
@@ -1066,14 +1078,16 @@ impl WeightInfo for () {
 	/// Proof: `Revive::PristineCode` (`max_values`: None, `max_size`: Some(262180), added: 264655, mode: `Measured`)
 	/// The range of component `c` is `[0, 262144]`.
 	/// The range of component `i` is `[0, 262144]`.
-	fn instantiate_with_code(_c: u32, i: u32, ) -> Weight {
+	fn instantiate_with_code(c: u32, i: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `416`
 		//  Estimated: `6348`
-		// Minimum execution time: 197_911_000 picoseconds.
-		Weight::from_parts(185_839_401, 6348)
-			// Standard Error: 9
-			.saturating_add(Weight::from_parts(4_419, 0).saturating_mul(i.into()))
+		// Minimum execution time: 196_248_000 picoseconds.
+		Weight::from_parts(162_338_484, 6348)
+			// Standard Error: 16
+			.saturating_add(Weight::from_parts(71, 0).saturating_mul(c.into()))
+			// Standard Error: 16
+			.saturating_add(Weight::from_parts(4_579, 0).saturating_mul(i.into()))
 			.saturating_add(RocksDbWeight::get().reads(7_u64))
 			.saturating_add(RocksDbWeight::get().writes(6_u64))
 	}
@@ -1096,10 +1110,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `1309`
 		//  Estimated: `4760`
-		// Minimum execution time: 162_062_000 picoseconds.
-		Weight::from_parts(146_040_237, 4760)
+		// Minimum execution time: 162_002_000 picoseconds.
+		Weight::from_parts(146_333_459, 4760)
 			// Standard Error: 15
-			.saturating_add(Weight::from_parts(4_410, 0).saturating_mul(i.into()))
+			.saturating_add(Weight::from_parts(4_482, 0).saturating_mul(i.into()))
 			.saturating_add(RocksDbWeight::get().reads(7_u64))
 			.saturating_add(RocksDbWeight::get().writes(4_u64))
 	}
@@ -1119,8 +1133,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `1465`
 		//  Estimated: `7405`
-		// Minimum execution time: 143_737_000 picoseconds.
-		Weight::from_parts(151_572_000, 7405)
+		// Minimum execution time: 144_493_000 picoseconds.
+		Weight::from_parts(150_783_000, 7405)
 			.saturating_add(RocksDbWeight::get().reads(7_u64))
 			.saturating_add(RocksDbWeight::get().writes(2_u64))
 	}
@@ -1131,12 +1145,14 @@ impl WeightInfo for () {
 	/// Storage: `Revive::PristineCode` (r:0 w:1)
 	/// Proof: `Revive::PristineCode` (`max_values`: None, `max_size`: Some(262180), added: 264655, mode: `Measured`)
 	/// The range of component `c` is `[0, 262144]`.
-	fn upload_code(_c: u32, ) -> Weight {
+	fn upload_code(c: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `109`
 		//  Estimated: `3574`
-		// Minimum execution time: 52_301_000 picoseconds.
-		Weight::from_parts(54_773_649, 3574)
+		// Minimum execution time: 51_261_000 picoseconds.
+		Weight::from_parts(53_656_457, 3574)
+			// Standard Error: 0
+			.saturating_add(Weight::from_parts(2, 0).saturating_mul(c.into()))
 			.saturating_add(RocksDbWeight::get().reads(2_u64))
 			.saturating_add(RocksDbWeight::get().writes(3_u64))
 	}
@@ -1150,8 +1166,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `285`
 		//  Estimated: `3750`
-		// Minimum execution time: 45_699_000 picoseconds.
-		Weight::from_parts(46_961_000, 3750)
+		// Minimum execution time: 44_921_000 picoseconds.
+		Weight::from_parts(46_970_000, 3750)
 			.saturating_add(RocksDbWeight::get().reads(2_u64))
 			.saturating_add(RocksDbWeight::get().writes(3_u64))
 	}
@@ -1163,8 +1179,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `529`
 		//  Estimated: `6469`
-		// Minimum execution time: 26_501_000 picoseconds.
-		Weight::from_parts(27_913_000, 6469)
+		// Minimum execution time: 27_070_000 picoseconds.
+		Weight::from_parts(27_897_000, 6469)
 			.saturating_add(RocksDbWeight::get().reads(3_u64))
 			.saturating_add(RocksDbWeight::get().writes(3_u64))
 	}
@@ -1176,8 +1192,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `109`
 		//  Estimated: `3574`
-		// Minimum execution time: 41_673_000 picoseconds.
-		Weight::from_parts(42_360_000, 3574)
+		// Minimum execution time: 40_939_000 picoseconds.
+		Weight::from_parts(42_250_000, 3574)
 			.saturating_add(RocksDbWeight::get().reads(2_u64))
 			.saturating_add(RocksDbWeight::get().writes(2_u64))
 	}
@@ -1189,8 +1205,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `56`
 		//  Estimated: `3521`
-		// Minimum execution time: 32_530_000 picoseconds.
-		Weight::from_parts(33_997_000, 3521)
+		// Minimum execution time: 32_804_000 picoseconds.
+		Weight::from_parts(33_965_000, 3521)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(2_u64))
 	}
@@ -1202,8 +1218,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `145`
 		//  Estimated: `3610`
-		// Minimum execution time: 13_327_000 picoseconds.
-		Weight::from_parts(13_976_000, 3610)
+		// Minimum execution time: 13_616_000 picoseconds.
+		Weight::from_parts(14_164_000, 3610)
 			.saturating_add(RocksDbWeight::get().reads(2_u64))
 	}
 	/// The range of component `r` is `[0, 1600]`.
@@ -1211,24 +1227,24 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 7_317_000 picoseconds.
-		Weight::from_parts(7_742_783, 0)
-			// Standard Error: 274
-			.saturating_add(Weight::from_parts(166_272, 0).saturating_mul(r.into()))
+		// Minimum execution time: 7_403_000 picoseconds.
+		Weight::from_parts(8_174_105, 0)
+			// Standard Error: 181
+			.saturating_add(Weight::from_parts(162_824, 0).saturating_mul(r.into()))
 	}
 	fn seal_caller() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 300_000 picoseconds.
-		Weight::from_parts(349_000, 0)
+		// Minimum execution time: 278_000 picoseconds.
+		Weight::from_parts(312_000, 0)
 	}
 	fn seal_origin() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 248_000 picoseconds.
-		Weight::from_parts(293_000, 0)
+		// Minimum execution time: 232_000 picoseconds.
+		Weight::from_parts(252_000, 0)
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
 	/// Proof: `Revive::ContractInfoOf` (`max_values`: None, `max_size`: Some(1779), added: 4254, mode: `Measured`)
@@ -1236,8 +1252,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `306`
 		//  Estimated: `3771`
-		// Minimum execution time: 10_018_000 picoseconds.
-		Weight::from_parts(10_399_000, 3771)
+		// Minimum execution time: 10_239_000 picoseconds.
+		Weight::from_parts(10_730_000, 3771)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
@@ -1246,16 +1262,16 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `403`
 		//  Estimated: `3868`
-		// Minimum execution time: 11_209_000 picoseconds.
-		Weight::from_parts(11_640_000, 3868)
+		// Minimum execution time: 11_016_000 picoseconds.
+		Weight::from_parts(11_331_000, 3868)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 	}
 	fn seal_own_code_hash() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 280_000 picoseconds.
-		Weight::from_parts(309_000, 0)
+		// Minimum execution time: 261_000 picoseconds.
+		Weight::from_parts(298_000, 0)
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
 	/// Proof: `Revive::ContractInfoOf` (`max_values`: None, `max_size`: Some(1779), added: 4254, mode: `Measured`)
@@ -1265,51 +1281,51 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `473`
 		//  Estimated: `3938`
-		// Minimum execution time: 14_718_000 picoseconds.
-		Weight::from_parts(15_292_000, 3938)
+		// Minimum execution time: 14_413_000 picoseconds.
+		Weight::from_parts(15_066_000, 3938)
 			.saturating_add(RocksDbWeight::get().reads(2_u64))
 	}
 	fn seal_caller_is_origin() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 336_000 picoseconds.
-		Weight::from_parts(391_000, 0)
+		// Minimum execution time: 303_000 picoseconds.
+		Weight::from_parts(340_000, 0)
 	}
 	fn seal_caller_is_root() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 275_000 picoseconds.
-		Weight::from_parts(296_000, 0)
+		// Minimum execution time: 246_000 picoseconds.
+		Weight::from_parts(266_000, 0)
 	}
 	fn seal_address() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 262_000 picoseconds.
-		Weight::from_parts(304_000, 0)
+		// Minimum execution time: 260_000 picoseconds.
+		Weight::from_parts(287_000, 0)
 	}
 	fn seal_weight_left() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 628_000 picoseconds.
-		Weight::from_parts(714_000, 0)
+		// Minimum execution time: 616_000 picoseconds.
+		Weight::from_parts(726_000, 0)
 	}
 	fn seal_ref_time_left() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 246_000 picoseconds.
-		Weight::from_parts(265_000, 0)
+		// Minimum execution time: 253_000 picoseconds.
+		Weight::from_parts(282_000, 0)
 	}
 	fn seal_balance() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `140`
 		//  Estimated: `0`
-		// Minimum execution time: 5_605_000 picoseconds.
-		Weight::from_parts(5_769_000, 0)
+		// Minimum execution time: 5_380_000 picoseconds.
+		Weight::from_parts(5_740_000, 0)
 	}
 	/// Storage: `Revive::AddressSuffix` (r:1 w:0)
 	/// Proof: `Revive::AddressSuffix` (`max_values`: None, `max_size`: Some(32), added: 2507, mode: `Measured`)
@@ -1319,8 +1335,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `264`
 		//  Estimated: `3729`
-		// Minimum execution time: 8_990_000 picoseconds.
-		Weight::from_parts(9_223_000, 3729)
+		// Minimum execution time: 8_826_000 picoseconds.
+		Weight::from_parts(9_166_000, 3729)
 			.saturating_add(RocksDbWeight::get().reads(2_u64))
 	}
 	/// Storage: `Revive::ImmutableDataOf` (r:1 w:0)
@@ -1330,10 +1346,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `238 + n * (1 ±0)`
 		//  Estimated: `3703 + n * (1 ±0)`
-		// Minimum execution time: 6_001_000 picoseconds.
-		Weight::from_parts(6_630_017, 3703)
+		// Minimum execution time: 5_971_000 picoseconds.
+		Weight::from_parts(6_578_727, 3703)
 			// Standard Error: 4
-			.saturating_add(Weight::from_parts(622, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(732, 0).saturating_mul(n.into()))
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
@@ -1344,46 +1360,53 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 2_026_000 picoseconds.
-		Weight::from_parts(2_271_985, 0)
-			// Standard Error: 2
-			.saturating_add(Weight::from_parts(537, 0).saturating_mul(n.into()))
+		// Minimum execution time: 1_866_000 picoseconds.
+		Weight::from_parts(2_158_746, 0)
+			// Standard Error: 1
+			.saturating_add(Weight::from_parts(637, 0).saturating_mul(n.into()))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 	}
 	fn seal_value_transferred() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 287_000 picoseconds.
-		Weight::from_parts(323_000, 0)
+		// Minimum execution time: 223_000 picoseconds.
+		Weight::from_parts(279_000, 0)
 	}
 	fn seal_minimum_balance() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 230_000 picoseconds.
-		Weight::from_parts(275_000, 0)
+		// Minimum execution time: 220_000 picoseconds.
+		Weight::from_parts(245_000, 0)
 	}
 	fn seal_return_data_size() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 242_000 picoseconds.
-		Weight::from_parts(268_000, 0)
+		// Minimum execution time: 208_000 picoseconds.
+		Weight::from_parts(245_000, 0)
 	}
 	fn seal_call_data_size() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 244_000 picoseconds.
-		Weight::from_parts(271_000, 0)
+		// Minimum execution time: 211_000 picoseconds.
+		Weight::from_parts(252_000, 0)
+	}
+	fn seal_gas_limit() -> Weight {
+		// Proof Size summary in bytes:
+		//  Measured:  `0`
+		//  Estimated: `0`
+		// Minimum execution time: 282_000 picoseconds.
+		Weight::from_parts(310_000, 0)
 	}
 	fn seal_block_number() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 266_000 picoseconds.
-		Weight::from_parts(304_000, 0)
+		// Minimum execution time: 216_000 picoseconds.
+		Weight::from_parts(242_000, 0)
 	}
 	/// Storage: `System::BlockHash` (r:1 w:0)
 	/// Proof: `System::BlockHash` (`max_values`: None, `max_size`: Some(44), added: 2519, mode: `Measured`)
@@ -1391,60 +1414,60 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `30`
 		//  Estimated: `3495`
-		// Minimum execution time: 3_559_000 picoseconds.
-		Weight::from_parts(3_697_000, 3495)
+		// Minimum execution time: 3_410_000 picoseconds.
+		Weight::from_parts(3_595_000, 3495)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 	}
 	fn seal_now() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 242_000 picoseconds.
-		Weight::from_parts(294_000, 0)
+		// Minimum execution time: 214_000 picoseconds.
+		Weight::from_parts(234_000, 0)
 	}
 	fn seal_weight_to_fee() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_222_000 picoseconds.
-		Weight::from_parts(1_387_000, 0)
+		// Minimum execution time: 1_344_000 picoseconds.
+		Weight::from_parts(1_503_000, 0)
 	}
 	/// The range of component `n` is `[0, 262140]`.
 	fn seal_copy_to_contract(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 392_000 picoseconds.
-		Weight::from_parts(397_500, 0)
+		// Minimum execution time: 372_000 picoseconds.
+		Weight::from_parts(613_654, 0)
 			// Standard Error: 0
-			.saturating_add(Weight::from_parts(206, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(295, 0).saturating_mul(n.into()))
 	}
 	fn seal_call_data_load() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 267_000 picoseconds.
-		Weight::from_parts(322_000, 0)
+		// Minimum execution time: 213_000 picoseconds.
+		Weight::from_parts(243_000, 0)
 	}
 	/// The range of component `n` is `[0, 262144]`.
 	fn seal_call_data_copy(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 234_000 picoseconds.
-		Weight::from_parts(291_182, 0)
+		// Minimum execution time: 230_000 picoseconds.
+		Weight::from_parts(252_625, 0)
 			// Standard Error: 0
-			.saturating_add(Weight::from_parts(113, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(150, 0).saturating_mul(n.into()))
 	}
 	/// The range of component `n` is `[0, 262140]`.
 	fn seal_return(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 253_000 picoseconds.
-		Weight::from_parts(271_000, 0)
+		// Minimum execution time: 231_000 picoseconds.
+		Weight::from_parts(378_784, 0)
 			// Standard Error: 0
-			.saturating_add(Weight::from_parts(212, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(296, 0).saturating_mul(n.into()))
 	}
 	/// Storage: `Revive::AddressSuffix` (r:1 w:0)
 	/// Proof: `Revive::AddressSuffix` (`max_values`: None, `max_size`: Some(32), added: 2507, mode: `Measured`)
@@ -1461,10 +1484,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `324 + n * (88 ±0)`
 		//  Estimated: `3790 + n * (2563 ±0)`
-		// Minimum execution time: 22_082_000 picoseconds.
-		Weight::from_parts(22_815_417, 3790)
-			// Standard Error: 9_515
-			.saturating_add(Weight::from_parts(4_283_767, 0).saturating_mul(n.into()))
+		// Minimum execution time: 22_246_000 picoseconds.
+		Weight::from_parts(22_824_813, 3790)
+			// Standard Error: 11_423
+			.saturating_add(Weight::from_parts(4_328_279, 0).saturating_mul(n.into()))
 			.saturating_add(RocksDbWeight::get().reads(3_u64))
 			.saturating_add(RocksDbWeight::get().reads((1_u64).saturating_mul(n.into())))
 			.saturating_add(RocksDbWeight::get().writes(4_u64))
@@ -1472,56 +1495,56 @@ impl WeightInfo for () {
 			.saturating_add(Weight::from_parts(0, 2563).saturating_mul(n.into()))
 	}
 	/// The range of component `t` is `[0, 4]`.
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_deposit_event(t: u32, n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 4_242_000 picoseconds.
-		Weight::from_parts(4_360_337, 0)
-			// Standard Error: 3_223
-			.saturating_add(Weight::from_parts(201_105, 0).saturating_mul(t.into()))
-			// Standard Error: 28
-			.saturating_add(Weight::from_parts(723, 0).saturating_mul(n.into()))
+		// Minimum execution time: 4_199_000 picoseconds.
+		Weight::from_parts(4_174_861, 0)
+			// Standard Error: 2_974
+			.saturating_add(Weight::from_parts(211_154, 0).saturating_mul(t.into()))
+			// Standard Error: 30
+			.saturating_add(Weight::from_parts(1_037, 0).saturating_mul(n.into()))
 	}
 	/// The range of component `i` is `[0, 262144]`.
 	fn seal_debug_message(i: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 340_000 picoseconds.
-		Weight::from_parts(773_824, 0)
-			// Standard Error: 1
-			.saturating_add(Weight::from_parts(722, 0).saturating_mul(i.into()))
+		// Minimum execution time: 311_000 picoseconds.
+		Weight::from_parts(326_000, 0)
+			// Standard Error: 0
+			.saturating_add(Weight::from_parts(815, 0).saturating_mul(i.into()))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
 	fn get_storage_empty() -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `744`
-		//  Estimated: `744`
-		// Minimum execution time: 7_741_000 picoseconds.
-		Weight::from_parts(8_048_000, 744)
+		//  Measured:  `680`
+		//  Estimated: `680`
+		// Minimum execution time: 7_584_000 picoseconds.
+		Weight::from_parts(8_006_000, 680)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
 	fn get_storage_full() -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `10754`
-		//  Estimated: `10754`
-		// Minimum execution time: 42_314_000 picoseconds.
-		Weight::from_parts(43_255_000, 10754)
+		//  Measured:  `10690`
+		//  Estimated: `10690`
+		// Minimum execution time: 42_716_000 picoseconds.
+		Weight::from_parts(43_583_000, 10690)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
 	fn set_storage_empty() -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `744`
-		//  Estimated: `744`
-		// Minimum execution time: 8_741_000 picoseconds.
-		Weight::from_parts(9_123_000, 744)
+		//  Measured:  `680`
+		//  Estimated: `680`
+		// Minimum execution time: 8_727_000 picoseconds.
+		Weight::from_parts(9_056_000, 680)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 	}
@@ -1529,85 +1552,85 @@ impl WeightInfo for () {
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
 	fn set_storage_full() -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `10754`
-		//  Estimated: `10754`
-		// Minimum execution time: 44_703_000 picoseconds.
-		Weight::from_parts(46_403_000, 10754)
+		//  Measured:  `10690`
+		//  Estimated: `10690`
+		// Minimum execution time: 44_882_000 picoseconds.
+		Weight::from_parts(45_933_000, 10690)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
-	/// The range of component `n` is `[0, 512]`.
-	/// The range of component `o` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
+	/// The range of component `o` is `[0, 448]`.
 	fn seal_set_storage(n: u32, o: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + o * (1 ±0)`
 		//  Estimated: `247 + o * (1 ±0)`
-		// Minimum execution time: 9_285_000 picoseconds.
-		Weight::from_parts(10_046_720, 247)
-			// Standard Error: 37
-			.saturating_add(Weight::from_parts(365, 0).saturating_mul(n.into()))
-			// Standard Error: 37
-			.saturating_add(Weight::from_parts(273, 0).saturating_mul(o.into()))
+		// Minimum execution time: 9_150_000 picoseconds.
+		Weight::from_parts(9_621_151, 247)
+			// Standard Error: 43
+			.saturating_add(Weight::from_parts(554, 0).saturating_mul(n.into()))
+			// Standard Error: 43
+			.saturating_add(Weight::from_parts(645, 0).saturating_mul(o.into()))
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(o.into()))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_clear_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// Minimum execution time: 8_879_000 picoseconds.
-		Weight::from_parts(9_736_050, 247)
-			// Standard Error: 48
-			.saturating_add(Weight::from_parts(514, 0).saturating_mul(n.into()))
+		// Minimum execution time: 8_670_000 picoseconds.
+		Weight::from_parts(9_528_913, 247)
+			// Standard Error: 56
+			.saturating_add(Weight::from_parts(805, 0).saturating_mul(n.into()))
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_get_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// Minimum execution time: 8_475_000 picoseconds.
-		Weight::from_parts(9_410_206, 247)
-			// Standard Error: 58
-			.saturating_add(Weight::from_parts(1_409, 0).saturating_mul(n.into()))
+		// Minimum execution time: 8_214_000 picoseconds.
+		Weight::from_parts(9_195_285, 247)
+			// Standard Error: 70
+			.saturating_add(Weight::from_parts(1_452, 0).saturating_mul(n.into()))
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_contains_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// Minimum execution time: 8_017_000 picoseconds.
-		Weight::from_parts(8_879_089, 247)
-			// Standard Error: 51
-			.saturating_add(Weight::from_parts(512, 0).saturating_mul(n.into()))
+		// Minimum execution time: 7_947_000 picoseconds.
+		Weight::from_parts(8_633_252, 247)
+			// Standard Error: 53
+			.saturating_add(Weight::from_parts(832, 0).saturating_mul(n.into()))
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_take_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// Minimum execution time: 9_196_000 picoseconds.
-		Weight::from_parts(10_285_787, 247)
-			// Standard Error: 65
-			.saturating_add(Weight::from_parts(1_553, 0).saturating_mul(n.into()))
+		// Minimum execution time: 9_414_000 picoseconds.
+		Weight::from_parts(10_289_881, 247)
+			// Standard Error: 66
+			.saturating_add(Weight::from_parts(1_325, 0).saturating_mul(n.into()))
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
@@ -1616,87 +1639,87 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_456_000 picoseconds.
-		Weight::from_parts(1_593_000, 0)
+		// Minimum execution time: 1_424_000 picoseconds.
+		Weight::from_parts(1_511_000, 0)
 	}
 	fn set_transient_storage_full() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_897_000 picoseconds.
-		Weight::from_parts(2_059_000, 0)
+		// Minimum execution time: 1_797_000 picoseconds.
+		Weight::from_parts(1_961_000, 0)
 	}
 	fn get_transient_storage_empty() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_487_000 picoseconds.
-		Weight::from_parts(1_588_000, 0)
+		// Minimum execution time: 1_498_000 picoseconds.
+		Weight::from_parts(1_562_000, 0)
 	}
 	fn get_transient_storage_full() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_622_000 picoseconds.
-		Weight::from_parts(1_732_000, 0)
+		// Minimum execution time: 1_610_000 picoseconds.
+		Weight::from_parts(1_703_000, 0)
 	}
 	fn rollback_transient_storage() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_188_000 picoseconds.
-		Weight::from_parts(1_239_000, 0)
+		// Minimum execution time: 1_100_000 picoseconds.
+		Weight::from_parts(1_197_000, 0)
 	}
-	/// The range of component `n` is `[0, 512]`.
-	/// The range of component `o` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
+	/// The range of component `o` is `[0, 448]`.
 	fn seal_set_transient_storage(n: u32, o: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 2_269_000 picoseconds.
-		Weight::from_parts(2_528_717, 0)
-			// Standard Error: 12
-			.saturating_add(Weight::from_parts(163, 0).saturating_mul(n.into()))
-			// Standard Error: 12
-			.saturating_add(Weight::from_parts(332, 0).saturating_mul(o.into()))
+		// Minimum execution time: 2_232_000 picoseconds.
+		Weight::from_parts(2_371_207, 0)
+			// Standard Error: 13
+			.saturating_add(Weight::from_parts(385, 0).saturating_mul(n.into()))
+			// Standard Error: 13
+			.saturating_add(Weight::from_parts(471, 0).saturating_mul(o.into()))
 	}
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_clear_transient_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 2_051_000 picoseconds.
-		Weight::from_parts(2_507_009, 0)
-			// Standard Error: 20
-			.saturating_add(Weight::from_parts(309, 0).saturating_mul(n.into()))
+		// Minimum execution time: 2_015_000 picoseconds.
+		Weight::from_parts(2_374_096, 0)
+			// Standard Error: 18
+			.saturating_add(Weight::from_parts(462, 0).saturating_mul(n.into()))
 	}
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_get_transient_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_829_000 picoseconds.
-		Weight::from_parts(2_052_749, 0)
-			// Standard Error: 14
-			.saturating_add(Weight::from_parts(350, 0).saturating_mul(n.into()))
+		// Minimum execution time: 1_788_000 picoseconds.
+		Weight::from_parts(1_983_300, 0)
+			// Standard Error: 17
+			.saturating_add(Weight::from_parts(404, 0).saturating_mul(n.into()))
 	}
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_contains_transient_storage(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_717_000 picoseconds.
-		Weight::from_parts(1_930_820, 0)
-			// Standard Error: 12
-			.saturating_add(Weight::from_parts(161, 0).saturating_mul(n.into()))
+		// Minimum execution time: 1_678_000 picoseconds.
+		Weight::from_parts(1_845_442, 0)
+			// Standard Error: 15
+			.saturating_add(Weight::from_parts(228, 0).saturating_mul(n.into()))
 	}
-	/// The range of component `n` is `[0, 512]`.
+	/// The range of component `n` is `[0, 448]`.
 	fn seal_take_transient_storage(_n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 2_502_000 picoseconds.
-		Weight::from_parts(2_829_951, 0)
+		// Minimum execution time: 2_489_000 picoseconds.
+		Weight::from_parts(2_786_607, 0)
 	}
 	/// Storage: `Revive::AddressSuffix` (r:1 w:0)
 	/// Proof: `Revive::AddressSuffix` (`max_values`: None, `max_size`: Some(32), added: 2507, mode: `Measured`)
@@ -1714,10 +1737,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `1292 + t * (280 ±0)`
 		//  Estimated: `4757 + t * (2518 ±0)`
-		// Minimum execution time: 40_791_000 picoseconds.
-		Weight::from_parts(42_421_336, 4757)
-			// Standard Error: 53_086
-			.saturating_add(Weight::from_parts(2_057_850, 0).saturating_mul(t.into()))
+		// Minimum execution time: 41_653_000 picoseconds.
+		Weight::from_parts(43_075_070, 4757)
+			// Standard Error: 42_656
+			.saturating_add(Weight::from_parts(1_667_094, 0).saturating_mul(t.into()))
 			// Standard Error: 0
 			.saturating_add(Weight::from_parts(1, 0).saturating_mul(i.into()))
 			.saturating_add(RocksDbWeight::get().reads(4_u64))
@@ -1735,8 +1758,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `1237`
 		//  Estimated: `4702`
-		// Minimum execution time: 35_825_000 picoseconds.
-		Weight::from_parts(37_377_000, 4702)
+		// Minimum execution time: 36_908_000 picoseconds.
+		Weight::from_parts(37_754_000, 4702)
 			.saturating_add(RocksDbWeight::get().reads(3_u64))
 	}
 	/// Storage: `Revive::CodeInfoOf` (r:1 w:1)
@@ -1752,10 +1775,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `1310`
 		//  Estimated: `4769`
-		// Minimum execution time: 121_920_000 picoseconds.
-		Weight::from_parts(115_842_357, 4769)
+		// Minimum execution time: 120_576_000 picoseconds.
+		Weight::from_parts(112_786_790, 4769)
 			// Standard Error: 10
-			.saturating_add(Weight::from_parts(4_062, 0).saturating_mul(i.into()))
+			.saturating_add(Weight::from_parts(4_192, 0).saturating_mul(i.into()))
 			.saturating_add(RocksDbWeight::get().reads(4_u64))
 			.saturating_add(RocksDbWeight::get().writes(3_u64))
 	}
@@ -1764,64 +1787,64 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 657_000 picoseconds.
-		Weight::from_parts(2_219_539, 0)
+		// Minimum execution time: 621_000 picoseconds.
+		Weight::from_parts(3_506_910, 0)
 			// Standard Error: 3
-			.saturating_add(Weight::from_parts(1_413, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(1_489, 0).saturating_mul(n.into()))
 	}
 	/// The range of component `n` is `[0, 262144]`.
 	fn seal_hash_keccak_256(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_091_000 picoseconds.
-		Weight::from_parts(4_036_613, 0)
+		// Minimum execution time: 1_054_000 picoseconds.
+		Weight::from_parts(5_395_465, 0)
 			// Standard Error: 3
-			.saturating_add(Weight::from_parts(3_600, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(3_688, 0).saturating_mul(n.into()))
 	}
 	/// The range of component `n` is `[0, 262144]`.
 	fn seal_hash_blake2_256(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 635_000 picoseconds.
-		Weight::from_parts(4_636_213, 0)
+		// Minimum execution time: 626_000 picoseconds.
+		Weight::from_parts(3_549_376, 0)
 			// Standard Error: 3
-			.saturating_add(Weight::from_parts(1_514, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(1_596, 0).saturating_mul(n.into()))
 	}
 	/// The range of component `n` is `[0, 262144]`.
 	fn seal_hash_blake2_128(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 648_000 picoseconds.
-		Weight::from_parts(3_658_083, 0)
-			// Standard Error: 3
-			.saturating_add(Weight::from_parts(1_516, 0).saturating_mul(n.into()))
+		// Minimum execution time: 598_000 picoseconds.
+		Weight::from_parts(2_618_039, 0)
+			// Standard Error: 2
+			.saturating_add(Weight::from_parts(1_616, 0).saturating_mul(n.into()))
 	}
 	/// The range of component `n` is `[0, 261889]`.
 	fn seal_sr25519_verify(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 42_722_000 picoseconds.
-		Weight::from_parts(28_496_037, 0)
+		// Minimum execution time: 42_715_000 picoseconds.
+		Weight::from_parts(25_484_960, 0)
 			// Standard Error: 13
-			.saturating_add(Weight::from_parts(5_235, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(5_315, 0).saturating_mul(n.into()))
 	}
 	fn seal_ecdsa_recover() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 46_924_000 picoseconds.
-		Weight::from_parts(48_639_000, 0)
+		// Minimum execution time: 47_123_000 picoseconds.
+		Weight::from_parts(48_956_000, 0)
 	}
 	fn seal_ecdsa_to_eth_address() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 12_882_000 picoseconds.
-		Weight::from_parts(13_108_000, 0)
+		// Minimum execution time: 12_650_000 picoseconds.
+		Weight::from_parts(12_768_000, 0)
 	}
 	/// Storage: `Revive::CodeInfoOf` (r:1 w:1)
 	/// Proof: `Revive::CodeInfoOf` (`max_values`: None, `max_size`: Some(96), added: 2571, mode: `Measured`)
@@ -1829,8 +1852,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `300`
 		//  Estimated: `3765`
-		// Minimum execution time: 17_907_000 picoseconds.
-		Weight::from_parts(18_634_000, 3765)
+		// Minimum execution time: 18_061_000 picoseconds.
+		Weight::from_parts(18_851_000, 3765)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 	}
@@ -1840,8 +1863,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `338`
 		//  Estimated: `3803`
-		// Minimum execution time: 14_091_000 picoseconds.
-		Weight::from_parts(14_393_000, 3803)
+		// Minimum execution time: 13_779_000 picoseconds.
+		Weight::from_parts(14_320_000, 3803)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 	}
@@ -1851,8 +1874,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `338`
 		//  Estimated: `3561`
-		// Minimum execution time: 12_824_000 picoseconds.
-		Weight::from_parts(13_304_000, 3561)
+		// Minimum execution time: 12_327_000 picoseconds.
+		Weight::from_parts(13_156_000, 3561)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 	}
@@ -1861,9 +1884,9 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 9_185_000 picoseconds.
-		Weight::from_parts(10_532_230, 0)
-			// Standard Error: 189
-			.saturating_add(Weight::from_parts(71_786, 0).saturating_mul(r.into()))
+		// Minimum execution time: 9_048_000 picoseconds.
+		Weight::from_parts(10_590_154, 0)
+			// Standard Error: 82
+			.saturating_add(Weight::from_parts(72_658, 0).saturating_mul(r.into()))
 	}
 }
diff --git a/substrate/frame/revive/uapi/src/host.rs b/substrate/frame/revive/uapi/src/host.rs
index ae4479cd1549e14b012f6527e396cae8ec4da4e1..16d6f0945427cc25aecc4d01557406ba405d106a 100644
--- a/substrate/frame/revive/uapi/src/host.rs
+++ b/substrate/frame/revive/uapi/src/host.rs
@@ -330,6 +330,9 @@ pub trait HostFn: private::Sealed {
 	/// - `output`: A reference to the output data buffer to write the timestamp.
 	fn now(output: &mut [u8; 32]);
 
+	/// Returns the block ref_time limit.
+	fn gas_limit() -> u64;
+
 	/// Cease contract execution and save a data buffer as a result of the execution.
 	///
 	/// This function never returns as it stops execution of the caller.
diff --git a/substrate/frame/revive/uapi/src/host/riscv64.rs b/substrate/frame/revive/uapi/src/host/riscv64.rs
index d45e0d65646c2d8472f477067e8db0710e45ed54..9f080ddbfbf57120094ea7e71072ed23a04fc794 100644
--- a/substrate/frame/revive/uapi/src/host/riscv64.rs
+++ b/substrate/frame/revive/uapi/src/host/riscv64.rs
@@ -84,6 +84,7 @@ mod sys {
 		pub fn chain_id(out_ptr: *mut u8);
 		pub fn value_transferred(out_ptr: *mut u8);
 		pub fn now(out_ptr: *mut u8);
+		pub fn gas_limit() -> u64;
 		pub fn minimum_balance(out_ptr: *mut u8);
 		pub fn deposit_event(
 			topics_ptr: *const [u8; 32],
@@ -386,6 +387,10 @@ impl HostFn for HostFnImpl {
 		unsafe { sys::call_data_load(out_ptr.as_mut_ptr(), offset) };
 	}
 
+	fn gas_limit() -> u64 {
+		unsafe { sys::gas_limit() }
+	}
+
 	fn call_data_size() -> u64 {
 		unsafe { sys::call_data_size() }
 	}