olga / rpms / glibc

Forked from rpms/glibc 5 years ago
Clone
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
 	}