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工具下载好后,