add yield-os
This commit is contained in:
parent
86c5532674
commit
6f4a47afb9
2 changed files with 34 additions and 0 deletions
3
kernels/yield-os/Makefile
Normal file
3
kernels/yield-os/Makefile
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
NAME = yield-os
|
||||||
|
SRCS = yield-os.c
|
||||||
|
include $(AM_HOME)/Makefile
|
31
kernels/yield-os/yield-os.c
Normal file
31
kernels/yield-os/yield-os.c
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
#include <am.h>
|
||||||
|
#include <klib-macros.h>
|
||||||
|
|
||||||
|
#define STACK_SIZE (4096 * 8)
|
||||||
|
typedef union {
|
||||||
|
uint8_t stack[STACK_SIZE];
|
||||||
|
struct { Context *cp; };
|
||||||
|
} PCB;
|
||||||
|
static PCB pcb[2], pcb_boot, *current = &pcb_boot;
|
||||||
|
|
||||||
|
static void f(void *arg) {
|
||||||
|
while (1) {
|
||||||
|
putch("?AB"[(uintptr_t)arg > 2 ? 0 : (uintptr_t)arg]);
|
||||||
|
for (int volatile i = 0; i < 100000; i++) ;
|
||||||
|
yield();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static Context *schedule(Event ev, Context *prev) {
|
||||||
|
current->cp = prev;
|
||||||
|
current = (current == &pcb[0] ? &pcb[1] : &pcb[0]);
|
||||||
|
return current->cp;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
cte_init(schedule);
|
||||||
|
pcb[0].cp = kcontext((Area) { pcb[0].stack, &pcb[0] + 1 }, f, (void *)1L);
|
||||||
|
pcb[1].cp = kcontext((Area) { pcb[1].stack, &pcb[1] + 1 }, f, (void *)2L);
|
||||||
|
yield();
|
||||||
|
panic("Should not reach here!");
|
||||||
|
}
|
Loading…
Reference in a new issue