intel强力分析工具Pin的使用入门(1)

本文介绍了Intel的Pin工具,一个用于动态二进制分析的框架,适用于构建程序分析工具。Pin非开源,但提供编译版本。内容基于官方手册,讲解了如何在X86_64系统上使用Pin,包括插入探测函数进行观察和分析。文中以计数helloworld程序执行指令为例,展示Pin的基本用法。
摘要由CSDN通过智能技术生成

Pin是intel公司推出的一款动态二进制分析框架,可以用于构建强大的动态程序分析工具。比如CPM$im模拟器就是基于Pin开发的。Intel为了封锁技术,并没有让Pin开源,

但是提供了其编译版本供使用,用户可以以外挂的形式扩展自定义的分析函数。

本文内容来自Pin的官方用户手册http://software.intel.com/sites/landingpage/pintool/docs/54730/Pin/html/,所有代码经过测试可以运行在X86_64、Red Hat 4.1.2-44 SMP版本上。如有任何疑问欢迎发送邮件到XinYuan49@gmail.com进行讨论。希望可以跟大家一起学习和进步。

Pin简单来说就是在可执行二进制代码中插入一些探测函数,用于观察、记录、分析等。通过Pin提供的API可以编写各种分析函数,这样程序运行完以后,统计和分析结果也同时产生。

从前面给出的站点下载Pin工具,按README说明编译系统默认提供的tools工具(source/tools/*Examples下的程序)。这些程序也叫pintool,他们是分析的实体。一个pintool程序往往包括两部分:

1.在何处进行分析

2.如何分析

在Pin框架下一个进程运行时,真正的运行代码包括三个部分:进程本身的二进制、Pin框架code、pintool code。

下面以一个基本的例子快速进入Pin的使用中。

目标1:想知道一个helloworld程序实际上执行多少条机器指令。

需要一个helloworld程序,一个pint

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值