如何使用GDB生成核心转储文件时限制核心转储文件的大小

时间:2011-10-12 08:51:37

标签: linux gdb arm embedded-linux coredump

我在ARM9主板上运行嵌入式应用程序,其总闪存大小仅为180MB。我可以运行gdb,但是当我这样做时

(gdb) generate-core-dump

我收到错误

warning: Memory read failed for corefile section, 1048576 bytes at 0x4156c000.
warning: Memory read failed for corefile section, 1048576 bytes at 0x50c00000.
Saved corefile core.5546
The program is running.  Quit anyway (and detach it)? (y or n) [answered Y; input not from terminal]
Tamper Detected
**********OUTSIDE ifelse 0*********
length validation is failed

我还设置了ulimit -c 50000,但核心转储仍超过此限制。当我ls -l检查文件大小时,它超过300 MB。在这种情况下,我应该如何限制核心转储的大小?

3 个答案:

答案 0 :(得分:9)

GDB不尊重'ulimit -c',只有内核会这样做。

目前尚不清楚您是在目标板上运行GDB,还是在开发主机上运行(并在目标上使用gdbserver)。您可能应该使用后者,这将允许您收集完整的核心转储。

截断的核心转储无论如何都是一种痛苦,因为它们通常不会包含调试问题所需的信息。

答案 1 :(得分:4)

在你的shell rc文件中:

limit coredumpsize 50000             # or whatever limit size you like

应设置所有内容的限制,包括GDB

注意:

如果将其设置为0,则可以确保主目录不会被核心转储文件混乱。

答案 2 :(得分:0)

你什么时候使用ulimit -c?必须在启动您正在为其生成核心转储的程序之前以及在同一会话中使用它。