|
|
00db10 |
commit 7da6d9ed266105e0ebefd01a4b6bf08bf56257c3
|
|
|
00db10 |
Author: Siddhesh Poyarekar <siddhesh@redhat.com>
|
|
|
00db10 |
Date: Tue Feb 26 14:24:40 2013 +0530
|
|
|
00db10 |
|
|
|
00db10 |
Fix FPE in memusagestat when malloc utilization is zero
|
|
|
00db10 |
|
|
|
00db10 |
[BZ #15160]
|
|
|
00db10 |
|
|
|
00db10 |
Draw graphs for heap and stack only if MAXSIZE_HEAP and MAXSIZE_STACK
|
|
|
00db10 |
are non-zero.
|
|
|
00db10 |
|
|
|
00db10 |
diff --git glibc-2.17-c758a686/malloc/memusagestat.c glibc-2.17-c758a686/malloc/memusagestat.c
|
|
|
00db10 |
index f561e0d..7bbd009 100644
|
|
|
00db10 |
--- glibc-2.17-c758a686/malloc/memusagestat.c
|
|
|
00db10 |
+++ glibc-2.17-c758a686/malloc/memusagestat.c
|
|
|
00db10 |
@@ -319,17 +319,26 @@ main (int argc, char *argv[])
|
|
|
00db10 |
|
|
|
00db10 |
for (line = 1; line <= 3; ++line)
|
|
|
00db10 |
{
|
|
|
00db10 |
- cnt = ((ysize - 40) * (maxsize_heap / 4 * line / heap_scale)) /
|
|
|
00db10 |
- (maxsize_heap / heap_scale);
|
|
|
00db10 |
- gdImageDashedLine (im_out, 40, ysize - 20 - cnt, xsize - 40,
|
|
|
00db10 |
- ysize - 20 - cnt, red);
|
|
|
00db10 |
- snprintf (buf, sizeof (buf), heap_format, maxsize_heap / 4 * line /
|
|
|
00db10 |
- heap_scale);
|
|
|
00db10 |
- gdImageString (im_out, gdFontSmall, 39 - strlen (buf) * 6,
|
|
|
00db10 |
- ysize - 26 - cnt, (unsigned char *) buf, red);
|
|
|
00db10 |
-
|
|
|
00db10 |
- cnt2 = ((ysize - 40) * (maxsize_stack / 4 * line / stack_scale)) /
|
|
|
00db10 |
- (maxsize_stack / stack_scale);
|
|
|
00db10 |
+ if (maxsize_heap > 0)
|
|
|
00db10 |
+ {
|
|
|
00db10 |
+ cnt = (((ysize - 40) * (maxsize_heap / 4 * line / heap_scale))
|
|
|
00db10 |
+ / (maxsize_heap / heap_scale));
|
|
|
00db10 |
+ gdImageDashedLine (im_out, 40, ysize - 20 - cnt, xsize - 40,
|
|
|
00db10 |
+ ysize - 20 - cnt, red);
|
|
|
00db10 |
+ snprintf (buf, sizeof (buf), heap_format,
|
|
|
00db10 |
+ maxsize_heap / 4 * line / heap_scale);
|
|
|
00db10 |
+ gdImageString (im_out, gdFontSmall, 39 - strlen (buf) * 6,
|
|
|
00db10 |
+ ysize - 26 - cnt, (unsigned char *) buf, red);
|
|
|
00db10 |
+ }
|
|
|
00db10 |
+ else
|
|
|
00db10 |
+ cnt = 0;
|
|
|
00db10 |
+
|
|
|
00db10 |
+ if (maxsize_stack > 0)
|
|
|
00db10 |
+ cnt2 = (((ysize - 40) * (maxsize_stack / 4 * line / stack_scale))
|
|
|
00db10 |
+ / (maxsize_stack / stack_scale));
|
|
|
00db10 |
+ else
|
|
|
00db10 |
+ cnt2 = 0;
|
|
|
00db10 |
+
|
|
|
00db10 |
if (cnt != cnt2)
|
|
|
00db10 |
gdImageDashedLine (im_out, 40, ysize - 20 - cnt2, xsize - 40,
|
|
|
00db10 |
ysize - 20 - cnt2, green);
|
|
|
00db10 |
@@ -372,7 +381,7 @@ main (int argc, char *argv[])
|
|
|
00db10 |
ysize - 14, yellow);
|
|
|
00db10 |
previously = now;
|
|
|
00db10 |
|
|
|
00db10 |
- if (also_total)
|
|
|
00db10 |
+ if (also_total && maxsize_heap > 0)
|
|
|
00db10 |
{
|
|
|
00db10 |
size_t new3;
|
|
|
00db10 |
|
|
|
00db10 |
@@ -386,21 +395,27 @@ main (int argc, char *argv[])
|
|
|
00db10 |
last_total = new3;
|
|
|
00db10 |
}
|
|
|
00db10 |
|
|
|
00db10 |
- // assert (entry.heap <= maxsize_heap);
|
|
|
00db10 |
- new[0] = (ysize - 20) - ((((unsigned long long int) (ysize - 40))
|
|
|
00db10 |
- * entry.heap) / maxsize_heap);
|
|
|
00db10 |
- gdImageLine (im_out, 40 + ((xsize - 80) * (cnt - 1)) / total,
|
|
|
00db10 |
- last_heap, 40 + ((xsize - 80) * cnt) / total, new[0],
|
|
|
00db10 |
- red);
|
|
|
00db10 |
- last_heap = new[0];
|
|
|
00db10 |
-
|
|
|
00db10 |
- // assert (entry.stack <= maxsize_stack);
|
|
|
00db10 |
- new[1] = (ysize - 20) - ((((unsigned long long int) (ysize - 40))
|
|
|
00db10 |
- * entry.stack) / maxsize_stack);
|
|
|
00db10 |
- gdImageLine (im_out, 40 + ((xsize - 80) * (cnt - 1)) / total,
|
|
|
00db10 |
- last_stack, 40 + ((xsize - 80) * cnt) / total, new[1],
|
|
|
00db10 |
- green);
|
|
|
00db10 |
- last_stack = new[1];
|
|
|
00db10 |
+ if (maxsize_heap > 0)
|
|
|
00db10 |
+ {
|
|
|
00db10 |
+ new[0] = ((ysize - 20)
|
|
|
00db10 |
+ - ((((unsigned long long int) (ysize - 40))
|
|
|
00db10 |
+ * entry.heap) / maxsize_heap));
|
|
|
00db10 |
+ gdImageLine (im_out, 40 + ((xsize - 80) * (cnt - 1)) / total,
|
|
|
00db10 |
+ last_heap, 40 + ((xsize - 80) * cnt) / total,
|
|
|
00db10 |
+ new[0], red);
|
|
|
00db10 |
+ last_heap = new[0];
|
|
|
00db10 |
+ }
|
|
|
00db10 |
+
|
|
|
00db10 |
+ if (maxsize_stack > 0)
|
|
|
00db10 |
+ {
|
|
|
00db10 |
+ new[1] = ((ysize - 20)
|
|
|
00db10 |
+ - ((((unsigned long long int) (ysize - 40))
|
|
|
00db10 |
+ * entry.stack) / maxsize_stack));
|
|
|
00db10 |
+ gdImageLine (im_out, 40 + ((xsize - 80) * (cnt - 1)) / total,
|
|
|
00db10 |
+ last_stack, 40 + ((xsize - 80) * cnt) / total,
|
|
|
00db10 |
+ new[1], green);
|
|
|
00db10 |
+ last_stack = new[1];
|
|
|
00db10 |
+ }
|
|
|
00db10 |
}
|
|
|
00db10 |
|
|
|
00db10 |
cnt = 0;
|
|
|
00db10 |
@@ -448,7 +463,7 @@ main (int argc, char *argv[])
|
|
|
00db10 |
next_tick += MAX (1, total / 20);
|
|
|
00db10 |
}
|
|
|
00db10 |
|
|
|
00db10 |
- if (also_total)
|
|
|
00db10 |
+ if (also_total && maxsize_heap > 0)
|
|
|
00db10 |
{
|
|
|
00db10 |
size_t new3;
|
|
|
00db10 |
|
|
|
00db10 |
@@ -459,16 +474,24 @@ main (int argc, char *argv[])
|
|
|
00db10 |
last_total = new3;
|
|
|
00db10 |
}
|
|
|
00db10 |
|
|
|
00db10 |
- new[0] = (ysize - 20) - ((((unsigned long long int) (ysize - 40))
|
|
|
00db10 |
- * entry.heap) / maxsize_heap);
|
|
|
00db10 |
- gdImageLine (im_out, last_xpos, last_heap, xpos, new[0], red);
|
|
|
00db10 |
- last_heap = new[0];
|
|
|
00db10 |
+ if (maxsize_heap > 0)
|
|
|
00db10 |
+ {
|
|
|
00db10 |
+ new[0] = ((ysize - 20)
|
|
|
00db10 |
+ - ((((unsigned long long int) (ysize - 40))
|
|
|
00db10 |
+ * entry.heap) / maxsize_heap));
|
|
|
00db10 |
+ gdImageLine (im_out, last_xpos, last_heap, xpos, new[0], red);
|
|
|
00db10 |
+ last_heap = new[0];
|
|
|
00db10 |
+ }
|
|
|
00db10 |
|
|
|
00db10 |
- // assert (entry.stack <= maxsize_stack);
|
|
|
00db10 |
- new[1] = (ysize - 20) - ((((unsigned long long int) (ysize - 40))
|
|
|
00db10 |
- * entry.stack) / maxsize_stack);
|
|
|
00db10 |
- gdImageLine (im_out, last_xpos, last_stack, xpos, new[1], green);
|
|
|
00db10 |
- last_stack = new[1];
|
|
|
00db10 |
+ if (maxsize_stack > 0)
|
|
|
00db10 |
+ {
|
|
|
00db10 |
+ new[1] = ((ysize - 20)
|
|
|
00db10 |
+ - ((((unsigned long long int) (ysize - 40))
|
|
|
00db10 |
+ * entry.stack) / maxsize_stack));
|
|
|
00db10 |
+ gdImageLine (im_out, last_xpos, last_stack, xpos, new[1],
|
|
|
00db10 |
+ green);
|
|
|
00db10 |
+ last_stack = new[1];
|
|
|
00db10 |
+ }
|
|
|
00db10 |
|
|
|
00db10 |
last_xpos = xpos;
|
|
|
00db10 |
}
|