From: Ruediger Pluem Date: Tue, 10 Oct 2017 05:53:35 +0000 (+0000) Subject: Merge r1811569 from trunk: X-Git-Tag: 2.4.29~59 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=763fec5ae90bcef362f5a60ba91df4effba1e638;p=apache Merge r1811569 from trunk: * The calculation of the sizes was flawed: The index tells us the size of the node in 4096 byte pages minus 1. Hence we need to multiply back with 4096 aka << 12 (plus adding the missing page). Submitted by: rpluem git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/branches/2.4.x@1811642 13f79535-47bb-0310-9956-ffa450edef68 --- diff --git a/.gdbinit b/.gdbinit index 7f1a5ba979..74b179f003 100644 --- a/.gdbinit +++ b/.gdbinit @@ -374,8 +374,8 @@ define dump_allocator if $node != 0 printf " #%2d: ", $i while $node != 0 - printf "%d, ", 4096 << $node->index - set $kb = $kb + (4 << $node->index) + printf "%d, ", ($node->index + 1) << 12 + set $kb = $kb + (($node->index + 1) << 2) set $node = $node->next end printf "ends.\n" @@ -396,7 +396,7 @@ define dump_one_pool set $node = $arg0->active set $done = 0 while $done == 0 - set $size = $size + (4096 << $node->index) + set $size = $size + (($node->index + 1) << 12) set $free = $free + ($node->endp - $node->first_avail) set $nodes = $nodes + 1 set $node = $node->next @@ -444,7 +444,7 @@ class DumpPoolAndChilds (gdb.Command): if node != 0: while node != 0: noded = node.dereference() - kb = kb + (4 << int(noded['index'])) + kb = kb + ((int(noded['index']) + 1) << 2) node = noded['next'] i = i + 1 self.total_free_blocks[salloc] = kb @@ -461,7 +461,7 @@ class DumpPoolAndChilds (gdb.Command): done = 0 while done == 0: noded = node.dereference() - size = size + (4096 << int(noded['index'])) + size = size + ((int(noded['index']) + 1) << 12) free = free + (noded['endp'] - noded['first_avail']) nodes = nodes + 1 node = noded['next']