Linux 堆栈大小
- 2024-11-13 08:36:00
- admin 原创
- 37
问题描述:
我正在寻找 Linux 内核中堆栈的良好描述,但我发现很难找到任何有用的东西。
我知道大多数系统的堆栈限制为 4k,其他系统的堆栈限制为 8k。我假设每个内核线程/下半部分都有自己的堆栈。我还听说如果中断发生,它会使用当前线程的堆栈,但我找不到任何关于这方面的文档。我正在寻找的是堆栈是如何分配的,是否有任何好的调试例程(我怀疑某个问题存在堆栈溢出,我想知道是否有可能编译内核来控制堆栈大小等)。
解决方案 1:
文档稀少的原因是该领域非常依赖于体系结构。代码实际上是最好的文档 - 例如,THREAD_SIZE
宏定义了(依赖于体系结构的)每个线程内核堆栈大小。
堆栈在 中分配alloc_thread_stack_node()
。 中的堆栈指针struct task_struct
在 中更新dup_task_struct()
,这是在克隆线程的过程中调用的。
内核会通过在堆栈末尾放置一个 canary 值STACK_END_MAGIC
来检查内核堆栈溢出。在页面错误处理程序中,如果内核空间发生错误,则会检查此 canary - 例如,参见x86 错误处理程序,Thread overran stack, or stack corrupted
如果堆栈 canary 已被破坏,它会在 Oops 消息后打印该消息。
当然,这不会在所有堆栈溢出时触发,只有破坏堆栈金丝雀的堆栈溢出才会触发。但是,您应该始终能够从 Oops 输出中判断是否遇到了堆栈溢出 - 如果堆栈指针低于 ,就会出现这种情况task->stack
。
解决方案 2:
您可以使用以下命令确定进程堆栈大小ulimit
。我的系统上得到 8192 KiB:
$ ulimit -s
8192
解决方案 3:
ulimit
对于进程,您可以通过命令 (选项)控制进程的堆栈大小-s
。对于线程,默认堆栈大小变化很大,但您可以通过调用来控制它pthread_attr_setstacksize()
(假设您使用的是 pthreads)。
至于使用用户空间堆栈的中断,我有点怀疑,因为从内核访问用户空间内存有点麻烦,尤其是从中断例程访问。但我不确定。
- 2024年20款好用的项目管理软件推荐,项目管理提效的20个工具和技巧
- 2024年开源项目管理软件有哪些?推荐5款好用的项目管理工具
- 项目管理软件有哪些?推荐7款超好用的项目管理工具
- 项目管理软件哪个最好用?盘点推荐5款好用的项目管理工具
- 项目管理软件有哪些最好用?推荐6款好用的项目管理工具
- 2024年常用的项目管理软件有哪些?推荐这10款国内外好用的项目管理工具
- 项目管理软件有哪些,盘点推荐国内外超好用的7款项目管理工具
- 2024项目管理软件排行榜(10类常用的项目管理工具全推荐)
- 项目管理软件排行榜:2024年项目经理必备5款开源项目管理软件汇总
- 项目管理必备:盘点2024年13款好用的项目管理软件