aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/frontend-passes.cc
diff options
context:
space:
mode:
authorThomas Schwinge <thomas@codesourcery.com>2023-02-12 16:35:44 +0100
committerThomas Schwinge <thomas@codesourcery.com>2023-02-12 16:35:44 +0100
commitd4d6d573b4a232519992123ae35740b0e5fa03da (patch)
treee46611c950994b3dac5e088950b5b84f68a0744c /gcc/fortran/frontend-passes.cc
parent2c454254ce5e41ca86717127d53ab75f8b64126a (diff)
parenta31becca488b537cfc24bba7c0f48b2c44726240 (diff)
downloadgcc-d4d6d573b4a232519992123ae35740b0e5fa03da.zip
gcc-d4d6d573b4a232519992123ae35740b0e5fa03da.tar.gz
gcc-d4d6d573b4a232519992123ae35740b0e5fa03da.tar.bz2
Merge commit '83ffe9cde7fe0b4deb0d1b54175fd9b19c38179c^' into HEAD
Diffstat (limited to 'gcc/fortran/frontend-passes.cc')
-rw-r--r--gcc/fortran/frontend-passes.cc13
1 files changed, 12 insertions, 1 deletions
diff --git a/gcc/fortran/frontend-passes.cc b/gcc/fortran/frontend-passes.cc
index 612c12d..db2b982 100644
--- a/gcc/fortran/frontend-passes.cc
+++ b/gcc/fortran/frontend-passes.cc
@@ -2892,7 +2892,12 @@ do_subscript (gfc_expr **e)
cmp = mpz_cmp (do_end, do_start);
if ((sgn > 0 && cmp < 0) || (sgn < 0 && cmp > 0))
- break;
+ {
+ mpz_clear (do_start);
+ mpz_clear (do_end);
+ mpz_clear (do_step);
+ break;
+ }
}
/* May have to correct the end value if the step does not equal
@@ -2965,6 +2970,12 @@ do_subscript (gfc_expr **e)
mpz_clear (val);
}
}
+
+ if (have_do_start)
+ mpz_clear (do_start);
+ if (have_do_end)
+ mpz_clear (do_end);
+ mpz_clear (do_step);
}
}
}