home *** CD-ROM | disk | FTP | other *** search
- /*
- (C) 1995-96 AROS - The Amiga Replacement OS
- $Id: signal.c,v 1.7 1997/01/01 03:46:16 ldp Exp $
- $Log: signal.c,v $
- Revision 1.7 1997/01/01 03:46:16 ldp
- Committed Amiga native (support) code
-
- Changed clib to proto
-
- Revision 1.6 1996/12/10 13:51:54 aros
- Moved all #include's in the first column so makedepend can see it.
-
- Revision 1.5 1996/10/24 15:50:58 aros
- Use the official AROS macros over the __AROS versions.
-
- Revision 1.4 1996/08/13 13:56:09 digulla
- Replaced AROS_LA by AROS_LHA
- Replaced some AROS_LH*I by AROS_LH*
- Sorted and added includes
-
- Revision 1.3 1996/08/01 17:41:20 digulla
- Added standard header for all files
-
- Desc:
- Lang: english
- */
- #include <exec/execbase.h>
- #include <aros/libcall.h>
- #include <proto/exec.h>
-
- /*****************************************************************************
-
- NAME */
-
- AROS_LH2(void, Signal,
-
- /* SYNOPSIS */
- AROS_LHA(struct Task *, task, A1),
- AROS_LHA(ULONG, signalSet, D0),
-
- /* LOCATION */
- struct ExecBase *, SysBase, 54, Exec)
-
- /* FUNCTION
- Send some signals to a given task. If the task is currently waiting
- on these signals, has a higher priority as the current one and if
- taskswitches are allowed the new task begins to run immediately.
-
- INPUTS
- task - Pointer to task structure.
- signalSet - The set of signals to send to the task.
-
- RESULT
-
- NOTES
- This function may be used from interrupts.
-
- EXAMPLE
-
- BUGS
-
- SEE ALSO
- AllocSignal(), FreeSignal(), Wait(), SetSignal(), SetExcept()
-
- INTERNALS
-
- HISTORY
-
- ******************************************************************************/
- {
- AROS_LIBFUNC_INIT
-
- /* Protect the task lists against other tasks that may use Signal(). */
- Disable();
-
- /* Set the signals in the task structure. */
- task->tc_SigRecvd|=signalSet;
-
- /* Do those bits raise exceptions? */
- if(task->tc_SigExcept&task->tc_SigRecvd)
- {
- /* Yes. Set the exception flag. */
- task->tc_Flags|=TF_EXCEPT;
-
- /* task is running? Raise the exception or defer it for later. */
- if(task->tc_State==TS_RUN)
- {
- /* Are taskswitches allowed? (Don't count own Disable() here) */
- if(SysBase->TDNestCnt>=0||SysBase->IDNestCnt>0)
- /* No. Store it for later. */
- SysBase->AttnResched|=0x80;
- else
- {
- /* Switches are allowed. Move the current task away. */
- SysBase->ThisTask->tc_State=TS_READY;
- Enqueue(&SysBase->TaskReady,&SysBase->ThisTask->tc_Node);
-
- /* And force a rescedule. */
- Switch();
- }
-
- /* All done. */
- Enable();
- return;
- }
- }
-
- /*
- Is the task receiving the signals waiting on them
- (or on a exception) ?
- */
- if(task->tc_State==TS_WAIT&&
- (task->tc_SigRecvd&(task->tc_SigWait|task->tc_SigExcept)))
- {
- /* Yes. Move him to the ready list. */
- task->tc_State=TS_READY;
- Remove(&task->tc_Node);
- Enqueue(&SysBase->TaskReady,&task->tc_Node);
-
- /* Has it a higher priority as the current one? */
- if(task->tc_Node.ln_Pri>SysBase->ThisTask->tc_Node.ln_Pri)
- /*
- Yes. A taskswitch is necessary. Prepare one if possible.
- (If the current task is not running it is already moved)
- */
- if(SysBase->ThisTask->tc_State==TS_RUN)
- {
- /* Are taskswitches allowed? */
- if(SysBase->TDNestCnt>=0||SysBase->IDNestCnt>0)
- /* No. Store it for later. */
- SysBase->AttnResched|=0x80;
- else
- {
- /* Switches are allowed. Move the current task away. */
- SysBase->ThisTask->tc_State=TS_READY;
- Enqueue(&SysBase->TaskReady,&SysBase->ThisTask->tc_Node);
-
- /* And force a rescedule. */
- Switch();
- }
- }
- }
-
- Enable();
- AROS_LIBFUNC_EXIT
- }
-
-