OSDN Git Service

* tree-ssa.c (redirect_edge_var_map_clear): Fix formatting.
authorhubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 11 Sep 2008 12:36:05 +0000 (12:36 +0000)
committerhubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 11 Sep 2008 12:36:05 +0000 (12:36 +0000)
(free_var_map_entry): New function.
(redirect_edge_var_map_destroy): Use it.

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

gcc/ChangeLog
gcc/tree-ssa.c

index 5777b0c..53fc1a4 100644 (file)
@@ -1,5 +1,11 @@
 2008-09-11  Jan Hubicka  <jh@suse.cz>
 
+       * tree-ssa.c (redirect_edge_var_map_clear): Fix formatting.
+       (free_var_map_entry): New function.
+       (redirect_edge_var_map_destroy): Use it.
+
+2008-09-11  Jan Hubicka  <jh@suse.cz>
+
        PR middle-end/37448
        * tree-inline.c (add_lexical_block): Replace with ...
        (prepend_lexical_block): ... prepend at begginig.
index eed15c6..6a1f6f3 100644 (file)
@@ -112,7 +112,8 @@ redirect_edge_var_map_clear (edge e)
 void
 redirect_edge_var_map_dup (edge newe, edge olde)
 {
-  void **new_slot, **old_slot; edge_var_map_vector head;
+  void **new_slot, **old_slot;
+  edge_var_map_vector head;
 
   if (!edge_var_maps)
     return;
@@ -149,6 +150,17 @@ redirect_edge_var_map_vector (edge e)
   return (edge_var_map_vector) *slot;
 }
 
+/* Used by redirect_edge_var_map_destroy to free all memory.  */
+
+static bool
+free_var_map_entry (const void *key ATTRIBUTE_UNUSED,
+                   void **value,
+                   void *data ATTRIBUTE_UNUSED)
+{
+  edge_var_map_vector head = (edge_var_map_vector) *value;
+  VEC_free (edge_var_map, heap, head);
+  return true;
+}
 
 /* Clear the edge variable mappings.  */
 
@@ -157,6 +169,7 @@ redirect_edge_var_map_destroy (void)
 {
   if (edge_var_maps)
     {
+      pointer_map_traverse (edge_var_maps, free_var_map_entry, NULL);
       pointer_map_destroy (edge_var_maps);
       edge_var_maps = NULL;
     }