summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoel Sherrill <joel.sherrill@OARcorp.com>2003-10-22 17:13:58 +0000
committerJoel Sherrill <joel.sherrill@OARcorp.com>2003-10-22 17:13:58 +0000
commita51735cb4c92c873696e00e18ed75b64d6e9b2a7 (patch)
tree8bb9c8e3d47c70c6ec53f103e18c2c38c7a16da1
parent2003-10-22 Joel Sherrill <joel@OARcorp.com> (diff)
downloadrtems-a51735cb4c92c873696e00e18ed75b64d6e9b2a7.tar.bz2
2003-10-22 Joel Sherrill <joel@OARcorp.com>
PR 512/core * src/tasks.c, src/taskvariabledelete.c: Run task variable destructor when task variable is deleted. Also some style cleanup.
-rw-r--r--cpukit/rtems/ChangeLog6
-rw-r--r--cpukit/rtems/src/tasks.c4
-rw-r--r--cpukit/rtems/src/taskvariabledelete.c6
3 files changed, 12 insertions, 4 deletions
diff --git a/cpukit/rtems/ChangeLog b/cpukit/rtems/ChangeLog
index be5db3c071..8f784aa162 100644
--- a/cpukit/rtems/ChangeLog
+++ b/cpukit/rtems/ChangeLog
@@ -1,3 +1,9 @@
+2003-10-22 Joel Sherrill <joel@OARcorp.com>
+
+ PR 512/core
+ * src/tasks.c, src/taskvariabledelete.c: Run task variable destructor
+ when task variable is deleted. Also some style cleanup.
+
2003-09-11 Joel Sherrill <joel@OARcorp.com>
PR 488/rtems
diff --git a/cpukit/rtems/src/tasks.c b/cpukit/rtems/src/tasks.c
index e9d7954c50..b7eadbea8a 100644
--- a/cpukit/rtems/src/tasks.c
+++ b/cpukit/rtems/src/tasks.c
@@ -109,8 +109,8 @@ User_extensions_routine _RTEMS_tasks_Delete_extension(
while (tvp) {
next = tvp->next;
if (tvp->dtor)
- (*tvp->dtor)(*tvp->ptr );
- if (executing == deleted)
+ (*tvp->dtor)(*tvp->ptr);
+ if (_Thread_Is_executing(deleted))
*tvp->ptr = tvp->gval;
_Workspace_Free( tvp );
tvp = next;
diff --git a/cpukit/rtems/src/taskvariabledelete.c b/cpukit/rtems/src/taskvariabledelete.c
index 05f66d4cac..43a45471ab 100644
--- a/cpukit/rtems/src/taskvariabledelete.c
+++ b/cpukit/rtems/src/taskvariabledelete.c
@@ -53,10 +53,12 @@ rtems_status_code rtems_task_variable_delete(
if (tvp->ptr == ptr) {
if (prev) prev->next = tvp->next;
else the_thread->task_variables = tvp->next;
- if (_Thread_Is_executing (the_thread))
+ if (tvp->dtor)
+ (*tvp->dtor)(*tvp->ptr);
+ if (_Thread_Is_executing(the_thread))
*tvp->ptr = tvp->gval;
- _Thread_Enable_dispatch();
_Workspace_Free(tvp);
+ _Thread_Enable_dispatch();
return RTEMS_SUCCESSFUL;
}
prev = tvp;