X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=kern%2Fsignal.c;h=692cd44bf679b0f8c6b772f1a33152ce2532d243;hb=d026292ceba279d56f2540a02cff974e7ca9e5ae;hp=0243987be76ac237b4b0c9ce8704b294f9584498;hpb=294f744f2676575fa3704a2fc321eac0b894e1da;p=bertos.git diff --git a/kern/signal.c b/kern/signal.c index 0243987b..692cd44b 100755 --- a/kern/signal.c +++ b/kern/signal.c @@ -66,6 +66,12 @@ /*#* *#* $Log$ + *#* 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. + *#* *#* Revision 1.8 2004/09/14 21:06:44 bernie *#* Use debug.h instead of kdebug.h. *#* @@ -100,22 +106,22 @@ #include "hw.h" #include -// FIXME #if CONFIG_KERN_SIGNALS /*! * Check if any of the signals in \a sigs has occurred and clear them. * Return the signals that have occurred. */ -sigset_t sig_check(sigset_t sigs) +sigmask_t sig_check(sigmask_t sigs) { - sigset_t result; + 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; } @@ -124,12 +130,12 @@ sigset_t sig_check(sigset_t sigs) * Sleep until any of the signals in \a sigs occurs. * Return the signal(s) that have awaked the process. */ -sigset_t sig_wait(sigset_t sigs) +sigmask_t sig_wait(sigmask_t sigs) { - sigset_t result; + 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)) @@ -145,7 +151,8 @@ sigset_t sig_wait(sigset_t sigs) /* Signals found: clear them and return */ CurrentProcess->sig_recv &= ~sigs; - ENABLE_IRQRESTORE(flags); + + IRQ_RESTORE(flags); return result; } @@ -156,10 +163,10 @@ sigset_t sig_wait(sigset_t sigs) * * \note This call is interrupt safe. */ -void sig_signal(Process *proc, sigset_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; @@ -172,7 +179,7 @@ void sig_signal(Process *proc, sigset_t sigs) SCHED_ENQUEUE(proc); } - ENABLE_IRQRESTORE(flags); + IRQ_RESTORE(flags); } #endif /* CONFIG_KERN_SIGNALS */