X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=bertos%2Fkern%2Fproc_test.c;h=e06e984f660aef3581416d1c60758e47d75fefe9;hb=d5642a0041cbc6b737a26d817b128073c0ef6202;hp=56f784d5b012f9e4b6f4ac48d385ee22c1856a05;hpb=45ad55306051d46d07a42672556a88c5d1c795cd;p=bertos.git diff --git a/bertos/kern/proc_test.c b/bertos/kern/proc_test.c index 56f784d5..e06e984f 100644 --- a/bertos/kern/proc_test.c +++ b/bertos/kern/proc_test.c @@ -26,18 +26,20 @@ * invalidate any other reasons why the executable file might be covered by * the GNU General Public License. * - * Copyright 2005 Develer S.r.l. (http://www.develer.com/) + * Copyright 2008 Develer S.r.l. (http://www.develer.com/) * --> * * * \brief Test kernel process. * * \version $Id$ - * * \author Daniele Basile */ #include +#include +#include + #include #include @@ -50,7 +52,7 @@ static void proc_test1(void) { kputs("> test1\n"); timer_delay(50); - proc_switch(); + proc_yield(); } } @@ -63,27 +65,12 @@ static void proc_test2(void) { kputs("> test2\n"); timer_delay(75); - proc_switch(); } } -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; -} +static cpu_stack_t proc_test1_stack[CONFIG_KERN_MINSTACKSIZE / sizeof(cpu_stack_t)]; +static cpu_stack_t proc_test2_stack[CONFIG_KERN_MINSTACKSIZE / sizeof(cpu_stack_t)]; -int proc_testTearDown(void) -{ - return 0; -} /** * Process scheduling test @@ -94,34 +81,55 @@ int proc_testRun(void) proc_new(proc_test2, NULL, sizeof(proc_test2_stack), proc_test2_stack); kputs("Processes created\n"); - //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\n"); timer_delay(93); - proc_switch(); + monitor_report(); + proc_yield(); } 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/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); +#if UNIT_TEST + +int proc_testSetup(void) +{ + kdbg_init(); + + #if CONFIG_KERN_PREEMPT + irq_init(); + #endif + + timer_init(); + + proc_init(); + return 0; +} + +int proc_testTearDown(void) +{ + return 0; +} + +#include +#include +#include +#include +#include +#if CONFIG_KERN_PREEMPT + #include + #include +#else + #include + // FIXME: we need to link with the switch asm code too! #endif +#include +#include +#include +#include +#include + +TEST_MAIN(proc); + +#endif // _TEST