在我的中间件软件层中,我收到了很多因邮件而崩溃的内容,
page allocation failure. order:10, mode:0xd1
据我所知,崩溃可能由于多种原因而发生,动态内存耗尽以进行进一步分配或内存碎片。
由于消息来自第三方驱动程序模块,因此消息后面的回溯无关紧要。很可能问题在于该驱动程序,但不幸的是,我既无法从源代码获取任何调试信息。我想使用一些编程函数调用来描述我的源代码,以便排除我上面提到的两种情况的可能性。
我无法使用valgrind
,因为Val尚未完全支持ARM。
[更新:]添加堆栈跟踪,因为@caf的回答表明其中可能存在一些有价值的信息。
Application: page allocation failure. order:10, mode:0xd1
Backtrace:
[<c00297d0>] (dump_backtrace+0x0/0x114) from [<c02812b8>] (dump_stack+0x18/0x1c)
r7:0000000a r6:000000d1 r5:00000000 r4:00000000
[<c02812a0>] (dump_stack+0x0/0x1c) from [<c00716e4>] (__alloc_pages_nodemask+0x49c/0x4fc)
[<c0071248>] (__alloc_pages_nodemask+0x0/0x4fc) from [<c007175c>] (__get_free_pages+0x18/0x44)
[<c0071744>] (__get_free_pages+0x0/0x44) from [<bf021790>] (tsif_request_rx_buffer+0x74/0xf4 [tsif_data])
[<bf02171c>] (tsif_request_rx_buffer+0x0/0xf4 [tsif_data]) from [<bf021bd8>] (tsif_data_ioctl+0x17c/0x9d4 [tsif_data])
r7:be9e8604 r6:c0045319 r5:c3793400 r4:00000007
[<bf021a5c>] (tsif_data_ioctl+0x0/0x9d4 [tsif_data]) from [<c00a1c30>] (vfs_ioctl+0x78/0x94)
[<c00a1bb8>] (vfs_ioctl+0x0/0x94) from [<c00a22e0>] (do_vfs_ioctl+0x594/0x5f0)
r7:c2067e80 r6:00000021 r5:c2067e80 r4:00000021
[<c00a1d4c>] (do_vfs_ioctl+0x0/0x5f0) from [<c00a237c>] (sys_ioctl+0x40/0x64)
[<c00a233c>] (sys_ioctl+0x0/0x64) from [<c0025ec0>] (ret_fast_syscall+0x0/0x28)
r7:00000036 r6:00144220 r5:00139030 r4:008a47cc
Mem-info:
DMA per-cpu:
CPU 0: hi: 18, btch: 3 usd: 0
active_anon:4120 inactive_anon:134 isolated_anon:0
active_file:79 inactive_file:3729 isolated_file:0
unevictable:0 dirty:0 writeback:0 unstable:0 buffer:0
free:4137 slab_reclaimable:198 slab_unreclaimable:894
mapped:1707 shmem:64 pagetables:75 bounce:0
DMA free:16548kB min:1104kB low:1380kB high:1656kB active_anon:16480kB inactive_anon:536kB active_file:316kB inactive_file:14916kB unevictable:0kB isolated(o
lowmem_reserve[]: 0 0 0
DMA: 215*4kB 131*8kB 73*16kB 49*32kB 30*64kB 8*128kB 3*256kB 2*512kB 3*1024kB 2*2048kB 0*4096kB 0*8192kB 0*16384kB = 16548kB
3872 total pagecache pages
19200 pages of RAM
4209 free pages
4738 reserved pages
960 slab pages
1751 pages shared
0 pages swap cached
所以问题是如何以编程方式获取C / C ++代码当前可用的内存量,该平台是Linux。
答案 0 :(得分:13)
您显示的消息表示无法为内核分配而不是用户空间分配分配内存。这是一个4MB(这是order = 10
意味着)连续物理内存块的请求。这是一个非常大的kmalloc()
请求,它失败并不奇怪(可能是由于内存碎片而不是空闲内存)。
您可以在/proc/meminfo
中找到可用的可用内存量,但是在回溯之后,可以立即从内核日志中获得更详细的摘要 - 从行{{1开始}}
您的回溯显示可用内存为16548kB,但最大块为2048kB("Mem-info"
)。所以内存碎片确实是你的问题。
通过阅读您似乎正在使用的source to the tsif
driver,似乎驱动程序请求内核分配,其大小完全由用户空间控制,由order = 9
TSIF_REQ_RX_BUF
调用(这是一个真的糟糕的设计,特别是考虑到它甚至没有尝试向用户空间报告失败!)。我的建议是使用ioctl()
缩小您请求的缓冲区大小。