向后兼容性
https://ewasm.readthedocs.io/en/mkdocs/backwards_compatibility/
(希望有经验的可以帮忙修改一下,看完一小节才发现,好难啊)
当前实现与evm1兼容的方法是支持两个指令集,同时可以将evm1格式代码转换为ewasm。这种方法在处理EVM1代码时给客户提供了可选性。终端既可以只实现一个ewasm vm,也可以转换所有evm1代码。再或者终端可以同时实现一个ewasm vm和evm1 vm,这样可以保留原来的代码,也可以支持新格式的代码。
Gas
在ewasm中,我们将引入sub-gas单元,因此每个evm1操作码转化之后等效的ewasm操作码,gas原始evm1操作码的成本。ewasm的gas规格尚未确立。
代码标识
我们假设有一些功能性代码是被所有的终端使用。处理程序通过是否以WASM的幻数开头来标识指令集类型。
WASM幻数是以下字节序列:0x00、0x61、0x73、0x6d。
Solidity
通过添加新的solidity编译后端,solidity可以支持编译到ewasm。ewasm对solidity的支持是MVP的一部分。(最小可行版本Minimum Viable Product,MVP)
事务编译器
后续目标是把事务编译器转化为ewsm的智能合约。一旦其完成之后,由CREAT操作码创建的EVM1合约将转换为ewasm。因此我们假设所有evm1代码被编译为ewasm代码,这种变化会体现在以太坊状态中,因为代码存储在merkle trie中。注意:如果运行evm1代码,这仍然允许客户端回退到evm1 vms。