1. 程序运行时Trace,DynamoRIO
最近在做一个trace程序执行路径的项目,了解到DynamoRIO可以实现这个功能,在此记录学习以下。首先,DynamoRIO是什么:DynamoRIO是一个运行时代码控制系统(runtime code manipulation system),支持程序运行时对程序的任一部分进行修改。DynamoRIO exports an interface for building dynamic tools for a wide variety of uses: program analysis and understanding, profiling, instrumentation, optimization, translation, etc.。在此我们用来监控代码的执行路径,最终由此结果得出程序执行的CFG(控制流图,Control-Flow Graphic)。
Ubuntu 16.04 下,获取DynamoRIO方式。其中已经包含了DR的可执行文件。
wget https://github.com/DynamoRIO/dynamorio/releases/download/release_7_0_0_rc1/DynamoRIO-Linux-7.0.0-RC1.tar.gz
tar -xzvf DynamoRIO-Linux-7.0.0-RC1.tar.gz
mkdir dynamorio
mv DynamoRIO-Linux-7.0.0-RC1 dynamorio
rm DynamoRIO-Linux-7.0.0-RC1.tar.gz'
2. 使用
DR工具下载好后,我们首先编译其自带的smapleC语言源文件进行简单的使用尝试。
cd dynamorio/
mkdir build && cd

本文介绍了如何利用DynamoRIO实现程序运行时的Trace,以监控代码执行路径并获取控制流图(CFG)。在Ubuntu 16.04上,详细阐述了DynamoRIO的获取、编译及使用过程,包括通过DR工具生成指令执行总数的示例,并强调理解DynamoRIO API对于实现定制控制逻辑的重要性。
最低0.47元/天 解锁文章
2423

被折叠的 条评论
为什么被折叠?



