X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;ds=sidebyside;f=bertos%2Fkern%2Firq.c;h=0bdbda854780810c69118343e406b8b2b6c308c6;hb=39e200e1f43474a96888f97e2271728c9605ccbe;hp=9b87d69b25420b03798c027adad670524a1ff65f;hpb=cfa8814ca45e8bae9b36713bc534ecb581834016;p=bertos.git diff --git a/bertos/kern/irq.c b/bertos/kern/irq.c index 9b87d69b..0bdbda85 100644 --- a/bertos/kern/irq.c +++ b/bertos/kern/irq.c @@ -31,19 +31,22 @@ * * \brief Process scheduler (public interface). * - * \version $Id: proc.h 1646 2008-08-17 13:49:48Z bernie $ * \author Bernie Innocenti + * + * Still in development, disable nightly test for now + * notest: avr + * notest: arm */ #include "irq.h" #include #include +#include -#include +#include "cfg/cfg_proc.h" #include // FIXME: move POSIX stuff to irq_posix.h - MOD_DEFINE(irq) // FIXME @@ -52,28 +55,7 @@ static void (*irq_handlers[100])(void); /* signal handler */ void irq_entry(int signum) { - Process * const old_process = CurrentProcess; - irq_handlers[signum](); - -#if CONFIG_KERN_PREEMPT - ASSERT2(CurrentProcess, "no idle proc?"); - - if (old_process != CurrentProcess) - { - TRACEMSG("switching from %p:%s to %p:%s", - old_process, old_process ? old_process->monitor.name : "---", - CurrentProcess, CurrentProcess->monitor.name); - - if (old_process) - swapcontext(&old_process->context, &CurrentProcess->context); - else - setcontext(&CurrentProcess->context); - - // not reached - } - //TRACEMSG("keeping %p:%s", CurrentProcess, CurrentProcess->monitor.name); -#endif // CONFIG_KERN_PREEMPT } void irq_register(int irq, void (*callback)(void)) @@ -84,6 +66,7 @@ void irq_register(int irq, void (*callback)(void)) void irq_init(void) { struct sigaction act; + act.sa_handler = irq_entry; sigemptyset(&act.sa_mask); //sigaddset(&act.sa_mask, irq);