Chinaunix首页 | 论坛 | 博客
  • 博客访问: 4263628
  • 博文数量: 776
  • 博客积分: 13014
  • 博客等级: 上将
  • 技术积分: 10391
  • 用 户 组: 普通用户
  • 注册时间: 2010-02-22 17:00
文章分类

全部博文(776)

文章存档

2015年(55)

2014年(43)

2013年(147)

2012年(20)

2011年(82)

2010年(429)

分类: LINUX

2011-06-11 08:53:00

配置PC的dmalloc环境
1. 首先把源码包打开,进入dmalloc文件夹
2. ./configure 配置Makefile,我是加了线程选项的,所以我的是./configure --enable-threads
3. 生成Makefile之后,需要修改makefile里面的编译选项 cc和cxx
   我用的是DM6467的开发环境,所以我的改成了arm_v5t_le-gcc和arm_v5t_le-g++,这里按照各自需要改成交叉编译的命令就好。
4. 然后make
5. make install
到此,环境配置完成

进到我们需要测试内存漏洞的代码,例如我们的代码在test文件夹里,名字叫mem.c。
1. 进入test
2. 用交叉编译工具编译arm_v5t_le-gcc mem.c -o mem -ldmalloc,这里记得加-ldmalloc这个编译选项,这样才能使用dmalloc。
执行成功后,生成的mem拷贝到开发板的某个目录,等待执行。

配置开发板的dmalloc执行环境
1. 从PC的/usr/local/bin 拷贝dmalloc 文件到开发板的目录/bin
2. 从PC的/usr/local/lib 拷贝相关的.a文件到开发板的目录/usr/lib
3. 从PC的/usr/local/include 拷贝dmalloc.h 文件到开发板的目录/usr/include
4. 输入配置文件命令 export DMALLOC_OPTIONS=log=logname,debug=0x3
   这里的logname是一个我们输入的文件,以后的编译debug信息会打印进去,0x3是debug的选项,详细的可以看http://www.linuxfordevices.com/c/a/Linux-For-Devices-Articles/ELJonline-BRMemory-Leak-Detection-in-Embedded-Systems/  我下面也把编译选项贴过来了。


将上面编译好的mem可执行程序拷贝到我们的开发板上,然后运行。

--------------------------
The following is a list of the tests and the corresponding bits to set in ``debug'':

    * none (nil): no functionality (0)

    * log-stats (lst): log general statistics (0x1)

    * log-non-free (lnf): log non-freed pointers (0x2)

    * log-known (lkn): log only known non-freed (0x4)

    * log-trans (ltr): log memory transactions (0x8)

    * log-admin (lad): log administrative info (0x20)

    * log-blocks (lbl): log blocks when heap-map (0x40)

    * log-bad-space (lbs): dump space from bad pointers (0x100)

    * log-nonfree-space (lns): dump space from non-freed pointers (0x200)

    * log-elapsed-time (let): log elapsed time for allocated pointer (0x40000)

    * log-current-time (lct): log current time for allocated pointer (0x80000)

    * check-fence (cfe): check fencepost errors (0x400)

    * check-heap (che): check heap adm structs (0x800)

    * check-lists (cli): check free lists (0x1000)

    * check-blank (cbl): check mem overwritten by alloc-blank, free-blank (0x2000)

    * check-funcs (cfu): check functions (0x4000)

    * force-linear (fli): force heap-space to be linear (0x10000)

    * catch-signals (csi): shut down program on SIGHUP, SIGINT, SIGTERM (0x20000)

    * realloc-copy (rco): copy all re-allocations (0x100000)

    * free-blank (fbl): overwrite freed memory space with BLANK_CHAR (0x200000)

    * error-abort (eab): abort immediately on error (0x400000)

    * alloc-blank (abl): overwrite newly alloced memory with BLANK_CHAR (0x800000)

    * heap-check-map (hcm): log heap-map on heap-check (0x1000000)

    * print-messages (pme): write messages to stderr (0x2000000)

    * catch-null (cnu): abort if no memory available (0x4000000)

    * never-reuse (nre): never reuse freed memory (0x8000000)

    * allow-free-null (afn): allow the frees of NULL pointers (0x20000000)

    * error-dump (edu): dump core on error and then continue (0x40000000)

阅读(2361) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~