X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=kern%2Fsignal.c;h=88ab1095915cacc74070f7b18e13828828fe4141;hb=380bc36d2969fd9d730fee770ce16d7f859ec211;hp=0af4f3992510ac07861bf7af9622026c0391c859;hpb=d6f35150fc5cdd120673ee4e245f28bac51e1d7a;p=bertos.git diff --git a/kern/signal.c b/kern/signal.c index 0af4f399..88ab1095 100755 --- a/kern/signal.c +++ b/kern/signal.c @@ -64,31 +64,38 @@ * \author Bernardo Innocenti */ -/* - * $Log$ - * Revision 1.5 2004/08/04 21:50:33 bernie - * Add extensive documentation. - * - * Revision 1.4 2004/07/30 14:30:27 rasky - * Resa la sig_signal interrupt safe (con il nuovo scheduler IRQ-safe) - * Rimossa event_doIntr (ora inutile) e semplificata la logica delle macro con funzioni inline - * - * Revision 1.3 2004/07/30 14:24:16 rasky - * Task switching con salvataggio perfetto stato di interrupt (SR) - * Kernel monitor per dump informazioni su stack dei processi - * - * Revision 1.2 2004/06/03 11:27:09 bernie - * Add dual-license information. - * - * Revision 1.1 2004/05/23 17:27:00 bernie - * Import kern/ subdirectory. - * - */ +/*#* + *#* $Log$ + *#* Revision 1.7 2004/08/25 14:12:09 rasky + *#* Aggiornato il comment block dei log RCS + *#* + *#* Revision 1.6 2004/08/14 19:37:57 rasky + *#* Merge da SC: macros.h, pool.h, BIT_CHANGE, nome dei processi, etc. + *#* + *#* Revision 1.5 2004/08/04 21:50:33 bernie + *#* Add extensive documentation. + *#* + *#* Revision 1.4 2004/07/30 14:30:27 rasky + *#* Resa la sig_signal interrupt safe (con il nuovo scheduler IRQ-safe) + *#* Rimossa event_doIntr (ora inutile) e semplificata la logica delle macro con funzioni inline + *#* + *#* Revision 1.3 2004/07/30 14:24:16 rasky + *#* Task switching con salvataggio perfetto stato di interrupt (SR) + *#* Kernel monitor per dump informazioni su stack dei processi + *#* + *#* Revision 1.2 2004/06/03 11:27:09 bernie + *#* Add dual-license information. + *#* + *#* Revision 1.1 2004/05/23 17:27:00 bernie + *#* Import kern/ subdirectory. + *#* + *#*/ #include "signal.h" #include "proc.h" #include "proc_p.h" #include "hw.h" +#include // FIXME #if CONFIG_KERN_SIGNALS @@ -127,6 +134,10 @@ sigset_t sig_wait(sigset_t sigs) /* go to sleep and proc_schedule() another process */ CurrentProcess->sig_wait = sigs; proc_schedule(); + + /* When we come back here, a signal must be arrived */ + ASSERT(!CurrentProcess->sig_wait); + ASSERT(CurrentProcess->sig_recv); } /* Signals found: clear them and return */