2 Copyright © 1995-2001, The AROS Development Team. All rights reserved.
8 #include <exec/execbase.h>
9 #include <exec/tasks.h>
10 #include <aros/libcall.h>
11 #include <proto/exec.h>
13 #include "exec_util.h"
14 #include "exec_debug.h"
16 # define DEBUG_RemTask 0
22 #include <aros/debug.h>
24 extern void Exec_Dispatch();
26 /*****************************************************************************
30 AROS_LH1(void, RemTask
,
33 AROS_LHA(struct Task
*, task
, A1
),
36 struct ExecBase
*, SysBase
, 48, Exec
)
39 Remove a task from the task lists. All memory in the tc_MemEntry list
40 is freed and a rescedule is done. It's safe to call RemTask() out
41 of Forbid() or Disable().
42 This function is one way to get rid of the current task. The other way
43 is to fall through the end of the entry point.
46 task - Task to be removed. NULL means current task.
63 ******************************************************************************/
69 /* A value of NULL means current task */
71 task
=SysBase
->ThisTask
;
73 D(bug("Call RemTask (%08lx (\"%s\"))\n", task
, task
->tc_Node
.ln_Name
));
76 Since it's possible that the following will free a task
77 structure that is used for some time afterwards it's
78 necessary to protect the free memory list so that nobody
79 can allocate that memory.
83 /* Remove() here, before freeing the MemEntry list. Because
84 the MemEntry list might contain the task struct itself! */
86 if(task
!= SysBase
->ThisTask
)
88 Remove(&task
->tc_Node
);
91 /* Free all memory in the tc_MemEntry list. */
92 while((mb
=(struct MemList
*)RemHead(&task
->tc_MemEntry
))!=NULL
)
93 /* Free one MemList node */
96 /* Uninitialize ETask structure */
100 CleanupETask(task
, et
);
103 /* Changing the task lists always needs a Disable(). */
106 /* Freeing myself? */
107 if(task
==SysBase
->ThisTask
)
109 /* Can't do that - let the dispatcher do it. */
110 task
->tc_State
=TS_REMOVED
;
113 Since I don't know how many levels of Forbid()
114 are already pending I set a default value.
116 SysBase
->TDNestCnt
=-1;
118 // task->tc_Node.ln_Pred->ln_Succ = task->tc_Node.ln_Succ;
119 // task->tc_Node.ln_Succ->ln_Pred = task->tc_Node.ln_Pred;
121 /* And force a task switch. Note: Dispatch, not Switch,
122 because the state of thistask must not be saved ->
123 after all the mem for the task + intetask + context
124 could already have been freed by the FreeEntry() call
128 Supervisor(__AROS_GETVECADDR(SysBase
, 10));
129 /* Does not return. */
136 ReturnVoid ("RemTask");