Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Merge branch 'master' into clean_events
[simgrid.git] / tools / cmake / test_prog / prog_stackgrowth.c
index f005341..dc7c0df 100644 (file)
 static int iterate = 10;
 static int growsdown(int *x)
 {
 static int iterate = 10;
 static int growsdown(int *x)
 {
-  int y;
-  y = (x > &y);
+  int y = (x > &y);
+
   if (--iterate > 0)
     y = growsdown(&y);
   if (--iterate > 0)
     y = growsdown(&y);
-  if (y != (x > &y))
+
+  /* The stack sometimes changes at the 0th level.
+   * Original version did fail in this case, but I changed this around SimGrid 3.13 because of https://bugs.debian.org/814272
+   * Every arch failed on that day :(
+   */
+  if (iterate != 0 && y != (x > &y)) {
+    fprintf(stderr, "The stack changed its direction! (Iteration: %d. It was growing %s; &y=%p; &prevY=%p)\n",
+            (10 - iterate), y ? "down" : "up", &y, x);
     exit(1);
     exit(1);
+  }
   return y;
 }
 
   return y;
 }
 
@@ -23,6 +31,6 @@ int main(int argc, char *argv[])
 {
   int x;
   printf("%s", growsdown(&x) ? "down" : "up");
 {
   int x;
   printf("%s", growsdown(&x) ? "down" : "up");
-  exit(0);
-  return 1;
+
+  return 0;
 }
 }