OSDN Git Service

Fix for sim/common hw_delete()/hw_tree_delete()
authorciceron <ciceron>
Sat, 25 Nov 2000 09:18:52 +0000 (09:18 +0000)
committerciceron <ciceron>
Sat, 25 Nov 2000 09:18:52 +0000 (09:18 +0000)
sim/common/ChangeLog
sim/common/hw-alloc.c
sim/common/hw-base.c
sim/common/hw-base.h

index 831e274..473bb57 100644 (file)
@@ -1,5 +1,13 @@
 2000-11-24  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
 
+       * hw-base.c (hw_delete): Don't free base_of_hw since it's freed.
+       (set_hw_delete): Moved the macro as a function.
+       * hw-base.h (set_hw_delete): Declare as external function.
+       * hw-alloc.c (delete_hw_alloc_data): Allow to free the memory
+       allocated using hw_malloc.
+       
+2000-11-24  Stephane Carrez  <Stephane.Carrez@worldnet.fr>
+
        * sim-options.c (sim_parse_args): Free the memory used for
        long_options, short_options, handlers, opt_cpu, orig_val.
 
index e64ae82..5664e9b 100644 (file)
@@ -42,8 +42,6 @@ create_hw_alloc_data (struct hw *me)
 void
 delete_hw_alloc_data (struct hw *me)
 {
-  if (me->alloc_of_hw != NULL)
-    hw_abort (me, "hw-alloc botch");
   while (me->alloc_of_hw != NULL)
     {
       hw_free (me, me->alloc_of_hw->alloc);
index a13ac64..9c05da8 100644 (file)
@@ -510,10 +510,15 @@ hw_delete (struct hw *me)
   delete_hw_alloc_data (me);
 
   /* finally */
-  zfree (me->base_of_hw);
   zfree (me);
 }
 
+void
+set_hw_delete (struct hw *hw, hw_delete_callback method)
+{
+  hw->base_of_hw->to_delete = method;
+}
+
 
 /* Go through the devices various reg properties for those that
    specify attach addresses */
index d6452d1..5760103 100644 (file)
@@ -54,8 +54,7 @@ void hw_delete
 typedef void (hw_delete_callback)
      (struct hw *me);
 
-#define set_hw_delete(hw, method) \
-((hw)->base_of_hw->to_delete = (method))
+extern void set_hw_delete(struct hw* hw, hw_delete_callback method);
 
 
 /* ALLOC */