From ce13044d7a335947b721e7e83730a9f7d97de8e0 Mon Sep 17 00:00:00 2001 From: Stephane Carrez Date: Sat, 25 Nov 2000 09:18:52 +0000 Subject: [PATCH] Fix for sim/common hw_delete()/hw_tree_delete() --- sim/common/ChangeLog | 8 ++++++++ sim/common/hw-alloc.c | 2 -- sim/common/hw-base.c | 7 ++++++- sim/common/hw-base.h | 3 +-- 4 files changed, 15 insertions(+), 5 deletions(-) diff --git a/sim/common/ChangeLog b/sim/common/ChangeLog index 831e27425c..473bb57e12 100644 --- a/sim/common/ChangeLog +++ b/sim/common/ChangeLog @@ -1,3 +1,11 @@ +2000-11-24 Stephane Carrez + + * 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 * sim-options.c (sim_parse_args): Free the memory used for diff --git a/sim/common/hw-alloc.c b/sim/common/hw-alloc.c index e64ae82997..5664e9b5e3 100644 --- a/sim/common/hw-alloc.c +++ b/sim/common/hw-alloc.c @@ -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); diff --git a/sim/common/hw-base.c b/sim/common/hw-base.c index a13ac64ba3..9c05da8115 100644 --- a/sim/common/hw-base.c +++ b/sim/common/hw-base.c @@ -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 */ diff --git a/sim/common/hw-base.h b/sim/common/hw-base.h index d6452d1b38..57601034a7 100644 --- a/sim/common/hw-base.h +++ b/sim/common/hw-base.h @@ -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 */