36 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2015 The go-ethereum Authors
 | 
						|
// This file is part of the go-ethereum library.
 | 
						|
//
 | 
						|
// The go-ethereum library is free software: you can redistribute it and/or modify
 | 
						|
// it under the terms of the GNU Lesser General Public License as published by
 | 
						|
// the Free Software Foundation, either version 3 of the License, or
 | 
						|
// (at your option) any later version.
 | 
						|
//
 | 
						|
// The go-ethereum library 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 Lesser General Public License for more details.
 | 
						|
//
 | 
						|
// You should have received a copy of the GNU Lesser General Public License
 | 
						|
// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
 | 
						|
 | 
						|
/*
 | 
						|
Package vm implements the Ethereum Virtual Machine.
 | 
						|
 | 
						|
The vm package implements two EVMs, a byte code VM and a JIT VM. The BC
 | 
						|
(Byte Code) VM loops over a set of bytes and executes them according to the set
 | 
						|
of rules defined in the Ethereum yellow paper. When the BC VM is invoked it
 | 
						|
invokes the JIT VM in a separate goroutine and compiles the byte code in JIT
 | 
						|
instructions.
 | 
						|
 | 
						|
The JIT VM, when invoked, loops around a set of pre-defined instructions until
 | 
						|
it either runs of gas, causes an internal error, returns or stops.
 | 
						|
 | 
						|
The JIT optimiser attempts to pre-compile instructions in to chunks or segments
 | 
						|
such as multiple PUSH operations and static JUMPs. It does this by analysing the
 | 
						|
opcodes and attempts to match certain regions to known sets. Whenever the
 | 
						|
optimiser finds said segments it creates a new instruction and replaces the
 | 
						|
first occurrence in the sequence.
 | 
						|
*/
 | 
						|
package vm
 |