X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=bertos%2Fkern%2Fproc_test.c;h=38a6b16c66fe5083b9b41e1ce8c2ab95179a354a;hb=87302355709b6d5ac0592024b84207ba86baa82e;hp=96c4a9bdf7c88eb3a20e5f26b3f55f28e57ac1e6;hpb=4108302ecc1a63518e91b3ee0ade5d50d89453b6;p=bertos.git diff --git a/bertos/kern/proc_test.c b/bertos/kern/proc_test.c index 96c4a9bd..38a6b16c 100644 --- a/bertos/kern/proc_test.c +++ b/bertos/kern/proc_test.c @@ -39,58 +39,90 @@ #include #include +#include -#warning FIXME: Review this test and refactor for all target. - -/** +/* * Proc scheduling test subthread 1 */ -static void proc_test_thread1(void) +static void proc_test1(void) { for (int i = 0; i < 30; ++i) { - kputs(">task 1\n"); + kputs("> test1\n"); timer_delay(50); proc_switch(); } } -/** +/* * Proc scheduling test subthread 2 */ -static void proc_test_thread2(void) +static void proc_test2(void) { for (int i = 0; i < 30; ++i) { - kputs(">task 2\n"); + kputs("> test2\n"); timer_delay(75); proc_switch(); } } -static cpustack_t proc_test_stack1[CONFIG_PROC_DEFSTACKSIZE / sizeof(cpustack_t)]; -static cpustack_t proc_test_stack2[CONFIG_PROC_DEFSTACKSIZE / sizeof(cpustack_t)]; +static cpustack_t proc_test1_stack[CONFIG_PROC_DEFSTACKSIZE / sizeof(cpustack_t)]; +static cpustack_t proc_test2_stack[CONFIG_PROC_DEFSTACKSIZE / sizeof(cpustack_t)]; + + +int proc_testSetup(void) +{ + kdbg_init(); + proc_init(); + IRQ_ENABLE; + timer_init(); + return 0; +} + +int proc_testTearDown(void) +{ + return 0; +} /** * Process scheduling test */ -void proc_test(void) +int proc_testRun(void) { - proc_new(proc_test_thread1, NULL, sizeof(proc_test_stack1), proc_test_stack1); - proc_new(proc_test_thread2, NULL, sizeof(proc_test_stack2), proc_test_stack2); - kputs("Created tasks\n"); + proc_new(proc_test1, NULL, sizeof(proc_test1_stack), proc_test1_stack); + proc_new(proc_test2, NULL, sizeof(proc_test2_stack), proc_test2_stack); + kputs("Processes created\n"); - kputs("stack1:\n"); -// #warning FIXME - kdump(proc_test_stack1+sizeof(proc_test_stack1)-64, 64); - kputs("stack2:\n"); -// #warning FIXME - kdump(proc_test_stack2+sizeof(proc_test_stack1)-64, 64); + //kputs("stack1:\n"); + //kdump(proc_test_stack1 + sizeof(proc_test_stack1) - 64, 64); + + //kputs("stack2:\n"); + //kdump(proc_test_stack2 + sizeof(proc_test_stack2) - 64, 64); for (int i = 0; i < 30; ++i) { - kputs(">main task\n"); + kputs("> main\n"); timer_delay(93); proc_switch(); } + return 0; } +#warning Fix test to comply to new policy. +#if 0 +/* + * FIXME: to be compiled as a single file + * the kernel module needs the assembly switch function + * and the idle() that lay in a emulator cpp file. + * How can we fix this? + */ +#include TEST_ONLY(drv/kdebug.c) +#include TEST_ONLY(kern/coop.c) +#include TEST_ONLY(kern/proc.c) +#include TEST_ONLY(drv/timer.c) +#include TEST_ONLY(mware/formatwr.c) +#include TEST_ONLY(mware/hex.c) +#include TEST_ONLY(os/hptime.c) + +TEST_MAIN(proc); +#endif