warning: the frame size of 1040 bytes is larger than 1024 bytes


http://blog.csdn.net/tigerjibo/article/details/9316263


问题描述:

       在编译内核模块驱动时,如果出现如下警告信息:

warning: the frame size of 1040 bytes is larger than 1024 bytes。主要是因为内核中设置了堆栈报警大小,其默认为1024bytes。我们主要将其修改为4096既可以消除告警信息。

如果解决:

(1)make menuconfig

(2)kernel hacking

(3)修改warn for stack frames larger than 的数值,将其修改为4096(最好不要大过这个数值)

(4)重新编译内核模块则不会出现如上的告警信息。



http://stackoverflow.com/questions/22460599/what-are-the-safe-values-for-config-frame-warn-on-x86-arch


There is no specific safe value.

What matters is how much stack is actually used, i.e., the sum of the stack frames of all active functions.

This warning does not guarantee that you will overflow the stack space; it just shows that this function makes an overflow more likely (when used together with other big-frame functions, or with many smaller functions).

------------------------

Linux kernel defines stack size 8192 bytes for each kernel thread, so the maximum safe value is the value that will not overflow total of 8192 bytes in the whole call path.


posted @   张同光  阅读(636)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示