2019-01-16 evmc项目研究

研究evmc项目,记录如下:
首先当然是编译运行

1、修改CMakeLists.txt文件,修改如下:

option(EVMC_TESTING "Build EVMC tests and test tools" ON)

这里直接打开测试用例,确保后续研究代码方便

2、编译

老套的方式

mkdir build
cd build
cmake ..
make

如果下载失败需要在命令行窗口执行:

export http_proxy=http://yourproxy/:8080
export https_proxy=http://yourproxy/:8080

如果在mingw下编译,需要使用:

cmake -G "MinGW Makefiles" ..

如果在vs2015下编译,需要使用:

cmake -G "Visual Studio 14 2015 Win64" ..

3、运行demo

cd evmc/build/examples
./evmc-example
Execution result:
  EVM execution failure: 1
Segmentation fault (core dumped)

执行错误

4、运行测试用例

cd evmc/build/test
./evmc-test 
./evmc-vmtester

其中evmc-test执行成功,而evmc-vmtester执行异常

5、检查demo执行失败的原因

5.1、增加调试信息

修改evmc/examples/CMakeLists.txt文件,在尾部增加

SET(CMAKE_BUILD_TYPE "Debug")  
SET(CMAKE_CXX_FLAGS_DEBUG "$ENV{CXXFLAGS} -O0 -Wall -g2 -ggdb")  
SET(CMAKE_CXX_FLAGS_RELEASE "$ENV{CXXFLAGS} -O3 -Wall")  

删除build目录后重新执行第二步编译

5.2、gdb调试

cd evmc/build/examples
gdb
file evmc-example
b example.c:16
r

后面就单步走,直到
evmc_release_result(&result); 函数出错
使用q退出gdb,然后再gdb一次,进入这个函数

gdb
file evmc-example
b example.c:52
r
s
p result->release
$1 = (evmc_release_result_fn) 0x0

打印发现result->release函数指针为空,因此这里crash
从前面跟踪看到还有个原因是evmc_execute执行失败导致
先修改文件evmc/include/evmc/helpers.h:116

static inline void evmc_release_result(struct evmc_result* result)
{
    if(result->release != NULL) {
        result->release(result);
    }
}

直接在目录evmc/build/examples执行make
然后执行

./evmc-example
Execution result:
  EVM execution failure: 1

5.3、继续解决上面这个错误

gdb过程不详述,这里只记录修改的代码
调试发现example.c里面是有sizeof求字符串长度得到长度9,而example_vm.c里面是用strlen求长度得到长度8,因此匹配错误执行失败
我们修改example.c

#include <string.h>
...
const size_t code_size = sizeof(code) - 1;

编译后执行:

./evmc-example
Execution result:
  Gas used: 200000
  Gas left: 0
  Output size: 20
  Output: 00 01 02 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00

这次demo就执行成功了

6、evmc-vmtester执行异常

研究代码发现这个程序执行需要指定vm虚拟机的库,我们参考hera git编译出libhera.so,并把so复制到当前目录下,执行

./evmc-vmtester ./libhera.so 
Testing ./libhera.so

[==========] Running 9 tests from 1 test case.
[----------] Global test environment set-up.
[----------] 9 tests from evmc_vm_test
[ RUN      ] evmc_vm_test.abi_version_match
[       OK ] evmc_vm_test.abi_version_match (0 ms)
[ RUN      ] evmc_vm_test.execute
Executing message in Hera
InternalError: Only Byzantium supported.
[       OK ] evmc_vm_test.execute (0 ms)
[ RUN      ] evmc_vm_test.set_option_unknown_name
[       OK ] evmc_vm_test.set_option_unknown_name (0 ms)
[ RUN      ] evmc_vm_test.set_option_empty_value
[       OK ] evmc_vm_test.set_option_empty_value (0 ms)
[ RUN      ] evmc_vm_test.set_option_unknown_value
[       OK ] evmc_vm_test.set_option_unknown_value (0 ms)
[ RUN      ] evmc_vm_test.name
[       OK ] evmc_vm_test.name (0 ms)
[ RUN      ] evmc_vm_test.version
[       OK ] evmc_vm_test.version (0 ms)
[ RUN      ] evmc_vm_test.set_tracer
[       OK ] evmc_vm_test.set_tracer (0 ms)
[ RUN      ] evmc_vm_test.capabilities
[       OK ] evmc_vm_test.capabilities (0 ms)
[----------] 9 tests from evmc_vm_test (0 ms total)

[----------] Global test environment tear-down
[==========] 9 tests from 1 test case ran. (0 ms total)
[  PASSED  ] 9 tests.

执行成功

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352