X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=kern%2Fsignal.c;h=8e0e6532482155f956259f485835a4ddee9b8c92;hb=d00ca36c2068d8b3099e956d59fcc314bf4b21b4;hp=9b61120a8e46aa1e243254da302641e0ccffa90b;hpb=23c24a8842abea3355937e9f67c17f4f1f1405a7;p=bertos.git diff --git a/kern/signal.c b/kern/signal.c old mode 100755 new mode 100644 index 9b61120a..8e0e6532 --- a/kern/signal.c +++ b/kern/signal.c @@ -1,9 +1,34 @@ -/*! +/** * \file * * * \brief IPC signals implementation. @@ -66,6 +91,21 @@ /*#* *#* $Log$ + *#* Revision 1.14 2006/07/19 12:56:27 bernie + *#* Convert to new Doxygen style. + *#* + *#* Revision 1.13 2006/02/24 01:17:05 bernie + *#* Update for new emulator. + *#* + *#* Revision 1.12 2005/11/04 16:20:02 bernie + *#* Fix reference to README.devlib in header. + *#* + *#* Revision 1.11 2005/04/11 19:10:28 bernie + *#* Include top-level headers from cfg/ subdir. + *#* + *#* Revision 1.10 2004/12/13 12:07:06 bernie + *#* DISABLE_IRQSAVE/ENABLE_IRQRESTORE: Convert to IRQ_SAVE_DISABLE/IRQ_RESTORE. + *#* *#* Revision 1.9 2004/12/08 08:57:35 bernie *#* Rename sigset_t to sigmask_t. *#* @@ -98,15 +138,14 @@ *#*/ #include "signal.h" -#include "proc.h" -#include "proc_p.h" -#include "hw.h" -#include -// FIXME +#include +#include +#include + #if CONFIG_KERN_SIGNALS -/*! +/** * Check if any of the signals in \a sigs has occurred and clear them. * Return the signals that have occurred. */ @@ -115,15 +154,16 @@ sigmask_t sig_check(sigmask_t sigs) sigmask_t result; cpuflags_t flags; - DISABLE_IRQSAVE(flags); + IRQ_SAVE_DISABLE(flags); result = CurrentProcess->sig_recv & sigs; CurrentProcess->sig_recv &= ~sigs; - ENABLE_IRQRESTORE(flags); + IRQ_RESTORE(flags); + return result; } -/*! +/** * Sleep until any of the signals in \a sigs occurs. * Return the signal(s) that have awaked the process. */ @@ -132,7 +172,7 @@ sigmask_t sig_wait(sigmask_t sigs) sigmask_t result; cpuflags_t flags; - DISABLE_IRQSAVE(flags); + IRQ_SAVE_DISABLE(flags); /* Loop until we get at least one of the signals */ while (!(result = CurrentProcess->sig_recv & sigs)) @@ -148,12 +188,13 @@ sigmask_t sig_wait(sigmask_t sigs) /* Signals found: clear them and return */ CurrentProcess->sig_recv &= ~sigs; - ENABLE_IRQRESTORE(flags); + + IRQ_RESTORE(flags); return result; } -/*! +/** * Send the signals \a sigs to the process \a proc. * The process will be awaken if it was waiting for any of them. * @@ -162,7 +203,7 @@ sigmask_t sig_wait(sigmask_t sigs) void sig_signal(Process *proc, sigmask_t sigs) { cpuflags_t flags; - DISABLE_IRQSAVE(flags); + IRQ_SAVE_DISABLE(flags); /* Set the signals */ proc->sig_recv |= sigs; @@ -175,7 +216,7 @@ void sig_signal(Process *proc, sigmask_t sigs) SCHED_ENQUEUE(proc); } - ENABLE_IRQRESTORE(flags); + IRQ_RESTORE(flags); } #endif /* CONFIG_KERN_SIGNALS */