diff options
author | Thomas Schwinge <thomas@codesourcery.com> | 2023-02-12 16:35:44 +0100 |
---|---|---|
committer | Thomas Schwinge <thomas@codesourcery.com> | 2023-02-12 16:35:44 +0100 |
commit | d4d6d573b4a232519992123ae35740b0e5fa03da (patch) | |
tree | e46611c950994b3dac5e088950b5b84f68a0744c /gcc/fortran/frontend-passes.cc | |
parent | 2c454254ce5e41ca86717127d53ab75f8b64126a (diff) | |
parent | a31becca488b537cfc24bba7c0f48b2c44726240 (diff) | |
download | gcc-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.cc | 13 |
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); } } } |