summaryrefslogtreecommitdiffstats
path: root/cpukit/rtems
diff options
context:
space:
mode:
authorJoel Sherrill <joel.sherrill@OARcorp.com>2003-10-22 17:14:16 +0000
committerJoel Sherrill <joel.sherrill@OARcorp.com>2003-10-22 17:14:16 +0000
commit5bda3a9a721343d9044bc94883ae26c9ed1fe6df (patch)
tree8059d3187211dad3d50e89a8ce685539f5fa8a30 /cpukit/rtems
parent2003-10-22 Joel Sherrill <joel@OARcorp.com> (diff)
downloadrtems-5bda3a9a721343d9044bc94883ae26c9ed1fe6df.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.
Diffstat (limited to 'cpukit/rtems')
-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 ebbcb85994..7350b1bf68 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;