From 893a46e9b9930f9defdc56619e043e422211a415 Mon Sep 17 00:00:00 2001 From: bear Date: Wed, 21 Dec 2022 13:13:35 +0800 Subject: [PATCH] Fix revert (#149) Co-authored-by: Xavier Lau --- runtime/crab/src/pallets/evm.rs | 6 +++--- runtime/darwinia/src/pallets/evm.rs | 6 +++--- runtime/pangolin/src/pallets/evm.rs | 6 +++--- 3 files changed, 9 insertions(+), 9 deletions(-) diff --git a/runtime/crab/src/pallets/evm.rs b/runtime/crab/src/pallets/evm.rs index 06766c029..749bb6be6 100644 --- a/runtime/crab/src/pallets/evm.rs +++ b/runtime/crab/src/pallets/evm.rs @@ -121,15 +121,15 @@ where // darwinia use darwinia_precompile_assets::AccountToAssetId; - let (code_address, caller) = (handle.code_address(), handle.context().caller); + let (code_addr, context_addr) = (handle.code_address(), handle.context().address); // Filter known precompile addresses except Ethereum officials - if self.is_precompile(code_address) && code_address > addr(9) && code_address != caller { + if self.is_precompile(code_addr) && code_addr > addr(9) && code_addr != context_addr { return Some(Err(precompile_utils::revert( "cannot be called with DELEGATECALL or CALLCODE", ))); }; - match code_address { + match code_addr { // Ethereum precompiles: a if a == addr(1) => Some(pallet_evm_precompile_simple::ECRecover::execute(handle)), a if a == addr(2) => Some(pallet_evm_precompile_simple::Sha256::execute(handle)), diff --git a/runtime/darwinia/src/pallets/evm.rs b/runtime/darwinia/src/pallets/evm.rs index d3e94bec0..7737ad08a 100644 --- a/runtime/darwinia/src/pallets/evm.rs +++ b/runtime/darwinia/src/pallets/evm.rs @@ -121,15 +121,15 @@ where // darwinia use darwinia_precompile_assets::AccountToAssetId; - let (code_address, caller) = (handle.code_address(), handle.context().caller); + let (code_addr, context_addr) = (handle.code_address(), handle.context().address); // Filter known precompile addresses except Ethereum officials - if self.is_precompile(code_address) && code_address > addr(9) && code_address != caller { + if self.is_precompile(code_addr) && code_addr > addr(9) && code_addr != context_addr { return Some(Err(precompile_utils::revert( "cannot be called with DELEGATECALL or CALLCODE", ))); }; - match code_address { + match code_addr { // Ethereum precompiles: a if a == addr(1) => Some(pallet_evm_precompile_simple::ECRecover::execute(handle)), a if a == addr(2) => Some(pallet_evm_precompile_simple::Sha256::execute(handle)), diff --git a/runtime/pangolin/src/pallets/evm.rs b/runtime/pangolin/src/pallets/evm.rs index 051329ca2..f08c57f64 100644 --- a/runtime/pangolin/src/pallets/evm.rs +++ b/runtime/pangolin/src/pallets/evm.rs @@ -121,15 +121,15 @@ where // darwinia use darwinia_precompile_assets::AccountToAssetId; - let (code_address, caller) = (handle.code_address(), handle.context().caller); + let (code_addr, context_addr) = (handle.code_address(), handle.context().address); // Filter known precompile addresses except Ethereum officials - if self.is_precompile(code_address) && code_address > addr(9) && code_address != caller { + if self.is_precompile(code_addr) && code_addr > addr(9) && code_addr != context_addr { return Some(Err(precompile_utils::revert( "cannot be called with DELEGATECALL or CALLCODE", ))); }; - match code_address { + match code_addr { // Ethereum precompiles: a if a == addr(1) => Some(pallet_evm_precompile_simple::ECRecover::execute(handle)), a if a == addr(2) => Some(pallet_evm_precompile_simple::Sha256::execute(handle)),