mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-21 20:40:05 +00:00
malloc: Account for all heaps in an arena in malloc_info [BZ #22439]
This commit adds a "subheaps" field to the malloc_info output that shows the number of heaps that were allocated to extend a non-main arena. Reviewed-by: Siddhesh Poyarekar <siddhesh@sourceware.org>
This commit is contained in:
parent
7a9368a117
commit
34eb41579c
@ -1,3 +1,9 @@
|
|||||||
|
2017-11-15 Florian Weimer <fweimer@redhat.com>
|
||||||
|
|
||||||
|
[BZ #22439]
|
||||||
|
* malloc/malloc.c (__malloc_info): Count all heaps in an arena,
|
||||||
|
not just the top one. Output a new "subheaps" statistic.
|
||||||
|
|
||||||
2017-11-15 Florian Weimer <fweimer@redhat.com>
|
2017-11-15 Florian Weimer <fweimer@redhat.com>
|
||||||
|
|
||||||
[BZ #22408]
|
[BZ #22408]
|
||||||
|
3
NEWS
3
NEWS
@ -63,6 +63,9 @@ Deprecated and removed features, and other changes affecting compatibility:
|
|||||||
* The res_hnok, res_dnok, res_mailok and res_ownok functions now check that
|
* The res_hnok, res_dnok, res_mailok and res_ownok functions now check that
|
||||||
the specified string can be parsed as a domain name.
|
the specified string can be parsed as a domain name.
|
||||||
|
|
||||||
|
* In the malloc_info output, the <heap> element may contain another <aspace>
|
||||||
|
element, "subheaps", which contains the number of sub-heaps.
|
||||||
|
|
||||||
Changes to build and runtime requirements:
|
Changes to build and runtime requirements:
|
||||||
|
|
||||||
[Add changes to build and runtime requirements here]
|
[Add changes to build and runtime requirements here]
|
||||||
|
@ -5457,11 +5457,19 @@ __malloc_info (int options, FILE *fp)
|
|||||||
|
|
||||||
size_t heap_size = 0;
|
size_t heap_size = 0;
|
||||||
size_t heap_mprotect_size = 0;
|
size_t heap_mprotect_size = 0;
|
||||||
|
size_t heap_count = 0;
|
||||||
if (ar_ptr != &main_arena)
|
if (ar_ptr != &main_arena)
|
||||||
{
|
{
|
||||||
|
/* Iterate over the arena heaps from back to front. */
|
||||||
heap_info *heap = heap_for_ptr (top (ar_ptr));
|
heap_info *heap = heap_for_ptr (top (ar_ptr));
|
||||||
heap_size = heap->size;
|
do
|
||||||
heap_mprotect_size = heap->mprotect_size;
|
{
|
||||||
|
heap_size += heap->size;
|
||||||
|
heap_mprotect_size += heap->mprotect_size;
|
||||||
|
heap = heap->prev;
|
||||||
|
++heap_count;
|
||||||
|
}
|
||||||
|
while (heap != NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
__libc_lock_unlock (ar_ptr->mutex);
|
__libc_lock_unlock (ar_ptr->mutex);
|
||||||
@ -5499,8 +5507,9 @@ __malloc_info (int options, FILE *fp)
|
|||||||
{
|
{
|
||||||
fprintf (fp,
|
fprintf (fp,
|
||||||
"<aspace type=\"total\" size=\"%zu\"/>\n"
|
"<aspace type=\"total\" size=\"%zu\"/>\n"
|
||||||
"<aspace type=\"mprotect\" size=\"%zu\"/>\n",
|
"<aspace type=\"mprotect\" size=\"%zu\"/>\n"
|
||||||
heap_size, heap_mprotect_size);
|
"<aspace type=\"subheaps\" size=\"%zu\"/>\n",
|
||||||
|
heap_size, heap_mprotect_size, heap_count);
|
||||||
total_aspace += heap_size;
|
total_aspace += heap_size;
|
||||||
total_aspace_mprotect += heap_mprotect_size;
|
total_aspace_mprotect += heap_mprotect_size;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user