Chinaunix首页 | 论坛 | 博客
  • 博客访问: 482274
  • 博文数量: 135
  • 博客积分: 1860
  • 博客等级: 上尉
  • 技术积分: 1441
  • 用 户 组: 普通用户
  • 注册时间: 2008-01-05 20:39
文章分类
文章存档

2012年(2)

2011年(130)

2009年(2)

2008年(1)

我的朋友

分类:

2011-08-11 15:01:43

 

gcc mudflap 用来检测内存越界的问题

原文地址:

我们用C语言在做大型服务器程序的时候,不可避免的要面对内存错误的问题。典型的问题是内存泄漏,越界,随机乱写等问题。在linux下valgrind是个很好的工具,大部分问题都可以查的到的。但是对于更微妙的越界问题,valgrind有时候也是无能为力的。比如下面的问题。

[admin@my174 ~]$ cat bug.c

int a[10];

int b[10];

int main(void) {

return a[11];

}

[admin@my174 ~]$ gcc -g -o bug bug.c

[admin@my174 ~]$ valgrind ./bug

==5791== Memcheck, a memory error detector.

==5791== Copyright (C) 2002-2006, and GNU GPL’d, by Julian Seward et al.

==5791== Using LibVEX rev 1658, a library for dynamic binary translation.

==5791== Copyright (C) 2004-2006, and GNU GPL’d, by OpenWorks LLP.

==5791== Using valgrind-3.2.1, a dynamic binary instrumentation framework.

==5791== Copyright (C) 2000-2006, and GNU GPL’d, by Julian Seward et al.

==5791== For more details, rerun with: -v

==5791==

==5791==

==5791== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 4 from 1)

==5791== malloc/free: in use at exit: 0 bytes in 0 blocks.

==5791== malloc/free: 0 allocs, 0 frees, 0 bytes allocated.

==5791== For counts of detected errors, rerun with: -v

==5791== All heap blocks were freed — no leaks are possible.

[admin@my174 ~]$

valgrind报告一切安好。

[admin@my174 ~]$ gcc -o bug bug.c -g -fmudflap -lmudflap

[admin@my174 ~]$ ./bug

*******

mudflap violation 1 (check/read): time=1285386334.204054 ptr=0×700e00 size=48

pc=0×2b6c3013c4c1 location=`bug.c:5 (main)’

/usr/lib64/libmudflap.so.0(__mf_check+0×41) [0x2b6c3013c4c1]

./bug(main+0×7a) [0x400952]

/lib64/libc.so.6(__libc_start_main+0xf4) [0x39ea21d994]

Nearby object 1: checked region begins 0B into and ends 8B after

mudflap object 0×16599370: name=`bug.c:1 a’

bounds=[0x700e00,0x700e27] size=40 area=static check=3r/0w liveness=3

alloc time=1285386334.204025 pc=0×2b6c3013bfe1

number of nearby objects: 1

mudflap就很顺利的检查出来了。

当然我们的这个例子很简单,典型的服务器要比这个复杂很多,而且mudflap的运行开销也非常高,我们在定位此类bug的时候不妨实验下。

Have fun!

 

Pasted from <http://rdc.taobao.com/blog/cs/?p=455>

 

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