forked from nuttx/nuttx-update
memdump: add dump for the orphan nodes(neighbor of free node)
Signed-off-by: buxiasen <buxiasen@xiaomi.com>
This commit is contained in:
parent
fd9a9f67cc
commit
9f2b08a91a
3 changed files with 31 additions and 1 deletions
|
@ -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: <used/free"
|
||||
"usage: <used/free/orphan"
|
||||
#if CONFIG_MM_HEAP_MEMPOOL_THRESHOLD > 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]))
|
||||
|
|
|
@ -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)
|
||||
|
|
|
@ -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);
|
||||
|
|
Loading…
Reference in a new issue