Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2164069
  • 博文数量: 374
  • 博客积分: 7276
  • 博客等级: 少将
  • 技术积分: 5669
  • 用 户 组: 普通用户
  • 注册时间: 2011-10-06 16:35
文章分类

全部博文(374)

文章存档

2013年(23)

2012年(153)

2011年(198)

分类: LINUX

2011-11-15 11:12:52

Linux内核的堆栈一般是8K,所以在写内核程序的时候一定要小心,防止函数递归的出现,递归可能导致内核堆栈溢出。
1. 查看Linux内核线程堆栈,源代码里一般定义为 #define THREAD_SIZE (2*PAGE_SIZE)
2. 如果怀疑有堆栈溢出的情况,可以在代码里面加入如下的代码来检查当前内核堆栈。
uint32 mystack_used (void) 
{
      char a;
      return (2*PAGE_SIZE - ((long)&a & ((2*PAGE_SIZE)-1)));
}
 
void myfunc()
{
  .............
  printk("Kernel Stack Total %d Used: %d\n",(2*PAGE_SIZE), mystack_used());
  .............
}
如果有以下信息产生,那可能就要堆栈溢出了。
Kernel Stack Total 8192 Used: 609
Kernel Stack Total 8192 Used: 1009
Kernel Stack Total 8192 Used: 609
Kernel Stack Total 8192 Used: 1009
Kernel Stack Total 8192 Used: 1409
Kernel Stack Total 8192 Used: 1809
Kernel Stack Total 8192 Used: 2209
Kernel Stack Total 8192 Used: 2609
Kernel Stack Total 8192 Used: 3009
Kernel Stack Total 8192 Used: 3409
Kernel Stack Total 8192 Used: 3809
Kernel Stack Total 8192 Used: 4209
Kernel Stack Total 8192 Used: 4609
Kernel Stack Total 8192 Used: 5009
Kernel Stack Total 8192 Used: 5409
Kernel Stack Total 8192 Used: 5809
Kernel Stack Total 8192 Used: 6209
Kernel Stack Total 8192 Used: 6609
Kernel Stack Total 8192 Used: 7009


PS:mystack_used函数中, return (2*PAGE_SIZE - ((long)&a & ((2*PAGE_SIZE)-1)));
若a的地址大于2*PAGE_SIZE时  就起不到原有的效果 应该判断函数返回的值<0时 内核堆栈
就一定溢出了
阅读(1964) | 评论(1) | 转发(3) |
给主人留下些什么吧!~~

tekkamanninja2011-11-15 14:07:42

是个好办法
不知道内核有没有自带的检测机制,
或者可以通过内嵌汇编来直接获得栈指针的值