- 论坛徽章:
- 0
|
如题, 使用signal函数将回调函数挂到SIGSEGV信号上,只有普通的段错误能调用到自己写的handle, 如果是栈空间溢出,则没有更多的栈空间执行自己写的handle,
我的需求是出现这种无限递归时,进行函数调用栈的收集,以便程序员调试,
小弟没有找到从进程自己解决这个问题的办法,尝试了一下通过用另一个进程使用ptrace attach上去进行捕获异常-- 父进程可以捕获到异常,但我还没找到怎么阻止子进程退出并打印出函数栈。
通过参考这篇文章http://blog.163.com/scan_study/blog/static/54378834200919551262/
我尝试用ptrace直接向子进程的eip空间写一个sleep得机器码(然后计划用gdb attach上去抓栈),但貌似直接向子进程的eip的空间写sleep的机器码后,子进程没有任何效果
各位大牛如果有做过类似的应用的请不吝赐教,万分感激
#include <execinfo.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <signal.h>
static int MAX_RECUR = 100;
void recurCall(){
recurCall();
}
static void segfault(){
printf("seg fault found!\n" ;
exit(0);
}
int main(){
signal(SIGSEGV, segfault);
sleep(60);
/*we could catch this
int* p;
*p = 0;
*/
recurCall();
return 0;
}
[ 本帖最后由 fwlx 于 2010-1-4 08:53 编辑 ] |
|