1e9aebbc86
* Add new Vm trappable interface * Exec/Resume interface * Basic implementation of CallCreateExecutive * Implement resume_call and resume_create for executive * Move convertion to call/create result to separate function * Implement consume that converts resumable to non-resumable * Use consume for Executive::call/create * Resumable EVM * Implement tracing mode without needing subtracers * Implement vmtracer so it doesn't require extra structs for subtracing * Use the new tracing mode in executive * Fix most of the linting errors for cargo build * Add the concept of stack_depth * Add back crossbeam * Fix some test compile * Fix prefix address test * Fix evm crate tests * Fix wasm crate test compile * Fix wasm runner compile * Fix jsontests compile * Fix evmbin compile * Fix an issue with create nonce and better vm tracing interface * Fix linting * Fix evmbin compile * Fix unconfirmed_substate and static_flag * Fix an issue in create address logic * Fix top-level tracing * Handle builtin tracing * Fix suicide and reward tracing index stack * Fix an issue where trap conflicts with tracing * Fix an issue in parent step vm tracing * Fix revert tracing * Fix evmbin tests * Remove params clone * Fix TODO proofs * Fix jsontests compile * Fix evmbin merge issue * Fix wasm merge issue * Fix wasm test * Fix ethcore merge warnings * Fix evmbin compile * Better expect messages and add some trace::skip_one asserts
105 lines
2.8 KiB
Rust
105 lines
2.8 KiB
Rust
// Copyright 2015-2018 Parity Technologies (UK) Ltd.
|
|
// This file is part of Parity.
|
|
|
|
// Parity is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Parity is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Evm factory.
|
|
//!
|
|
use std::sync::Arc;
|
|
use vm::{Exec, Schedule};
|
|
use ethereum_types::U256;
|
|
use super::vm::ActionParams;
|
|
use super::interpreter::SharedCache;
|
|
use super::vmtype::VMType;
|
|
|
|
/// Evm factory. Creates appropriate Evm.
|
|
#[derive(Clone)]
|
|
pub struct Factory {
|
|
evm: VMType,
|
|
evm_cache: Arc<SharedCache>,
|
|
}
|
|
|
|
impl Factory {
|
|
/// Create fresh instance of VM
|
|
/// Might choose implementation depending on supplied gas.
|
|
pub fn create(&self, params: ActionParams, schedule: &Schedule, depth: usize) -> Box<Exec> {
|
|
match self.evm {
|
|
VMType::Interpreter => if Self::can_fit_in_usize(¶ms.gas) {
|
|
Box::new(super::interpreter::Interpreter::<usize>::new(params, self.evm_cache.clone(), schedule, depth))
|
|
} else {
|
|
Box::new(super::interpreter::Interpreter::<U256>::new(params, self.evm_cache.clone(), schedule, depth))
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Create new instance of specific `VMType` factory, with a size in bytes
|
|
/// for caching jump destinations.
|
|
pub fn new(evm: VMType, cache_size: usize) -> Self {
|
|
Factory {
|
|
evm: evm,
|
|
evm_cache: Arc::new(SharedCache::new(cache_size)),
|
|
}
|
|
}
|
|
|
|
fn can_fit_in_usize(gas: &U256) -> bool {
|
|
gas == &U256::from(gas.low_u64() as usize)
|
|
}
|
|
}
|
|
|
|
impl Default for Factory {
|
|
/// Returns native rust evm factory
|
|
fn default() -> Factory {
|
|
Factory {
|
|
evm: VMType::Interpreter,
|
|
evm_cache: Arc::new(SharedCache::default()),
|
|
}
|
|
}
|
|
}
|
|
|
|
#[test]
|
|
fn test_create_vm() {
|
|
use vm::Ext;
|
|
use vm::tests::FakeExt;
|
|
use bytes::Bytes;
|
|
|
|
let mut params = ActionParams::default();
|
|
params.code = Some(Arc::new(Bytes::default()));
|
|
let ext = FakeExt::new();
|
|
let _vm = Factory::default().create(params, ext.schedule(), ext.depth());
|
|
}
|
|
|
|
/// Create tests by injecting different VM factories
|
|
#[macro_export]
|
|
macro_rules! evm_test(
|
|
($name_test: ident: $name_int: ident) => {
|
|
#[test]
|
|
fn $name_int() {
|
|
$name_test(Factory::new(VMType::Interpreter, 1024 * 32));
|
|
}
|
|
}
|
|
);
|
|
|
|
/// Create ignored tests by injecting different VM factories
|
|
#[macro_export]
|
|
macro_rules! evm_test_ignore(
|
|
($name_test: ident: $name_int: ident) => {
|
|
#[test]
|
|
#[ignore]
|
|
#[cfg(feature = "ignored-tests")]
|
|
fn $name_int() {
|
|
$name_test(Factory::new(VMType::Interpreter, 1024 * 32));
|
|
}
|
|
}
|
|
);
|