From 9f2b08a91af882696e2a2b586eee065ec1ac7bc5 Mon Sep 17 00:00:00 2001 From: buxiasen Date: Fri, 26 Jul 2024 21:36:45 +0800 Subject: [PATCH] memdump: add dump for the orphan nodes(neighbor of free node) Signed-off-by: buxiasen --- fs/procfs/fs_procfsmeminfo.c | 11 ++++++++++- include/malloc.h | 1 + mm/mm_heap/mm_memdump.c | 20 ++++++++++++++++++++ 3 files changed, 31 insertions(+), 1 deletion(-) diff --git a/fs/procfs/fs_procfsmeminfo.c b/fs/procfs/fs_procfsmeminfo.c index ada57edff1..ebec459cac 100644 --- a/fs/procfs/fs_procfsmeminfo.c +++ b/fs/procfs/fs_procfsmeminfo.c @@ -430,7 +430,7 @@ static ssize_t memdump_read(FAR struct file *filep, FAR char *buffer, DEBUGASSERT(procfile); linesize = procfs_snprintf(procfile->line, MEMINFO_LINELEN, - "usage: 0 "/mempool" #endif @@ -446,6 +446,7 @@ static ssize_t memdump_read(FAR struct file *filep, FAR char *buffer, ">\n" "used: dump all allocated node\n" "free: dump all free node\n" + "orphan: dump allocated free neighbored node\n" #if CONFIG_MM_HEAP_MEMPOOL_THRESHOLD > 0 "mempool: dump all mempool alloc node\n" #endif @@ -600,6 +601,14 @@ static ssize_t memdump_write(FAR struct file *filep, FAR const char *buffer, break; #endif + case 'o': + dump.pid = PID_MM_ORPHAN; +# if CONFIG_MM_BACKTRACE >= 0 + p = (FAR char *)buffer + 6; + goto dump; +# endif + break; + #if CONFIG_MM_BACKTRACE >= 0 default: if (!isdigit(buffer[0])) diff --git a/include/malloc.h b/include/malloc.h index ccae9330a0..1955b175ce 100644 --- a/include/malloc.h +++ b/include/malloc.h @@ -35,6 +35,7 @@ /* Special PID to query the info about alloc, free and mempool */ +#define PID_MM_ORPHAN ((pid_t)-6) #define PID_MM_BIGGEST ((pid_t)-5) #define PID_MM_FREE ((pid_t)-4) #define PID_MM_ALLOC ((pid_t)-3) diff --git a/mm/mm_heap/mm_memdump.c b/mm/mm_heap/mm_memdump.c index 0735730e0c..6a51ac948b 100644 --- a/mm/mm_heap/mm_memdump.c +++ b/mm/mm_heap/mm_memdump.c @@ -146,6 +146,15 @@ static void memdump_handler(FAR struct mm_allocnode_s *node, FAR void *arg) { memdump_allocnode(node); } + else if(dump->pid == PID_MM_ORPHAN && MM_DUMP_SEQNO(dump, node)) + { + FAR struct mm_allocnode_s *next = (FAR struct mm_allocnode_s *) + ((FAR char *)node + nodesize); + if (MM_PREVNODE_IS_FREE(node) || MM_NODE_IS_FREE(next)) + { + memdump_allocnode(node); + } + } #if CONFIG_MM_HEAP_BIGGEST_COUNT > 0 else if (dump->pid == PID_MM_BIGGEST && MM_DUMP_SEQNO(dump, node)) { @@ -231,6 +240,17 @@ void mm_memdump(FAR struct mm_heap_s *heap, # endif } #endif + else if (dump->pid == PID_MM_ORPHAN) + { + syslog(LOG_INFO, "Dump allocated orphan nodes\n"); +# if CONFIG_MM_BACKTRACE < 0 + syslog(LOG_INFO, "%12s%*s\n", "Size", BACKTRACE_PTR_FMT_WIDTH, + "Address"); +# else + syslog(LOG_INFO, "%6s%12s%12s%*s %s\n", "PID", "Size", "Sequence", + BACKTRACE_PTR_FMT_WIDTH, "Address", "Backtrace"); +# endif + } #ifdef CONFIG_MM_HEAP_MEMPOOL mempool_multiple_memdump(heap->mm_mpool, dump);