eos wasm虚拟机相关接口定义实现
wasm虚拟机相关接口定义实现
执行流程
controller::push_transaction() // 事务
-> transaction_context::exec() // 事务
-> transaction_context::dispatch_action() // 通过便利transaction中的各个action来分发执行
-> apply_context::exec() // action
-> apply_context::exec_one() // action 执行具体的智能合约
-> controller::get_wasm_interface()->apply() // 进入虚拟机开始执行对应智能合约
-> wasm_interface_impl::get_instantiated_module()->apply() // 加载智能合约并执行
-> wavm_instantiated_module::apply() // 具体模块开始接收调用
-> wavm_instantiated_module::call() // 开始执行具体函数
-> Runtime::invokeFunction() // 进入到wasm运行时库开始执行具体函数
接口定义
- wasm_interface_impl wasm虚拟机实现类
1.加载模块实现
std::unique_ptr<wasm_instantiated_module_interface> &get_instantiated_module(const digest_type &code_id,const shared_string &code,transaction_context &trx_context)
{
...
IR::Module module;
try
{
// 将模块序列化到内存并加载模块
Serialization::MemoryInputStream stream((const U8 *)code.data(), code.size());
WASM::serialize(stream, module);
module.userSections.clear();
}
catch(...){
...
}
...
/**
* 这里是注入拦截代码,用于拦截计算相应cpu和内存数据
*/
wasm_injections::wasm_binary_injection injector(module); //如下
injector.inject();
...
}
- wasm_eosio_injection wasm虚拟机注入
- 默认通过内存计算
- using standard_module_injectors = module_injectors<max_memory_injection_visitor>
- max_memory_injection_visitor 最大内存拦截
监控模块适用内存数
void max_memory_injection_visitor::inject( Module& m ) {
if(m.memories.defs.size() && m.memories.defs[0].type.size.max > maximum_linear_memory/wasm_page_size)
m.memories.defs[0].type.size.max = maximum_linear_memory/wasm_page_size;
}
2.执行智能合约
void wasm_interface::apply(const digest_type &code_id, const shared_string &code, apply_context &context)
{
// 智能合约虚拟机加载模块
// 加载模块时会通过如下的injection来注入监控
// 默认:eos监控最大使用内存:max_memory_injection_visitor
// 通过apply来执行相应智能合约
my->get_instantiated_module(code_id, code, context.trx_context)->apply(context);
}
- wasm_instantiated_module_interface wasm模块基类
- wavm_instantiated_module wavm模块实现类
- wavm_instantiated_module wavm模块实现类
// 函数执行
void apply(apply_context& context) override {
// 默认3个参数
// receiver/account/name
// 其他参数通过context获取
vector<Value> args = {Value(uint64_t(context.receiver)),
Value(uint64_t(context.act.account)),
Value(uint64_t(context.act.name))};
call("apply", args, context);
}
void call(const string &entry_point, const vector <Value> &args, apply_context &context) {
try {
FunctionInstance* call = asFunctionNullable(getInstanceExport(_instance,entry_point));
if( !call )
return;
the_running_instance_context.memory = default_mem;
the_running_instance_context.apply_ctx = &context;
// 加载instance
resetGlobalInstances(_instance);
// 调用初始化函数
runInstanceStartFunc(_instance);
// 这里就调用到了wasm runtime来调用智能合约
Runtime::invokeFunction(call,args);
}
}
- wabt_instantiated_module wabt模块
整体实现过程同wavm,局部有差异
虚拟机启动
- controller_impl 控制器实现类
在controller构造函数中构建wasm_interface对象
controller_impl( const controller::config& cfg, controller& s )
...略...
wasmif( cfg.wasm_runtime ), //根据配置来构建wasm_interface对象
...略...
eos wasm虚拟机相关接口定义实现的更多相关文章
- Spring中Aware相关接口原理
Spring中提供一些Aware相关接口,像是BeanFactoryAware. ApplicationContextAware.ResourceLoaderAware.ServletContextA ...
- Servlet相关接口和Servlet的生命周期
http://www.cnblogs.com/luotaoyeah/p/3860292.html Servlet相关接口和Servlet的生命周期 创建一个Servlet类最直接的方式是实现javax ...
- USB 3.0连接器引脚、接口定义及封装尺寸
上篇整理了USB 2.0A型.B型和Mini USB接口定义及封装,本文补充USB 3.0接口定义,USB 3.0采用的双总线结构,在速率上已经达到4.8Gbps,所以称为Super speed,在U ...
- USB 2.0 A型、B型、Mini和Micro接口定义及封装
USB全称Universal Serial Bus(通用串行总线),目前USB 2.0接口分为四种类型A型.B型.Mini型还有后来补充的Micro型接口,每种接口都分插头和插座两个部分,Micro还 ...
- 数据结构 链式哈希表(Hash Table)的接口定义与实现分析(完整代码)
链式哈希表的接口定义 关于哈希表与链式哈希表的描述可以参阅:http://www.cnblogs.com/idreamo/p/7990860.html 链式哈希表的操作与属性有:初始化.销毁.插入元素 ...
- 开地址哈希表(Hash Table)的接口定义与实现分析
开地址哈希函数的接口定义 基本的操作包括:初始化开地址哈希表.销毁开地址哈希表.插入元素.删除元素.查找元素.获取元素个数. 各种操作的定义如下: ohtbl_init int ohtbl_init ...
- 【Android 应用开发】Android 网络编程 API笔记 - java.net 包相关 接口 api
Android 网络编程相关的包 : 9 包, 20 接口, 103 类, 6 枚举, 14异常; -- Java包 : java.net 包 (6接口, 34类, 2枚举, 12异常); -- An ...
- 【Spring源码分析系列】ApplicationContext 相关接口架构分析
[原创文章,转载请注明出处][本文地址]http://www.cnblogs.com/zffenger/p/5813470.html 在使用Spring的时候,我们经常需要先得到一个Applicati ...
- Android 网络编程 API笔记 - java.net 包相关 接口 api
Android 网络编程相关的包 : 9 包, 20 接口, 103 类, 6 枚举, 14异常; -- Java包 : java.net 包 (6接口, 34类, 2枚举, 12异常); -- An ...
随机推荐
- 61、请求数据进行gizp压缩
1.请求时进行头部处理 /** * 设置通用消息头 * * @param request */ public void setHeader(HttpUriRequest request) { // r ...
- python 笔试总结
1.对比两种函数对应结果 def fn(x): if x>0: print(x) fn(x-1) ****结果****** 3 2 1 $$$$$$另外一种$$$$$$$$$ def fn(x) ...
- 实战小项目之IMX6 VPU使用
项目简介 基于官方的demo进行修改,限于能力问题,并没有将功能代码完全从官方的demo中分离出来,还是基于原来的框架进行修改,做了一些简单的封装,我做的工作如下: 使用自己的采集程序 定义6中工作模 ...
- (转载)django 访问url报错Forbidden (CSRF cookie not set.): xxx 问
原地址:http://www.cnblogs.com/meitian/p/7016336.html 问题:页面访问时报错 Forbidden (CSRF cookie not set.): xxx ...
- GitLab-CI环境搭建与操作手册
第一章 系统安装简介 1.1. 系统结构 GitLab-CI持续集成服务主要包括gitlab.runner 2个模块.Gitlab主要负责代码文件的管理:runner则负责版本编译.存储.推送等任务. ...
- 【神题】AtCoder 028 C Min Cost Cycle
TO BE DONE 思维题 十分巧妙的转化
- [CQOI2015][bzoj3930] 选数 [杜教筛+莫比乌斯反演]
题面: 传送门 思路: 首先我们把区间缩小到$\left[\lfloor\frac{L-1}{K}\rfloor,\lfloor\frac{R}{K}\rfloor\right]$ 这道题的最特殊的点 ...
- 本文将介绍“数据计算”环节中常用的三种分布式计算组件——Hadoop、Storm以及Spark。
本文将介绍“数据计算”环节中常用的三种分布式计算组件——Hadoop.Storm以及Spark. 当前的高性能PC机.中型机等机器在处理海量数据时,其计算能力.内存容量等指标都远远无法达到要求.在大数 ...
- python(4)-- 日期 & 时间
1. Python 提供了一个 time 和 calendar 模块可以用于格式化日期和时间. 2. 时间间隔是以秒为单位的浮点小数. 3. 每个时间戳都以自从1970年1月1日午夜(历元)经过了多长 ...
- webpack-dev-server 支持其他设备访问配置
webpack-dev-server 打开的服务默认是只能localhost访问的,当有时候需要让别人访问的时候可以配置 --host 192.168.84 这样在同一个局域网下面就可以通过该ip来访 ...