]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
Fortran: fix FE memleak
authorHarald Anlauf <anlauf@gmx.de>
Wed, 3 Jan 2024 19:21:00 +0000 (20:21 +0100)
committerHarald Anlauf <anlauf@gmx.de>
Wed, 3 Jan 2024 19:21:00 +0000 (20:21 +0100)
gcc/fortran/ChangeLog:

* trans-types.cc (gfc_get_nodesc_array_type): Clear used gmp
variables.

gcc/fortran/trans-types.cc

index e6db1c9545037ab5b6dd94e7633a89239086c1ba..676014e9b98450a474965e103ea914ab2c74be30 100644 (file)
@@ -1795,7 +1795,7 @@ gfc_get_nodesc_array_type (tree etype, gfc_array_spec * as, gfc_packed packed,
          TYPE_LANG_SPECIFIC (type) = TYPE_LANG_SPECIFIC (TREE_TYPE (type));
        }
 
-      return type;
+      goto array_type_done;
     }
 
   if (known_stride)
@@ -1814,10 +1814,6 @@ gfc_get_nodesc_array_type (tree etype, gfc_array_spec * as, gfc_packed packed,
 
   layout_type (type);
 
-  mpz_clear (offset);
-  mpz_clear (stride);
-  mpz_clear (delta);
-
   /* Represent packed arrays as multi-dimensional if they have rank >
      1 and with proper bounds, instead of flat arrays.  This makes for
      better debug info.  */
@@ -1848,6 +1844,12 @@ gfc_get_nodesc_array_type (tree etype, gfc_array_spec * as, gfc_packed packed,
       GFC_ARRAY_TYPE_P (type) = 1;
       TYPE_LANG_SPECIFIC (type) = TYPE_LANG_SPECIFIC (TREE_TYPE (type));
     }
+
+array_type_done:
+  mpz_clear (offset);
+  mpz_clear (stride);
+  mpz_clear (delta);
+
   return type;
 }