diff --git a/prdoc/pr_6954.prdoc b/prdoc/pr_6954.prdoc
new file mode 100644
index 0000000000000000000000000000000000000000..8e8faf5fffd20f89106560855eee552b87812d9d
--- /dev/null
+++ b/prdoc/pr_6954.prdoc
@@ -0,0 +1,13 @@
+title: '[pallet-revive] implement the gas price API'
+doc:
+- audience: Runtime Dev
+  description: This PR implements the EVM gas price syscall API method. Currently
+    this is a compile time constant in revive, but in the EVM it is an opcode. Thus
+    we should provide an opcode for this in the pallet.
+crates:
+- name: pallet-revive-fixtures
+  bump: minor
+- name: pallet-revive
+  bump: minor
+- name: pallet-revive-uapi
+  bump: minor
diff --git a/substrate/frame/revive/fixtures/contracts/gas_price.rs b/substrate/frame/revive/fixtures/contracts/gas_price.rs
new file mode 100644
index 0000000000000000000000000000000000000000..c1c8109fafbee3965641f04d409ab9190eb5f882
--- /dev/null
+++ b/substrate/frame/revive/fixtures/contracts/gas_price.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 gas price 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_price().to_le_bytes());
+}
diff --git a/substrate/frame/revive/src/benchmarking/mod.rs b/substrate/frame/revive/src/benchmarking/mod.rs
index 4ddd6dfbc3720ff98d43b5ed81f64c7085557820..093f7ef706749acb43872a3c9e2acecc7bbc8e0c 100644
--- a/substrate/frame/revive/src/benchmarking/mod.rs
+++ b/substrate/frame/revive/src/benchmarking/mod.rs
@@ -23,6 +23,7 @@ mod call_builder;
 mod code;
 use self::{call_builder::CallSetup, code::WasmModule};
 use crate::{
+	evm::runtime::GAS_PRICE,
 	exec::{Key, MomentOf},
 	limits,
 	storage::WriteOutcome,
@@ -820,6 +821,17 @@ mod benchmarks {
 		assert_eq!(result.unwrap(), T::BlockWeights::get().max_block.ref_time());
 	}
 
+	#[benchmark(pov_mode = Measured)]
+	fn seal_gas_price() {
+		build_runtime!(runtime, memory: []);
+		let result;
+		#[block]
+		{
+			result = runtime.bench_gas_price(memory.as_mut_slice());
+		}
+		assert_eq!(result.unwrap(), u64::from(GAS_PRICE));
+	}
+
 	#[benchmark(pov_mode = Measured)]
 	fn seal_block_number() {
 		build_runtime!(runtime, memory: [[0u8;32], ]);
diff --git a/substrate/frame/revive/src/tests.rs b/substrate/frame/revive/src/tests.rs
index b863b52af2af67150d39461abaeb9d48a6dc240f..a09930eaac642cf261fcb0ad556dc659d49deff6 100644
--- a/substrate/frame/revive/src/tests.rs
+++ b/substrate/frame/revive/src/tests.rs
@@ -29,7 +29,7 @@ use crate::{
 		ChainExtension, Environment, Ext, RegisteredChainExtension, Result as ExtensionResult,
 		RetVal, ReturnFlags,
 	},
-	evm::GenericTransaction,
+	evm::{runtime::GAS_PRICE, GenericTransaction},
 	exec::Key,
 	limits,
 	primitives::CodeUploadReturnValue,
@@ -4364,6 +4364,24 @@ fn create1_with_value_works() {
 	});
 }
 
+#[test]
+fn gas_price_api_works() {
+	let (code, _) = compile_module("gas_price").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 price 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()), u64::from(GAS_PRICE));
+	});
+}
+
 #[test]
 fn call_data_size_api_works() {
 	let (code, _) = compile_module("call_data_size").unwrap();
diff --git a/substrate/frame/revive/src/wasm/runtime.rs b/substrate/frame/revive/src/wasm/runtime.rs
index cdf6b3b08fdc3391a9b24b2091961af179b11559..3268e0c59c2ba7dd0c73088b81a6104c9118567b 100644
--- a/substrate/frame/revive/src/wasm/runtime.rs
+++ b/substrate/frame/revive/src/wasm/runtime.rs
@@ -19,6 +19,7 @@
 
 use crate::{
 	address::AddressMapper,
+	evm::runtime::GAS_PRICE,
 	exec::{ExecError, ExecResult, Ext, Key},
 	gas::{ChargedAmount, Token},
 	limits,
@@ -324,6 +325,8 @@ pub enum RuntimeCosts {
 	BlockNumber,
 	/// Weight of calling `seal_block_hash`.
 	BlockHash,
+	/// Weight of calling `seal_gas_price`.
+	GasPrice,
 	/// Weight of calling `seal_now`.
 	Now,
 	/// Weight of calling `seal_gas_limit`.
@@ -477,6 +480,7 @@ impl<T: Config> Token<T> for RuntimeCosts {
 			MinimumBalance => T::WeightInfo::seal_minimum_balance(),
 			BlockNumber => T::WeightInfo::seal_block_number(),
 			BlockHash => T::WeightInfo::seal_block_hash(),
+			GasPrice => T::WeightInfo::seal_gas_price(),
 			Now => T::WeightInfo::seal_now(),
 			GasLimit => T::WeightInfo::seal_gas_limit(),
 			WeightToFee => T::WeightInfo::seal_weight_to_fee(),
@@ -1563,6 +1567,14 @@ pub mod env {
 		)?)
 	}
 
+	/// Returns the simulated ethereum `GASPRICE` value.
+	/// See [`pallet_revive_uapi::HostFn::gas_price`].
+	#[stable]
+	fn gas_price(&mut self, memory: &mut M) -> Result<u64, TrapReason> {
+		self.charge_gas(RuntimeCosts::GasPrice)?;
+		Ok(GAS_PRICE.into())
+	}
+
 	/// Load the latest block timestamp into the supplied buffer
 	/// See [`pallet_revive_uapi::HostFn::now`].
 	#[stable]
diff --git a/substrate/frame/revive/src/weights.rs b/substrate/frame/revive/src/weights.rs
index 3f7ede275928e8806933248b75ba45af31490e2a..78eb6740c10a2c1c6a915785b0b822f9a222346f 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: `c3bb6290af79`, CPU: `Intel(R) Xeon(R) CPU @ 2.60GHz`
+//! HOSTNAME: `8a4618716d33`, CPU: `Intel(R) Xeon(R) CPU @ 2.60GHz`
 //! WASM-EXECUTION: `Compiled`, CHAIN: `Some("dev")`, DB CACHE: `1024`
 
 // Executed Command:
@@ -84,6 +84,7 @@ pub trait WeightInfo {
 	fn seal_return_data_size() -> Weight;
 	fn seal_call_data_size() -> Weight;
 	fn seal_gas_limit() -> Weight;
+	fn seal_gas_price() -> Weight;
 	fn seal_block_number() -> Weight;
 	fn seal_block_hash() -> Weight;
 	fn seal_now() -> Weight;
@@ -139,8 +140,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `109`
 		//  Estimated: `1594`
-		// Minimum execution time: 2_749_000 picoseconds.
-		Weight::from_parts(2_844_000, 1594)
+		// Minimum execution time: 2_700_000 picoseconds.
+		Weight::from_parts(2_858_000, 1594)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
@@ -150,10 +151,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: 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()))
+		// Minimum execution time: 15_542_000 picoseconds.
+		Weight::from_parts(3_353_401, 415)
+			// Standard Error: 1_167
+			.saturating_add(Weight::from_parts(1_194_349, 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))
@@ -175,10 +176,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 	/// The range of component `c` is `[0, 262144]`.
 	fn call_with_code_per_byte(_c: u32, ) -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `1465`
-		//  Estimated: `7405`
-		// Minimum execution time: 92_898_000 picoseconds.
-		Weight::from_parts(97_241_513, 7405)
+		//  Measured:  `1502`
+		//  Estimated: `7442`
+		// Minimum execution time: 93_827_000 picoseconds.
+		Weight::from_parts(98_408_848, 7442)
 			.saturating_add(T::DbWeight::get().reads(7_u64))
 			.saturating_add(T::DbWeight::get().writes(2_u64))
 	}
@@ -198,16 +199,14 @@ 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: 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()))
+		//  Measured:  `403`
+		//  Estimated: `6343`
+		// Minimum execution time: 197_900_000 picoseconds.
+		Weight::from_parts(189_732_698, 6343)
+			// Standard Error: 9
+			.saturating_add(Weight::from_parts(4_465, 0).saturating_mul(i.into()))
 			.saturating_add(T::DbWeight::get().reads(7_u64))
 			.saturating_add(T::DbWeight::get().writes(6_u64))
 	}
@@ -230,10 +229,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `1309`
 		//  Estimated: `4760`
-		// Minimum execution time: 162_002_000 picoseconds.
-		Weight::from_parts(146_333_459, 4760)
-			// Standard Error: 15
-			.saturating_add(Weight::from_parts(4_482, 0).saturating_mul(i.into()))
+		// Minimum execution time: 162_798_000 picoseconds.
+		Weight::from_parts(148_006_239, 4760)
+			// Standard Error: 14
+			.saturating_add(Weight::from_parts(4_424, 0).saturating_mul(i.into()))
 			.saturating_add(T::DbWeight::get().reads(7_u64))
 			.saturating_add(T::DbWeight::get().writes(4_u64))
 	}
@@ -251,10 +250,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 	/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `Measured`)
 	fn call() -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `1465`
-		//  Estimated: `7405`
-		// Minimum execution time: 144_493_000 picoseconds.
-		Weight::from_parts(150_783_000, 7405)
+		//  Measured:  `1502`
+		//  Estimated: `7442`
+		// Minimum execution time: 144_505_000 picoseconds.
+		Weight::from_parts(149_799_000, 7442)
 			.saturating_add(T::DbWeight::get().reads(7_u64))
 			.saturating_add(T::DbWeight::get().writes(2_u64))
 	}
@@ -265,14 +264,12 @@ 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: 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()))
+		// Minimum execution time: 52_117_000 picoseconds.
+		Weight::from_parts(55_103_397, 3574)
 			.saturating_add(T::DbWeight::get().reads(2_u64))
 			.saturating_add(T::DbWeight::get().writes(3_u64))
 	}
@@ -286,8 +283,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `285`
 		//  Estimated: `3750`
-		// Minimum execution time: 44_921_000 picoseconds.
-		Weight::from_parts(46_970_000, 3750)
+		// Minimum execution time: 46_384_000 picoseconds.
+		Weight::from_parts(47_327_000, 3750)
 			.saturating_add(T::DbWeight::get().reads(2_u64))
 			.saturating_add(T::DbWeight::get().writes(3_u64))
 	}
@@ -299,8 +296,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `529`
 		//  Estimated: `6469`
-		// Minimum execution time: 27_070_000 picoseconds.
-		Weight::from_parts(27_897_000, 6469)
+		// Minimum execution time: 27_210_000 picoseconds.
+		Weight::from_parts(28_226_000, 6469)
 			.saturating_add(T::DbWeight::get().reads(3_u64))
 			.saturating_add(T::DbWeight::get().writes(3_u64))
 	}
@@ -312,8 +309,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `109`
 		//  Estimated: `3574`
-		// Minimum execution time: 40_939_000 picoseconds.
-		Weight::from_parts(42_250_000, 3574)
+		// Minimum execution time: 41_028_000 picoseconds.
+		Weight::from_parts(42_438_000, 3574)
 			.saturating_add(T::DbWeight::get().reads(2_u64))
 			.saturating_add(T::DbWeight::get().writes(2_u64))
 	}
@@ -325,8 +322,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `56`
 		//  Estimated: `3521`
-		// Minimum execution time: 32_804_000 picoseconds.
-		Weight::from_parts(33_965_000, 3521)
+		// Minimum execution time: 33_271_000 picoseconds.
+		Weight::from_parts(35_037_000, 3521)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(2_u64))
 	}
@@ -338,8 +335,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `145`
 		//  Estimated: `3610`
-		// Minimum execution time: 13_616_000 picoseconds.
-		Weight::from_parts(14_164_000, 3610)
+		// Minimum execution time: 13_455_000 picoseconds.
+		Weight::from_parts(14_144_000, 3610)
 			.saturating_add(T::DbWeight::get().reads(2_u64))
 	}
 	/// The range of component `r` is `[0, 1600]`.
@@ -347,24 +344,24 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// 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()))
+		// Minimum execution time: 7_514_000 picoseconds.
+		Weight::from_parts(8_642_516, 0)
+			// Standard Error: 190
+			.saturating_add(Weight::from_parts(168_973, 0).saturating_mul(r.into()))
 	}
 	fn seal_caller() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 278_000 picoseconds.
-		Weight::from_parts(312_000, 0)
+		// Minimum execution time: 341_000 picoseconds.
+		Weight::from_parts(373_000, 0)
 	}
 	fn seal_origin() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 232_000 picoseconds.
-		Weight::from_parts(252_000, 0)
+		// Minimum execution time: 280_000 picoseconds.
+		Weight::from_parts(329_000, 0)
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
 	/// Proof: `Revive::ContractInfoOf` (`max_values`: None, `max_size`: Some(1779), added: 4254, mode: `Measured`)
@@ -372,8 +369,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `306`
 		//  Estimated: `3771`
-		// Minimum execution time: 10_239_000 picoseconds.
-		Weight::from_parts(10_730_000, 3771)
+		// Minimum execution time: 10_296_000 picoseconds.
+		Weight::from_parts(10_757_000, 3771)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
@@ -382,16 +379,16 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `403`
 		//  Estimated: `3868`
-		// Minimum execution time: 11_016_000 picoseconds.
-		Weight::from_parts(11_331_000, 3868)
+		// Minimum execution time: 11_453_000 picoseconds.
+		Weight::from_parts(12_071_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: 261_000 picoseconds.
-		Weight::from_parts(298_000, 0)
+		// Minimum execution time: 266_000 picoseconds.
+		Weight::from_parts(360_000, 0)
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
 	/// Proof: `Revive::ContractInfoOf` (`max_values`: None, `max_size`: Some(1779), added: 4254, mode: `Measured`)
@@ -401,51 +398,51 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `473`
 		//  Estimated: `3938`
-		// Minimum execution time: 14_413_000 picoseconds.
-		Weight::from_parts(15_066_000, 3938)
+		// Minimum execution time: 14_463_000 picoseconds.
+		Weight::from_parts(15_085_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: 303_000 picoseconds.
-		Weight::from_parts(340_000, 0)
+		// Minimum execution time: 329_000 picoseconds.
+		Weight::from_parts(394_000, 0)
 	}
 	fn seal_caller_is_root() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 246_000 picoseconds.
-		Weight::from_parts(266_000, 0)
+		// Minimum execution time: 265_000 picoseconds.
+		Weight::from_parts(327_000, 0)
 	}
 	fn seal_address() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 260_000 picoseconds.
-		Weight::from_parts(287_000, 0)
+		// Minimum execution time: 306_000 picoseconds.
+		Weight::from_parts(359_000, 0)
 	}
 	fn seal_weight_left() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 616_000 picoseconds.
-		Weight::from_parts(726_000, 0)
+		// Minimum execution time: 653_000 picoseconds.
+		Weight::from_parts(727_000, 0)
 	}
 	fn seal_ref_time_left() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 253_000 picoseconds.
-		Weight::from_parts(282_000, 0)
+		// Minimum execution time: 257_000 picoseconds.
+		Weight::from_parts(328_000, 0)
 	}
 	fn seal_balance() -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `140`
+		//  Measured:  `174`
 		//  Estimated: `0`
-		// Minimum execution time: 5_380_000 picoseconds.
-		Weight::from_parts(5_740_000, 0)
+		// Minimum execution time: 5_572_000 picoseconds.
+		Weight::from_parts(5_858_000, 0)
 	}
 	/// Storage: `Revive::AddressSuffix` (r:1 w:0)
 	/// Proof: `Revive::AddressSuffix` (`max_values`: None, `max_size`: Some(32), added: 2507, mode: `Measured`)
@@ -455,8 +452,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `264`
 		//  Estimated: `3729`
-		// Minimum execution time: 8_826_000 picoseconds.
-		Weight::from_parts(9_166_000, 3729)
+		// Minimum execution time: 9_006_000 picoseconds.
+		Weight::from_parts(9_371_000, 3729)
 			.saturating_add(T::DbWeight::get().reads(2_u64))
 	}
 	/// Storage: `Revive::ImmutableDataOf` (r:1 w:0)
@@ -466,10 +463,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: 5_971_000 picoseconds.
-		Weight::from_parts(6_578_727, 3703)
+		// Minimum execution time: 5_853_000 picoseconds.
+		Weight::from_parts(6_592_851, 3703)
 			// Standard Error: 4
-			.saturating_add(Weight::from_parts(732, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(665, 0).saturating_mul(n.into()))
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
@@ -480,53 +477,60 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// 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()))
+		// Minimum execution time: 2_040_000 picoseconds.
+		Weight::from_parts(2_288_695, 0)
+			// Standard Error: 2
+			.saturating_add(Weight::from_parts(570, 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: 223_000 picoseconds.
-		Weight::from_parts(279_000, 0)
+		// Minimum execution time: 263_000 picoseconds.
+		Weight::from_parts(305_000, 0)
 	}
 	fn seal_minimum_balance() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 220_000 picoseconds.
-		Weight::from_parts(245_000, 0)
+		// Minimum execution time: 273_000 picoseconds.
+		Weight::from_parts(303_000, 0)
 	}
 	fn seal_return_data_size() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 208_000 picoseconds.
-		Weight::from_parts(245_000, 0)
+		// Minimum execution time: 260_000 picoseconds.
+		Weight::from_parts(304_000, 0)
 	}
 	fn seal_call_data_size() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 211_000 picoseconds.
-		Weight::from_parts(252_000, 0)
+		// Minimum execution time: 277_000 picoseconds.
+		Weight::from_parts(309_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)
+		// Minimum execution time: 298_000 picoseconds.
+		Weight::from_parts(356_000, 0)
+	}
+	fn seal_gas_price() -> Weight {
+		// Proof Size summary in bytes:
+		//  Measured:  `0`
+		//  Estimated: `0`
+		// Minimum execution time: 261_000 picoseconds.
+		Weight::from_parts(293_000, 0)
 	}
 	fn seal_block_number() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 216_000 picoseconds.
-		Weight::from_parts(242_000, 0)
+		// Minimum execution time: 257_000 picoseconds.
+		Weight::from_parts(325_000, 0)
 	}
 	/// Storage: `System::BlockHash` (r:1 w:0)
 	/// Proof: `System::BlockHash` (`max_values`: None, `max_size`: Some(44), added: 2519, mode: `Measured`)
@@ -534,48 +538,48 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `30`
 		//  Estimated: `3495`
-		// Minimum execution time: 3_410_000 picoseconds.
-		Weight::from_parts(3_595_000, 3495)
+		// Minimum execution time: 3_458_000 picoseconds.
+		Weight::from_parts(3_785_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: 214_000 picoseconds.
-		Weight::from_parts(234_000, 0)
+		// Minimum execution time: 273_000 picoseconds.
+		Weight::from_parts(328_000, 0)
 	}
 	fn seal_weight_to_fee() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_344_000 picoseconds.
-		Weight::from_parts(1_503_000, 0)
+		// Minimum execution time: 1_383_000 picoseconds.
+		Weight::from_parts(1_517_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: 372_000 picoseconds.
-		Weight::from_parts(613_654, 0)
+		// Minimum execution time: 373_000 picoseconds.
+		Weight::from_parts(630_750, 0)
 			// Standard Error: 0
-			.saturating_add(Weight::from_parts(295, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(235, 0).saturating_mul(n.into()))
 	}
 	fn seal_call_data_load() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 213_000 picoseconds.
-		Weight::from_parts(243_000, 0)
+		// Minimum execution time: 265_000 picoseconds.
+		Weight::from_parts(297_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: 230_000 picoseconds.
-		Weight::from_parts(252_625, 0)
+		// Minimum execution time: 250_000 picoseconds.
+		Weight::from_parts(219_823, 0)
 			// Standard Error: 0
 			.saturating_add(Weight::from_parts(150, 0).saturating_mul(n.into()))
 	}
@@ -584,10 +588,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 231_000 picoseconds.
-		Weight::from_parts(378_784, 0)
+		// Minimum execution time: 293_000 picoseconds.
+		Weight::from_parts(492_148, 0)
 			// Standard Error: 0
-			.saturating_add(Weight::from_parts(296, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(236, 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`)
@@ -602,12 +606,12 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 	/// The range of component `n` is `[0, 32]`.
 	fn seal_terminate(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `324 + n * (88 ±0)`
-		//  Estimated: `3790 + n * (2563 ±0)`
-		// 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()))
+		//  Measured:  `322 + n * (88 ±0)`
+		//  Estimated: `3788 + n * (2563 ±0)`
+		// Minimum execution time: 22_378_000 picoseconds.
+		Weight::from_parts(21_359_808, 3788)
+			// Standard Error: 12_515
+			.saturating_add(Weight::from_parts(4_433_373, 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))
@@ -620,22 +624,22 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// 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()))
+		// Minimum execution time: 4_250_000 picoseconds.
+		Weight::from_parts(4_275_643, 0)
+			// Standard Error: 2_911
+			.saturating_add(Weight::from_parts(197_045, 0).saturating_mul(t.into()))
+			// Standard Error: 29
+			.saturating_add(Weight::from_parts(978, 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: 311_000 picoseconds.
-		Weight::from_parts(326_000, 0)
-			// Standard Error: 0
-			.saturating_add(Weight::from_parts(815, 0).saturating_mul(i.into()))
+		// Minimum execution time: 362_000 picoseconds.
+		Weight::from_parts(68_341, 0)
+			// Standard Error: 1
+			.saturating_add(Weight::from_parts(762, 0).saturating_mul(i.into()))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
@@ -643,8 +647,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `680`
 		//  Estimated: `680`
-		// Minimum execution time: 7_584_000 picoseconds.
-		Weight::from_parts(8_006_000, 680)
+		// Minimum execution time: 7_649_000 picoseconds.
+		Weight::from_parts(7_908_000, 680)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
@@ -653,8 +657,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `10690`
 		//  Estimated: `10690`
-		// Minimum execution time: 42_716_000 picoseconds.
-		Weight::from_parts(43_583_000, 10690)
+		// Minimum execution time: 42_646_000 picoseconds.
+		Weight::from_parts(44_107_000, 10690)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
@@ -663,8 +667,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `680`
 		//  Estimated: `680`
-		// Minimum execution time: 8_727_000 picoseconds.
-		Weight::from_parts(9_056_000, 680)
+		// Minimum execution time: 8_978_000 picoseconds.
+		Weight::from_parts(9_343_000, 680)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 	}
@@ -674,8 +678,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `10690`
 		//  Estimated: `10690`
-		// Minimum execution time: 44_882_000 picoseconds.
-		Weight::from_parts(45_933_000, 10690)
+		// Minimum execution time: 44_678_000 picoseconds.
+		Weight::from_parts(46_166_000, 10690)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 	}
@@ -687,12 +691,12 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + o * (1 ±0)`
 		//  Estimated: `247 + o * (1 ±0)`
-		// 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()))
+		// Minimum execution time: 9_216_000 picoseconds.
+		Weight::from_parts(9_774_592, 247)
+			// Standard Error: 51
+			.saturating_add(Weight::from_parts(532, 0).saturating_mul(n.into()))
+			// Standard Error: 51
+			.saturating_add(Weight::from_parts(504, 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()))
@@ -704,10 +708,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// 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()))
+		// Minimum execution time: 8_800_000 picoseconds.
+		Weight::from_parts(9_758_732, 247)
+			// Standard Error: 70
+			.saturating_add(Weight::from_parts(387, 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()))
@@ -719,10 +723,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// 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()))
+		// Minimum execution time: 8_502_000 picoseconds.
+		Weight::from_parts(9_415_872, 247)
+			// Standard Error: 72
+			.saturating_add(Weight::from_parts(1_304, 0).saturating_mul(n.into()))
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
@@ -733,10 +737,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// 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()))
+		// Minimum execution time: 8_003_000 picoseconds.
+		Weight::from_parts(8_757_027, 247)
+			// Standard Error: 64
+			.saturating_add(Weight::from_parts(508, 0).saturating_mul(n.into()))
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
@@ -747,10 +751,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// 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()))
+		// Minimum execution time: 9_369_000 picoseconds.
+		Weight::from_parts(10_394_508, 247)
+			// Standard Error: 70
+			.saturating_add(Weight::from_parts(1_404, 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()))
@@ -759,36 +763,36 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_424_000 picoseconds.
-		Weight::from_parts(1_511_000, 0)
+		// Minimum execution time: 1_457_000 picoseconds.
+		Weight::from_parts(1_595_000, 0)
 	}
 	fn set_transient_storage_full() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_797_000 picoseconds.
-		Weight::from_parts(1_961_000, 0)
+		// Minimum execution time: 1_894_000 picoseconds.
+		Weight::from_parts(2_062_000, 0)
 	}
 	fn get_transient_storage_empty() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_498_000 picoseconds.
-		Weight::from_parts(1_562_000, 0)
+		// Minimum execution time: 1_535_000 picoseconds.
+		Weight::from_parts(1_586_000, 0)
 	}
 	fn get_transient_storage_full() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_610_000 picoseconds.
-		Weight::from_parts(1_703_000, 0)
+		// Minimum execution time: 1_706_000 picoseconds.
+		Weight::from_parts(1_850_000, 0)
 	}
 	fn rollback_transient_storage() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_100_000 picoseconds.
-		Weight::from_parts(1_197_000, 0)
+		// Minimum execution time: 1_198_000 picoseconds.
+		Weight::from_parts(1_325_000, 0)
 	}
 	/// The range of component `n` is `[0, 448]`.
 	/// The range of component `o` is `[0, 448]`.
@@ -796,50 +800,50 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// 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()))
+		// Minimum execution time: 2_324_000 picoseconds.
+		Weight::from_parts(2_397_504, 0)
+			// Standard Error: 16
+			.saturating_add(Weight::from_parts(379, 0).saturating_mul(n.into()))
+			// Standard Error: 16
+			.saturating_add(Weight::from_parts(524, 0).saturating_mul(o.into()))
 	}
 	/// 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_015_000 picoseconds.
-		Weight::from_parts(2_374_096, 0)
-			// Standard Error: 18
-			.saturating_add(Weight::from_parts(462, 0).saturating_mul(n.into()))
+		// Minimum execution time: 2_072_000 picoseconds.
+		Weight::from_parts(2_408_702, 0)
+			// Standard Error: 23
+			.saturating_add(Weight::from_parts(432, 0).saturating_mul(n.into()))
 	}
 	/// 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_788_000 picoseconds.
-		Weight::from_parts(1_983_300, 0)
-			// Standard Error: 17
-			.saturating_add(Weight::from_parts(404, 0).saturating_mul(n.into()))
+		// Minimum execution time: 1_930_000 picoseconds.
+		Weight::from_parts(2_120_317, 0)
+			// Standard Error: 18
+			.saturating_add(Weight::from_parts(391, 0).saturating_mul(n.into()))
 	}
 	/// 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_678_000 picoseconds.
-		Weight::from_parts(1_845_442, 0)
-			// Standard Error: 15
-			.saturating_add(Weight::from_parts(228, 0).saturating_mul(n.into()))
+		// Minimum execution time: 1_755_000 picoseconds.
+		Weight::from_parts(1_968_623, 0)
+			// Standard Error: 14
+			.saturating_add(Weight::from_parts(191, 0).saturating_mul(n.into()))
 	}
 	/// 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_489_000 picoseconds.
-		Weight::from_parts(2_786_607, 0)
+		// Minimum execution time: 2_567_000 picoseconds.
+		Weight::from_parts(2_841_579, 0)
 	}
 	/// Storage: `Revive::AddressSuffix` (r:1 w:0)
 	/// Proof: `Revive::AddressSuffix` (`max_values`: None, `max_size`: Some(32), added: 2507, mode: `Measured`)
@@ -853,20 +857,18 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 	/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `Measured`)
 	/// The range of component `t` is `[0, 1]`.
 	/// The range of component `i` is `[0, 262144]`.
-	fn seal_call(t: u32, i: u32, ) -> Weight {
-		// Proof Size summary in bytes:
-		//  Measured:  `1292 + t * (280 ±0)`
-		//  Estimated: `4757 + t * (2518 ±0)`
-		// 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()))
+	fn seal_call(t: u32, _i: u32, ) -> Weight {
+		// Proof Size summary in bytes:
+		//  Measured:  `1292 + t * (314 ±0)`
+		//  Estimated: `4757 + t * (2535 ±0)`
+		// Minimum execution time: 40_925_000 picoseconds.
+		Weight::from_parts(42_866_040, 4757)
+			// Standard Error: 99_028
+			.saturating_add(Weight::from_parts(2_467_746, 0).saturating_mul(t.into()))
 			.saturating_add(T::DbWeight::get().reads(4_u64))
 			.saturating_add(T::DbWeight::get().reads((1_u64).saturating_mul(t.into())))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
-			.saturating_add(Weight::from_parts(0, 2518).saturating_mul(t.into()))
+			.saturating_add(Weight::from_parts(0, 2535).saturating_mul(t.into()))
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
 	/// Proof: `Revive::ContractInfoOf` (`max_values`: None, `max_size`: Some(1779), added: 4254, mode: `Measured`)
@@ -878,8 +880,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `1237`
 		//  Estimated: `4702`
-		// Minimum execution time: 36_908_000 picoseconds.
-		Weight::from_parts(37_754_000, 4702)
+		// Minimum execution time: 36_048_000 picoseconds.
+		Weight::from_parts(37_921_000, 4702)
 			.saturating_add(T::DbWeight::get().reads(3_u64))
 	}
 	/// Storage: `Revive::CodeInfoOf` (r:1 w:1)
@@ -893,12 +895,12 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 	/// The range of component `i` is `[0, 262144]`.
 	fn seal_instantiate(i: u32, ) -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `1310`
-		//  Estimated: `4769`
-		// Minimum execution time: 120_576_000 picoseconds.
-		Weight::from_parts(112_786_790, 4769)
+		//  Measured:  `1331`
+		//  Estimated: `4796`
+		// Minimum execution time: 121_507_000 picoseconds.
+		Weight::from_parts(115_250_696, 4796)
 			// Standard Error: 10
-			.saturating_add(Weight::from_parts(4_192, 0).saturating_mul(i.into()))
+			.saturating_add(Weight::from_parts(4_136, 0).saturating_mul(i.into()))
 			.saturating_add(T::DbWeight::get().reads(4_u64))
 			.saturating_add(T::DbWeight::get().writes(3_u64))
 	}
@@ -907,64 +909,64 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 621_000 picoseconds.
-		Weight::from_parts(3_506_910, 0)
+		// Minimum execution time: 649_000 picoseconds.
+		Weight::from_parts(3_208_110, 0)
 			// Standard Error: 3
-			.saturating_add(Weight::from_parts(1_489, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(1_439, 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_054_000 picoseconds.
-		Weight::from_parts(5_395_465, 0)
-			// Standard Error: 3
-			.saturating_add(Weight::from_parts(3_688, 0).saturating_mul(n.into()))
+		// Minimum execution time: 1_078_000 picoseconds.
+		Weight::from_parts(3_361_333, 0)
+			// Standard Error: 4
+			.saturating_add(Weight::from_parts(3_648, 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: 626_000 picoseconds.
-		Weight::from_parts(3_549_376, 0)
+		// Minimum execution time: 673_000 picoseconds.
+		Weight::from_parts(3_115_184, 0)
 			// Standard Error: 3
-			.saturating_add(Weight::from_parts(1_596, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(1_557, 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: 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()))
+		// Minimum execution time: 685_000 picoseconds.
+		Weight::from_parts(3_752_567, 0)
+			// Standard Error: 3
+			.saturating_add(Weight::from_parts(1_549, 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_715_000 picoseconds.
-		Weight::from_parts(25_484_960, 0)
-			// Standard Error: 13
-			.saturating_add(Weight::from_parts(5_315, 0).saturating_mul(n.into()))
+		// Minimum execution time: 42_901_000 picoseconds.
+		Weight::from_parts(30_989_396, 0)
+			// Standard Error: 11
+			.saturating_add(Weight::from_parts(5_414, 0).saturating_mul(n.into()))
 	}
 	fn seal_ecdsa_recover() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 47_123_000 picoseconds.
-		Weight::from_parts(48_956_000, 0)
+		// Minimum execution time: 47_249_000 picoseconds.
+		Weight::from_parts(48_530_000, 0)
 	}
 	fn seal_ecdsa_to_eth_address() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 12_650_000 picoseconds.
-		Weight::from_parts(12_768_000, 0)
+		// Minimum execution time: 12_873_000 picoseconds.
+		Weight::from_parts(13_127_000, 0)
 	}
 	/// Storage: `Revive::CodeInfoOf` (r:1 w:1)
 	/// Proof: `Revive::CodeInfoOf` (`max_values`: None, `max_size`: Some(96), added: 2571, mode: `Measured`)
@@ -972,8 +974,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `300`
 		//  Estimated: `3765`
-		// Minimum execution time: 18_061_000 picoseconds.
-		Weight::from_parts(18_851_000, 3765)
+		// Minimum execution time: 18_436_000 picoseconds.
+		Weight::from_parts(19_107_000, 3765)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 	}
@@ -983,8 +985,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `338`
 		//  Estimated: `3803`
-		// Minimum execution time: 13_779_000 picoseconds.
-		Weight::from_parts(14_320_000, 3803)
+		// Minimum execution time: 13_894_000 picoseconds.
+		Weight::from_parts(14_355_000, 3803)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 	}
@@ -994,8 +996,8 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `338`
 		//  Estimated: `3561`
-		// Minimum execution time: 12_327_000 picoseconds.
-		Weight::from_parts(13_156_000, 3561)
+		// Minimum execution time: 12_516_000 picoseconds.
+		Weight::from_parts(13_223_000, 3561)
 			.saturating_add(T::DbWeight::get().reads(1_u64))
 			.saturating_add(T::DbWeight::get().writes(1_u64))
 	}
@@ -1004,10 +1006,10 @@ impl<T: frame_system::Config> WeightInfo for SubstrateWeight<T> {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// 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()))
+		// Minimum execution time: 9_177_000 picoseconds.
+		Weight::from_parts(11_420_562, 0)
+			// Standard Error: 99
+			.saturating_add(Weight::from_parts(72_860, 0).saturating_mul(r.into()))
 	}
 }
 
@@ -1019,8 +1021,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `109`
 		//  Estimated: `1594`
-		// Minimum execution time: 2_749_000 picoseconds.
-		Weight::from_parts(2_844_000, 1594)
+		// Minimum execution time: 2_700_000 picoseconds.
+		Weight::from_parts(2_858_000, 1594)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
@@ -1030,10 +1032,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `425 + k * (69 ±0)`
 		//  Estimated: `415 + k * (70 ±0)`
-		// 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()))
+		// Minimum execution time: 15_542_000 picoseconds.
+		Weight::from_parts(3_353_401, 415)
+			// Standard Error: 1_167
+			.saturating_add(Weight::from_parts(1_194_349, 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))
@@ -1055,10 +1057,10 @@ impl WeightInfo for () {
 	/// The range of component `c` is `[0, 262144]`.
 	fn call_with_code_per_byte(_c: u32, ) -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `1465`
-		//  Estimated: `7405`
-		// Minimum execution time: 92_898_000 picoseconds.
-		Weight::from_parts(97_241_513, 7405)
+		//  Measured:  `1502`
+		//  Estimated: `7442`
+		// Minimum execution time: 93_827_000 picoseconds.
+		Weight::from_parts(98_408_848, 7442)
 			.saturating_add(RocksDbWeight::get().reads(7_u64))
 			.saturating_add(RocksDbWeight::get().writes(2_u64))
 	}
@@ -1078,16 +1080,14 @@ 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: 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()))
+		//  Measured:  `403`
+		//  Estimated: `6343`
+		// Minimum execution time: 197_900_000 picoseconds.
+		Weight::from_parts(189_732_698, 6343)
+			// Standard Error: 9
+			.saturating_add(Weight::from_parts(4_465, 0).saturating_mul(i.into()))
 			.saturating_add(RocksDbWeight::get().reads(7_u64))
 			.saturating_add(RocksDbWeight::get().writes(6_u64))
 	}
@@ -1110,10 +1110,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `1309`
 		//  Estimated: `4760`
-		// Minimum execution time: 162_002_000 picoseconds.
-		Weight::from_parts(146_333_459, 4760)
-			// Standard Error: 15
-			.saturating_add(Weight::from_parts(4_482, 0).saturating_mul(i.into()))
+		// Minimum execution time: 162_798_000 picoseconds.
+		Weight::from_parts(148_006_239, 4760)
+			// Standard Error: 14
+			.saturating_add(Weight::from_parts(4_424, 0).saturating_mul(i.into()))
 			.saturating_add(RocksDbWeight::get().reads(7_u64))
 			.saturating_add(RocksDbWeight::get().writes(4_u64))
 	}
@@ -1131,10 +1131,10 @@ impl WeightInfo for () {
 	/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `Measured`)
 	fn call() -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `1465`
-		//  Estimated: `7405`
-		// Minimum execution time: 144_493_000 picoseconds.
-		Weight::from_parts(150_783_000, 7405)
+		//  Measured:  `1502`
+		//  Estimated: `7442`
+		// Minimum execution time: 144_505_000 picoseconds.
+		Weight::from_parts(149_799_000, 7442)
 			.saturating_add(RocksDbWeight::get().reads(7_u64))
 			.saturating_add(RocksDbWeight::get().writes(2_u64))
 	}
@@ -1145,14 +1145,12 @@ 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: 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()))
+		// Minimum execution time: 52_117_000 picoseconds.
+		Weight::from_parts(55_103_397, 3574)
 			.saturating_add(RocksDbWeight::get().reads(2_u64))
 			.saturating_add(RocksDbWeight::get().writes(3_u64))
 	}
@@ -1166,8 +1164,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `285`
 		//  Estimated: `3750`
-		// Minimum execution time: 44_921_000 picoseconds.
-		Weight::from_parts(46_970_000, 3750)
+		// Minimum execution time: 46_384_000 picoseconds.
+		Weight::from_parts(47_327_000, 3750)
 			.saturating_add(RocksDbWeight::get().reads(2_u64))
 			.saturating_add(RocksDbWeight::get().writes(3_u64))
 	}
@@ -1179,8 +1177,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `529`
 		//  Estimated: `6469`
-		// Minimum execution time: 27_070_000 picoseconds.
-		Weight::from_parts(27_897_000, 6469)
+		// Minimum execution time: 27_210_000 picoseconds.
+		Weight::from_parts(28_226_000, 6469)
 			.saturating_add(RocksDbWeight::get().reads(3_u64))
 			.saturating_add(RocksDbWeight::get().writes(3_u64))
 	}
@@ -1192,8 +1190,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `109`
 		//  Estimated: `3574`
-		// Minimum execution time: 40_939_000 picoseconds.
-		Weight::from_parts(42_250_000, 3574)
+		// Minimum execution time: 41_028_000 picoseconds.
+		Weight::from_parts(42_438_000, 3574)
 			.saturating_add(RocksDbWeight::get().reads(2_u64))
 			.saturating_add(RocksDbWeight::get().writes(2_u64))
 	}
@@ -1205,8 +1203,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `56`
 		//  Estimated: `3521`
-		// Minimum execution time: 32_804_000 picoseconds.
-		Weight::from_parts(33_965_000, 3521)
+		// Minimum execution time: 33_271_000 picoseconds.
+		Weight::from_parts(35_037_000, 3521)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(2_u64))
 	}
@@ -1218,8 +1216,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `145`
 		//  Estimated: `3610`
-		// Minimum execution time: 13_616_000 picoseconds.
-		Weight::from_parts(14_164_000, 3610)
+		// Minimum execution time: 13_455_000 picoseconds.
+		Weight::from_parts(14_144_000, 3610)
 			.saturating_add(RocksDbWeight::get().reads(2_u64))
 	}
 	/// The range of component `r` is `[0, 1600]`.
@@ -1227,24 +1225,24 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// 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()))
+		// Minimum execution time: 7_514_000 picoseconds.
+		Weight::from_parts(8_642_516, 0)
+			// Standard Error: 190
+			.saturating_add(Weight::from_parts(168_973, 0).saturating_mul(r.into()))
 	}
 	fn seal_caller() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 278_000 picoseconds.
-		Weight::from_parts(312_000, 0)
+		// Minimum execution time: 341_000 picoseconds.
+		Weight::from_parts(373_000, 0)
 	}
 	fn seal_origin() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 232_000 picoseconds.
-		Weight::from_parts(252_000, 0)
+		// Minimum execution time: 280_000 picoseconds.
+		Weight::from_parts(329_000, 0)
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
 	/// Proof: `Revive::ContractInfoOf` (`max_values`: None, `max_size`: Some(1779), added: 4254, mode: `Measured`)
@@ -1252,8 +1250,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `306`
 		//  Estimated: `3771`
-		// Minimum execution time: 10_239_000 picoseconds.
-		Weight::from_parts(10_730_000, 3771)
+		// Minimum execution time: 10_296_000 picoseconds.
+		Weight::from_parts(10_757_000, 3771)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
@@ -1262,16 +1260,16 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `403`
 		//  Estimated: `3868`
-		// Minimum execution time: 11_016_000 picoseconds.
-		Weight::from_parts(11_331_000, 3868)
+		// Minimum execution time: 11_453_000 picoseconds.
+		Weight::from_parts(12_071_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: 261_000 picoseconds.
-		Weight::from_parts(298_000, 0)
+		// Minimum execution time: 266_000 picoseconds.
+		Weight::from_parts(360_000, 0)
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
 	/// Proof: `Revive::ContractInfoOf` (`max_values`: None, `max_size`: Some(1779), added: 4254, mode: `Measured`)
@@ -1281,51 +1279,51 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `473`
 		//  Estimated: `3938`
-		// Minimum execution time: 14_413_000 picoseconds.
-		Weight::from_parts(15_066_000, 3938)
+		// Minimum execution time: 14_463_000 picoseconds.
+		Weight::from_parts(15_085_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: 303_000 picoseconds.
-		Weight::from_parts(340_000, 0)
+		// Minimum execution time: 329_000 picoseconds.
+		Weight::from_parts(394_000, 0)
 	}
 	fn seal_caller_is_root() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 246_000 picoseconds.
-		Weight::from_parts(266_000, 0)
+		// Minimum execution time: 265_000 picoseconds.
+		Weight::from_parts(327_000, 0)
 	}
 	fn seal_address() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 260_000 picoseconds.
-		Weight::from_parts(287_000, 0)
+		// Minimum execution time: 306_000 picoseconds.
+		Weight::from_parts(359_000, 0)
 	}
 	fn seal_weight_left() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 616_000 picoseconds.
-		Weight::from_parts(726_000, 0)
+		// Minimum execution time: 653_000 picoseconds.
+		Weight::from_parts(727_000, 0)
 	}
 	fn seal_ref_time_left() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 253_000 picoseconds.
-		Weight::from_parts(282_000, 0)
+		// Minimum execution time: 257_000 picoseconds.
+		Weight::from_parts(328_000, 0)
 	}
 	fn seal_balance() -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `140`
+		//  Measured:  `174`
 		//  Estimated: `0`
-		// Minimum execution time: 5_380_000 picoseconds.
-		Weight::from_parts(5_740_000, 0)
+		// Minimum execution time: 5_572_000 picoseconds.
+		Weight::from_parts(5_858_000, 0)
 	}
 	/// Storage: `Revive::AddressSuffix` (r:1 w:0)
 	/// Proof: `Revive::AddressSuffix` (`max_values`: None, `max_size`: Some(32), added: 2507, mode: `Measured`)
@@ -1335,8 +1333,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `264`
 		//  Estimated: `3729`
-		// Minimum execution time: 8_826_000 picoseconds.
-		Weight::from_parts(9_166_000, 3729)
+		// Minimum execution time: 9_006_000 picoseconds.
+		Weight::from_parts(9_371_000, 3729)
 			.saturating_add(RocksDbWeight::get().reads(2_u64))
 	}
 	/// Storage: `Revive::ImmutableDataOf` (r:1 w:0)
@@ -1346,10 +1344,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `238 + n * (1 ±0)`
 		//  Estimated: `3703 + n * (1 ±0)`
-		// Minimum execution time: 5_971_000 picoseconds.
-		Weight::from_parts(6_578_727, 3703)
+		// Minimum execution time: 5_853_000 picoseconds.
+		Weight::from_parts(6_592_851, 3703)
 			// Standard Error: 4
-			.saturating_add(Weight::from_parts(732, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(665, 0).saturating_mul(n.into()))
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
@@ -1360,53 +1358,60 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// 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()))
+		// Minimum execution time: 2_040_000 picoseconds.
+		Weight::from_parts(2_288_695, 0)
+			// Standard Error: 2
+			.saturating_add(Weight::from_parts(570, 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: 223_000 picoseconds.
-		Weight::from_parts(279_000, 0)
+		// Minimum execution time: 263_000 picoseconds.
+		Weight::from_parts(305_000, 0)
 	}
 	fn seal_minimum_balance() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 220_000 picoseconds.
-		Weight::from_parts(245_000, 0)
+		// Minimum execution time: 273_000 picoseconds.
+		Weight::from_parts(303_000, 0)
 	}
 	fn seal_return_data_size() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 208_000 picoseconds.
-		Weight::from_parts(245_000, 0)
+		// Minimum execution time: 260_000 picoseconds.
+		Weight::from_parts(304_000, 0)
 	}
 	fn seal_call_data_size() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 211_000 picoseconds.
-		Weight::from_parts(252_000, 0)
+		// Minimum execution time: 277_000 picoseconds.
+		Weight::from_parts(309_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)
+		// Minimum execution time: 298_000 picoseconds.
+		Weight::from_parts(356_000, 0)
+	}
+	fn seal_gas_price() -> Weight {
+		// Proof Size summary in bytes:
+		//  Measured:  `0`
+		//  Estimated: `0`
+		// Minimum execution time: 261_000 picoseconds.
+		Weight::from_parts(293_000, 0)
 	}
 	fn seal_block_number() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 216_000 picoseconds.
-		Weight::from_parts(242_000, 0)
+		// Minimum execution time: 257_000 picoseconds.
+		Weight::from_parts(325_000, 0)
 	}
 	/// Storage: `System::BlockHash` (r:1 w:0)
 	/// Proof: `System::BlockHash` (`max_values`: None, `max_size`: Some(44), added: 2519, mode: `Measured`)
@@ -1414,48 +1419,48 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `30`
 		//  Estimated: `3495`
-		// Minimum execution time: 3_410_000 picoseconds.
-		Weight::from_parts(3_595_000, 3495)
+		// Minimum execution time: 3_458_000 picoseconds.
+		Weight::from_parts(3_785_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: 214_000 picoseconds.
-		Weight::from_parts(234_000, 0)
+		// Minimum execution time: 273_000 picoseconds.
+		Weight::from_parts(328_000, 0)
 	}
 	fn seal_weight_to_fee() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_344_000 picoseconds.
-		Weight::from_parts(1_503_000, 0)
+		// Minimum execution time: 1_383_000 picoseconds.
+		Weight::from_parts(1_517_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: 372_000 picoseconds.
-		Weight::from_parts(613_654, 0)
+		// Minimum execution time: 373_000 picoseconds.
+		Weight::from_parts(630_750, 0)
 			// Standard Error: 0
-			.saturating_add(Weight::from_parts(295, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(235, 0).saturating_mul(n.into()))
 	}
 	fn seal_call_data_load() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 213_000 picoseconds.
-		Weight::from_parts(243_000, 0)
+		// Minimum execution time: 265_000 picoseconds.
+		Weight::from_parts(297_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: 230_000 picoseconds.
-		Weight::from_parts(252_625, 0)
+		// Minimum execution time: 250_000 picoseconds.
+		Weight::from_parts(219_823, 0)
 			// Standard Error: 0
 			.saturating_add(Weight::from_parts(150, 0).saturating_mul(n.into()))
 	}
@@ -1464,10 +1469,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 231_000 picoseconds.
-		Weight::from_parts(378_784, 0)
+		// Minimum execution time: 293_000 picoseconds.
+		Weight::from_parts(492_148, 0)
 			// Standard Error: 0
-			.saturating_add(Weight::from_parts(296, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(236, 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`)
@@ -1482,12 +1487,12 @@ impl WeightInfo for () {
 	/// The range of component `n` is `[0, 32]`.
 	fn seal_terminate(n: u32, ) -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `324 + n * (88 ±0)`
-		//  Estimated: `3790 + n * (2563 ±0)`
-		// 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()))
+		//  Measured:  `322 + n * (88 ±0)`
+		//  Estimated: `3788 + n * (2563 ±0)`
+		// Minimum execution time: 22_378_000 picoseconds.
+		Weight::from_parts(21_359_808, 3788)
+			// Standard Error: 12_515
+			.saturating_add(Weight::from_parts(4_433_373, 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))
@@ -1500,22 +1505,22 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// 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()))
+		// Minimum execution time: 4_250_000 picoseconds.
+		Weight::from_parts(4_275_643, 0)
+			// Standard Error: 2_911
+			.saturating_add(Weight::from_parts(197_045, 0).saturating_mul(t.into()))
+			// Standard Error: 29
+			.saturating_add(Weight::from_parts(978, 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: 311_000 picoseconds.
-		Weight::from_parts(326_000, 0)
-			// Standard Error: 0
-			.saturating_add(Weight::from_parts(815, 0).saturating_mul(i.into()))
+		// Minimum execution time: 362_000 picoseconds.
+		Weight::from_parts(68_341, 0)
+			// Standard Error: 1
+			.saturating_add(Weight::from_parts(762, 0).saturating_mul(i.into()))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
 	/// Proof: `Skipped::Metadata` (`max_values`: None, `max_size`: None, mode: `Measured`)
@@ -1523,8 +1528,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `680`
 		//  Estimated: `680`
-		// Minimum execution time: 7_584_000 picoseconds.
-		Weight::from_parts(8_006_000, 680)
+		// Minimum execution time: 7_649_000 picoseconds.
+		Weight::from_parts(7_908_000, 680)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
@@ -1533,8 +1538,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `10690`
 		//  Estimated: `10690`
-		// Minimum execution time: 42_716_000 picoseconds.
-		Weight::from_parts(43_583_000, 10690)
+		// Minimum execution time: 42_646_000 picoseconds.
+		Weight::from_parts(44_107_000, 10690)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 	}
 	/// Storage: `Skipped::Metadata` (r:0 w:0)
@@ -1543,8 +1548,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `680`
 		//  Estimated: `680`
-		// Minimum execution time: 8_727_000 picoseconds.
-		Weight::from_parts(9_056_000, 680)
+		// Minimum execution time: 8_978_000 picoseconds.
+		Weight::from_parts(9_343_000, 680)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 	}
@@ -1554,8 +1559,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `10690`
 		//  Estimated: `10690`
-		// Minimum execution time: 44_882_000 picoseconds.
-		Weight::from_parts(45_933_000, 10690)
+		// Minimum execution time: 44_678_000 picoseconds.
+		Weight::from_parts(46_166_000, 10690)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 	}
@@ -1567,12 +1572,12 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + o * (1 ±0)`
 		//  Estimated: `247 + o * (1 ±0)`
-		// 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()))
+		// Minimum execution time: 9_216_000 picoseconds.
+		Weight::from_parts(9_774_592, 247)
+			// Standard Error: 51
+			.saturating_add(Weight::from_parts(532, 0).saturating_mul(n.into()))
+			// Standard Error: 51
+			.saturating_add(Weight::from_parts(504, 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()))
@@ -1584,10 +1589,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// 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()))
+		// Minimum execution time: 8_800_000 picoseconds.
+		Weight::from_parts(9_758_732, 247)
+			// Standard Error: 70
+			.saturating_add(Weight::from_parts(387, 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()))
@@ -1599,10 +1604,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// 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()))
+		// Minimum execution time: 8_502_000 picoseconds.
+		Weight::from_parts(9_415_872, 247)
+			// Standard Error: 72
+			.saturating_add(Weight::from_parts(1_304, 0).saturating_mul(n.into()))
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
@@ -1613,10 +1618,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// 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()))
+		// Minimum execution time: 8_003_000 picoseconds.
+		Weight::from_parts(8_757_027, 247)
+			// Standard Error: 64
+			.saturating_add(Weight::from_parts(508, 0).saturating_mul(n.into()))
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(Weight::from_parts(0, 1).saturating_mul(n.into()))
 	}
@@ -1627,10 +1632,10 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `248 + n * (1 ±0)`
 		//  Estimated: `247 + n * (1 ±0)`
-		// 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()))
+		// Minimum execution time: 9_369_000 picoseconds.
+		Weight::from_parts(10_394_508, 247)
+			// Standard Error: 70
+			.saturating_add(Weight::from_parts(1_404, 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()))
@@ -1639,36 +1644,36 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_424_000 picoseconds.
-		Weight::from_parts(1_511_000, 0)
+		// Minimum execution time: 1_457_000 picoseconds.
+		Weight::from_parts(1_595_000, 0)
 	}
 	fn set_transient_storage_full() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_797_000 picoseconds.
-		Weight::from_parts(1_961_000, 0)
+		// Minimum execution time: 1_894_000 picoseconds.
+		Weight::from_parts(2_062_000, 0)
 	}
 	fn get_transient_storage_empty() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_498_000 picoseconds.
-		Weight::from_parts(1_562_000, 0)
+		// Minimum execution time: 1_535_000 picoseconds.
+		Weight::from_parts(1_586_000, 0)
 	}
 	fn get_transient_storage_full() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_610_000 picoseconds.
-		Weight::from_parts(1_703_000, 0)
+		// Minimum execution time: 1_706_000 picoseconds.
+		Weight::from_parts(1_850_000, 0)
 	}
 	fn rollback_transient_storage() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 1_100_000 picoseconds.
-		Weight::from_parts(1_197_000, 0)
+		// Minimum execution time: 1_198_000 picoseconds.
+		Weight::from_parts(1_325_000, 0)
 	}
 	/// The range of component `n` is `[0, 448]`.
 	/// The range of component `o` is `[0, 448]`.
@@ -1676,50 +1681,50 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// 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()))
+		// Minimum execution time: 2_324_000 picoseconds.
+		Weight::from_parts(2_397_504, 0)
+			// Standard Error: 16
+			.saturating_add(Weight::from_parts(379, 0).saturating_mul(n.into()))
+			// Standard Error: 16
+			.saturating_add(Weight::from_parts(524, 0).saturating_mul(o.into()))
 	}
 	/// 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_015_000 picoseconds.
-		Weight::from_parts(2_374_096, 0)
-			// Standard Error: 18
-			.saturating_add(Weight::from_parts(462, 0).saturating_mul(n.into()))
+		// Minimum execution time: 2_072_000 picoseconds.
+		Weight::from_parts(2_408_702, 0)
+			// Standard Error: 23
+			.saturating_add(Weight::from_parts(432, 0).saturating_mul(n.into()))
 	}
 	/// 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_788_000 picoseconds.
-		Weight::from_parts(1_983_300, 0)
-			// Standard Error: 17
-			.saturating_add(Weight::from_parts(404, 0).saturating_mul(n.into()))
+		// Minimum execution time: 1_930_000 picoseconds.
+		Weight::from_parts(2_120_317, 0)
+			// Standard Error: 18
+			.saturating_add(Weight::from_parts(391, 0).saturating_mul(n.into()))
 	}
 	/// 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_678_000 picoseconds.
-		Weight::from_parts(1_845_442, 0)
-			// Standard Error: 15
-			.saturating_add(Weight::from_parts(228, 0).saturating_mul(n.into()))
+		// Minimum execution time: 1_755_000 picoseconds.
+		Weight::from_parts(1_968_623, 0)
+			// Standard Error: 14
+			.saturating_add(Weight::from_parts(191, 0).saturating_mul(n.into()))
 	}
 	/// 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_489_000 picoseconds.
-		Weight::from_parts(2_786_607, 0)
+		// Minimum execution time: 2_567_000 picoseconds.
+		Weight::from_parts(2_841_579, 0)
 	}
 	/// Storage: `Revive::AddressSuffix` (r:1 w:0)
 	/// Proof: `Revive::AddressSuffix` (`max_values`: None, `max_size`: Some(32), added: 2507, mode: `Measured`)
@@ -1733,20 +1738,18 @@ impl WeightInfo for () {
 	/// Proof: `System::Account` (`max_values`: None, `max_size`: Some(128), added: 2603, mode: `Measured`)
 	/// The range of component `t` is `[0, 1]`.
 	/// The range of component `i` is `[0, 262144]`.
-	fn seal_call(t: u32, i: u32, ) -> Weight {
-		// Proof Size summary in bytes:
-		//  Measured:  `1292 + t * (280 ±0)`
-		//  Estimated: `4757 + t * (2518 ±0)`
-		// 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()))
+	fn seal_call(t: u32, _i: u32, ) -> Weight {
+		// Proof Size summary in bytes:
+		//  Measured:  `1292 + t * (314 ±0)`
+		//  Estimated: `4757 + t * (2535 ±0)`
+		// Minimum execution time: 40_925_000 picoseconds.
+		Weight::from_parts(42_866_040, 4757)
+			// Standard Error: 99_028
+			.saturating_add(Weight::from_parts(2_467_746, 0).saturating_mul(t.into()))
 			.saturating_add(RocksDbWeight::get().reads(4_u64))
 			.saturating_add(RocksDbWeight::get().reads((1_u64).saturating_mul(t.into())))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
-			.saturating_add(Weight::from_parts(0, 2518).saturating_mul(t.into()))
+			.saturating_add(Weight::from_parts(0, 2535).saturating_mul(t.into()))
 	}
 	/// Storage: `Revive::ContractInfoOf` (r:1 w:0)
 	/// Proof: `Revive::ContractInfoOf` (`max_values`: None, `max_size`: Some(1779), added: 4254, mode: `Measured`)
@@ -1758,8 +1761,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `1237`
 		//  Estimated: `4702`
-		// Minimum execution time: 36_908_000 picoseconds.
-		Weight::from_parts(37_754_000, 4702)
+		// Minimum execution time: 36_048_000 picoseconds.
+		Weight::from_parts(37_921_000, 4702)
 			.saturating_add(RocksDbWeight::get().reads(3_u64))
 	}
 	/// Storage: `Revive::CodeInfoOf` (r:1 w:1)
@@ -1773,12 +1776,12 @@ impl WeightInfo for () {
 	/// The range of component `i` is `[0, 262144]`.
 	fn seal_instantiate(i: u32, ) -> Weight {
 		// Proof Size summary in bytes:
-		//  Measured:  `1310`
-		//  Estimated: `4769`
-		// Minimum execution time: 120_576_000 picoseconds.
-		Weight::from_parts(112_786_790, 4769)
+		//  Measured:  `1331`
+		//  Estimated: `4796`
+		// Minimum execution time: 121_507_000 picoseconds.
+		Weight::from_parts(115_250_696, 4796)
 			// Standard Error: 10
-			.saturating_add(Weight::from_parts(4_192, 0).saturating_mul(i.into()))
+			.saturating_add(Weight::from_parts(4_136, 0).saturating_mul(i.into()))
 			.saturating_add(RocksDbWeight::get().reads(4_u64))
 			.saturating_add(RocksDbWeight::get().writes(3_u64))
 	}
@@ -1787,64 +1790,64 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 621_000 picoseconds.
-		Weight::from_parts(3_506_910, 0)
+		// Minimum execution time: 649_000 picoseconds.
+		Weight::from_parts(3_208_110, 0)
 			// Standard Error: 3
-			.saturating_add(Weight::from_parts(1_489, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(1_439, 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_054_000 picoseconds.
-		Weight::from_parts(5_395_465, 0)
-			// Standard Error: 3
-			.saturating_add(Weight::from_parts(3_688, 0).saturating_mul(n.into()))
+		// Minimum execution time: 1_078_000 picoseconds.
+		Weight::from_parts(3_361_333, 0)
+			// Standard Error: 4
+			.saturating_add(Weight::from_parts(3_648, 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: 626_000 picoseconds.
-		Weight::from_parts(3_549_376, 0)
+		// Minimum execution time: 673_000 picoseconds.
+		Weight::from_parts(3_115_184, 0)
 			// Standard Error: 3
-			.saturating_add(Weight::from_parts(1_596, 0).saturating_mul(n.into()))
+			.saturating_add(Weight::from_parts(1_557, 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: 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()))
+		// Minimum execution time: 685_000 picoseconds.
+		Weight::from_parts(3_752_567, 0)
+			// Standard Error: 3
+			.saturating_add(Weight::from_parts(1_549, 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_715_000 picoseconds.
-		Weight::from_parts(25_484_960, 0)
-			// Standard Error: 13
-			.saturating_add(Weight::from_parts(5_315, 0).saturating_mul(n.into()))
+		// Minimum execution time: 42_901_000 picoseconds.
+		Weight::from_parts(30_989_396, 0)
+			// Standard Error: 11
+			.saturating_add(Weight::from_parts(5_414, 0).saturating_mul(n.into()))
 	}
 	fn seal_ecdsa_recover() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 47_123_000 picoseconds.
-		Weight::from_parts(48_956_000, 0)
+		// Minimum execution time: 47_249_000 picoseconds.
+		Weight::from_parts(48_530_000, 0)
 	}
 	fn seal_ecdsa_to_eth_address() -> Weight {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// Minimum execution time: 12_650_000 picoseconds.
-		Weight::from_parts(12_768_000, 0)
+		// Minimum execution time: 12_873_000 picoseconds.
+		Weight::from_parts(13_127_000, 0)
 	}
 	/// Storage: `Revive::CodeInfoOf` (r:1 w:1)
 	/// Proof: `Revive::CodeInfoOf` (`max_values`: None, `max_size`: Some(96), added: 2571, mode: `Measured`)
@@ -1852,8 +1855,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `300`
 		//  Estimated: `3765`
-		// Minimum execution time: 18_061_000 picoseconds.
-		Weight::from_parts(18_851_000, 3765)
+		// Minimum execution time: 18_436_000 picoseconds.
+		Weight::from_parts(19_107_000, 3765)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 	}
@@ -1863,8 +1866,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `338`
 		//  Estimated: `3803`
-		// Minimum execution time: 13_779_000 picoseconds.
-		Weight::from_parts(14_320_000, 3803)
+		// Minimum execution time: 13_894_000 picoseconds.
+		Weight::from_parts(14_355_000, 3803)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 	}
@@ -1874,8 +1877,8 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `338`
 		//  Estimated: `3561`
-		// Minimum execution time: 12_327_000 picoseconds.
-		Weight::from_parts(13_156_000, 3561)
+		// Minimum execution time: 12_516_000 picoseconds.
+		Weight::from_parts(13_223_000, 3561)
 			.saturating_add(RocksDbWeight::get().reads(1_u64))
 			.saturating_add(RocksDbWeight::get().writes(1_u64))
 	}
@@ -1884,9 +1887,9 @@ impl WeightInfo for () {
 		// Proof Size summary in bytes:
 		//  Measured:  `0`
 		//  Estimated: `0`
-		// 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()))
+		// Minimum execution time: 9_177_000 picoseconds.
+		Weight::from_parts(11_420_562, 0)
+			// Standard Error: 99
+			.saturating_add(Weight::from_parts(72_860, 0).saturating_mul(r.into()))
 	}
 }
diff --git a/substrate/frame/revive/uapi/src/host.rs b/substrate/frame/revive/uapi/src/host.rs
index 476e3a26817a3828d795e7fc1552903a671fbe79..86ccb623a1d90b122db176f1f1114dcb38fd2068 100644
--- a/substrate/frame/revive/uapi/src/host.rs
+++ b/substrate/frame/revive/uapi/src/host.rs
@@ -71,6 +71,10 @@ pub trait HostFn: private::Sealed {
 	/// Returns the [EIP-155](https://eips.ethereum.org/EIPS/eip-155) chain ID.
 	fn chain_id(output: &mut [u8; 32]);
 
+	/// Returns the price per ref_time, akin to the EVM
+	/// [GASPRICE](https://www.evm.codes/?fork=cancun#3a) opcode.
+	fn gas_price() -> u64;
+
 	/// Returns the call data size.
 	fn call_data_size() -> u64;
 
diff --git a/substrate/frame/revive/uapi/src/host/riscv64.rs b/substrate/frame/revive/uapi/src/host/riscv64.rs
index 8376263b23481f092d3011bfd76aeb507913a658..045ebf0fbf750ef5baf5143bfa89bc92cf00a321 100644
--- a/substrate/frame/revive/uapi/src/host/riscv64.rs
+++ b/substrate/frame/revive/uapi/src/host/riscv64.rs
@@ -93,6 +93,7 @@ mod sys {
 			data_ptr: *const u8,
 			data_len: u32,
 		);
+		pub fn gas_price() -> u64;
 		pub fn call_data_size() -> u64;
 		pub fn block_number(out_ptr: *mut u8);
 		pub fn block_hash(block_number_ptr: *const u8, out_ptr: *mut u8);
@@ -369,6 +370,10 @@ impl HostFn for HostFnImpl {
 		panic!("seal_return does not return");
 	}
 
+	fn gas_price() -> u64 {
+		unsafe { sys::gas_price() }
+	}
+
 	fn balance(output: &mut [u8; 32]) {
 		unsafe { sys::balance(output.as_mut_ptr()) }
 	}