]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR libfortran/54736 (GFORTRAN_CONVERT_UNIT causes malloc error on several platforms)
authorThomas Koenig <tkoenig@gcc.gnu.org>
Sun, 21 Oct 2012 13:43:32 +0000 (13:43 +0000)
committerThomas Koenig <tkoenig@gcc.gnu.org>
Sun, 21 Oct 2012 13:43:32 +0000 (13:43 +0000)
2012-10-21  Thomas König  <tkoenig@gcc.gnu.org>

PR libfortran/54736
Backport from trunk
* runtime/environ.c (search_unit):  Correct logic
for binary search.
(mark_single):  Fix index errors.

From-SVN: r192653

libgfortran/ChangeLog
libgfortran/runtime/environ.c

index 3921f72a63cfc0161063e4515e49491d18c190b8..a57a66dac2936c8ff1778ad2b2118a294d961694 100644 (file)
@@ -1,3 +1,11 @@
+2012-10-21  Thomas König  <tkoenig@gcc.gnu.org>
+
+       PR libfortran/54736
+       Backport from trunk
+       * runtime/environ.c (search_unit):  Correct logic
+       for binary search.
+       (mark_single):  Fix index errors.
+
 2012-05-12  Tobias Burnus  <burnus@net-b.de>
 
        PR fortran/53310
index a6ce645e0e17a6399f4c5ce6a0b14bcb95418b60..accf2b10c28bda2bc371d720b089a0b5a1fd9d85 100644 (file)
@@ -453,21 +453,35 @@ search_unit (int unit, int *ip)
 {
   int low, high, mid;
 
-  low = -1;
-  high = n_elist;
-  while (high - low > 1)
+  if (n_elist == 0)
+    {
+      *ip = 0;
+      return 0;
+    }
+
+  low = 0;
+  high = n_elist - 1;
+
+  do 
     {
       mid = (low + high) / 2;
-      if (unit <= elist[mid].unit)
-       high = mid;
+      if (unit == elist[mid].unit)
+       {
+         *ip = mid;
+         return 1;
+       }
+      else if (unit > elist[mid].unit)
+       low = mid + 1;
       else
-       low = mid;
-    }
-  *ip = high;
-  if (elist[high].unit == unit)
-    return 1;
+       high = mid - 1;
+    } while (low <= high);
+
+  if (unit > elist[mid].unit)
+    *ip = mid + 1;
   else
-    return 0;
+    *ip = mid;
+
+  return 0;
 }
 
 /* This matches a keyword.  If it is found, return the token supplied,
@@ -582,13 +596,13 @@ mark_single (int unit)
     }
   if (search_unit (unit, &i))
     {
-      elist[unit].conv = endian;
+      elist[i].conv = endian;
     }
   else
     {
-      for (j=n_elist; j>=i; j--)
+      for (j=n_elist-1; j>=i; j--)
        elist[j+1] = elist[j];
-    
+
       n_elist += 1;
       elist[i].unit = unit;
       elist[i].conv = endian;