2013-03-01 Tobias Burnus <burnus@net-b.de>
authorburnus <burnus@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 1 Mar 2013 10:24:11 +0000 (10:24 +0000)
committerburnus <burnus@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 1 Mar 2013 10:24:11 +0000 (10:24 +0000)
        * trans-decl.c (gfc_trans_deferred_vars): Free expr after use.
        * trans-io.c (build_dt): Ditto.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@196372 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/fortran/ChangeLog
gcc/fortran/trans-decl.c
gcc/fortran/trans-io.c

index 2bea996..cb6fd61 100644 (file)
@@ -1,3 +1,8 @@
+2013-03-01  Tobias Burnus  <burnus@net-b.de>
+
+       * trans-decl.c (gfc_trans_deferred_vars): Free expr after use.
+       * trans-io.c (build_dt): Ditto.
+
 2013-02-24  Joseph Myers  <joseph@codesourcery.com>
 
        * resolve.c (generate_component_assignments): Don't use UTF-8
index 337d747..7806bbb 100644 (file)
@@ -3818,10 +3818,12 @@ gfc_trans_deferred_vars (gfc_symbol * proc_sym, gfc_wrapped_block * block)
                                                      NULL_TREE, true, NULL,
                                                      true);
                  else
-                   tmp = gfc_deallocate_scalar_with_status (se.expr, NULL_TREE,
-                                                  true,
-                                                  gfc_lval_expr_from_sym (sym),
-                                                  sym->ts);
+                   {
+                     gfc_expr *expr = gfc_lval_expr_from_sym (sym);
+                     tmp = gfc_deallocate_scalar_with_status (se.expr, NULL_TREE,
+                                                  true, expr, sym->ts);
+                     gfc_free_expr (expr);
+                   }
                }
              if (sym->ts.type == BT_CLASS)
                {
index bb5fa24..9394810 100644 (file)
@@ -1782,6 +1782,8 @@ build_dt (tree function, gfc_code * code)
          mask |= set_string (&block, &post_block, var, IOPARM_dt_namelist_name,
                              nmlname);
 
+         gfc_free_expr (nmlname);
+
          if (last_dt == READ)
            mask |= IOPARM_dt_namelist_read_mode;