Still annotating the kernel
[akaros.git] / kern / src / smp.c
1 /*
2  * Copyright (c) 2009 The Regents of the University of California
3  * Barret Rhoden <brho@cs.berkeley.edu>
4  * See LICENSE for details.
5  */
6
7 #include <arch/arch.h>
8 #include <atomic.h>
9 #include <smp.h>
10 #include <ros/error.h>
11 #include <stdio.h>
12 #include <string.h>
13 #include <assert.h>
14 #include <pmap.h>
15 #include <process.h>
16 #include <trap.h>
17
18 struct per_cpu_info per_cpu_info[MAX_NUM_CPUS];
19
20 // tracks number of global waits on smp_calls, must be <= NUM_HANDLER_WRAPPERS
21 atomic_t outstanding_calls = 0;
22
23 /* All non-zero cores call this at the end of their boot process.  They halt,
24  * and wake up when interrupted, do any work on their work queue, then halt
25  * when there is nothing to do.  
26  * TODO: think about resetting the stack pointer at the beginning.
27  */
28 void smp_idle(void)
29 {
30         enable_irq();
31         while (1) {
32                 process_workqueue();
33                 // consider races with work added after we started leaving the last func
34                 cpu_halt();
35         }
36 }