monitor: Correct preemptive locking
authorbernie <bernie@38d2e660-2303-0410-9eaa-f027e97ec537>
Thu, 7 Aug 2008 11:05:57 +0000 (11:05 +0000)
committerbernie <bernie@38d2e660-2303-0410-9eaa-f027e97ec537>
Thu, 7 Aug 2008 11:05:57 +0000 (11:05 +0000)
git-svn-id: https://src.develer.com/svnoss/bertos/trunk@1564 38d2e660-2303-0410-9eaa-f027e97ec537

bertos/kern/monitor.c
bertos/kern/proc_p.h
bertos/kern/proc_test.c

index 362bb82dd2a077f12d1e97f8423bb7c3ec052e5d..9dcc38b0b666543e116f75909f7d4a0817b909dd 100644 (file)
@@ -49,6 +49,7 @@
 #include <cfg/debug.h>
 
 
+/* Access to this list must be protected against the scheduler */
 static List MonitorProcs;
 
 
@@ -62,13 +63,13 @@ void monitor_add(Process *proc, const char *name)
 {
        proc->monitor.name = name;
 
-       ADDTAIL(&MonitorProcs, &proc->monitor.link);
+       PROC_ATOMIC(ADDTAIL(&MonitorProcs, &proc->monitor.link));
 }
 
 
 void monitor_remove(Process *proc)
 {
-       REMOVE(&proc->monitor.link);
+       PROC_ATOMIC(REMOVE(&proc->monitor.link));
 }
 
 void monitor_rename(Process *proc, const char *name)
@@ -76,10 +77,6 @@ void monitor_rename(Process *proc, const char *name)
        proc->monitor.name = name;
 }
 
-/* TODO: use containerof() */
-#define MONITOR_NODE_TO_PROCESS(node) \
-       (struct Process *)((intptr_t)(node) - offsetof(struct Process, monitor.link))
-
 size_t monitor_checkStack(cpustack_t *stack_base, size_t stack_size)
 {
        cpustack_t *beg;
@@ -116,49 +113,47 @@ size_t monitor_checkStack(cpustack_t *stack_base, size_t stack_size)
 
 void monitor_report(void)
 {
-       struct Process* p;
+       Node *node;
        int i;
 
-       if (LIST_EMPTY(&MonitorProcs))
-       {
-               kputs("No stacks registered in the monitor\n");
-               return;
-       }
-
        kprintf("%-24s%-8s%-8s%-8s%-8s\n", "Process name", "TCB", "SPbase", "SPsize", "SPfree");
-       for (i=0;i<56;i++)
+       for (i = 0; i<56; i++)
                kputchar('-');
        kputchar('\n');
 
-       for (p = MONITOR_NODE_TO_PROCESS(LIST_HEAD(&MonitorProcs));
-                p->monitor.link.succ;
-                p = MONITOR_NODE_TO_PROCESS(p->monitor.link.succ))
+       proc_forbid();
+       FOREACH_NODE(node, &MonitorProcs)
        {
+               Process *p = containerof(node, Process, monitor.link);
                size_t free = monitor_checkStack(p->stack_base, p->stack_size);
                kprintf("%-24s%-8p%-8p%-8lu%-8lu\n",
                        p->monitor.name, p, p->stack_base, p->stack_size, free);
        }
+       proc_permit();
 }
 
 
 static void NORETURN monitor(void)
 {
-       struct Process *p;
+       Process *p;
+       Node *node;
 
-       while (1)
+       for (;;)
        {
-               for (p = MONITOR_NODE_TO_PROCESS(LIST_HEAD(&MonitorProcs));
-                       p->monitor.link.succ;
-                       p = MONITOR_NODE_TO_PROCESS(p->monitor.link.succ))
+               proc_forbid();
+               FOREACH_NODE(node, &MonitorProcs)
                {
+                       Process *p = containerof(node, Process, monitor.link);
                        size_t free = monitor_checkStack(p->stack_base, p->stack_size);
 
                        if (free < 0x20)
-                               kprintf("MONITOR: WARNING: Free stack for process '%s' is only %u chars\n",
+                               kprintf("MONITOR: Free stack of process '%s' is only %u chars\n",
                                                p->monitor.name, (unsigned int)free);
-
-                       timer_delay(500);
                }
+               proc_permit();
+
+               /* Give some rest to the system */
+               timer_delay(500);
        }
 }
 
index 7dad780d4fb03098ce3f388afcee3750acec50bb..d69794103bdd943530c525cce2fe0dbf13eb0c1f 100644 (file)
@@ -98,7 +98,11 @@ extern REGISTER Process      *CurrentProcess;
 extern REGISTER List     ProcReadyList;
 
 
-/** Enqueue a task in the ready list. */
+/**
+ * Enqueue a task in the ready list.
+ *
+ * \note This is *NOT* protected against 
+ */
 #define SCHED_ENQUEUE(proc)  ADDTAIL(&ProcReadyList, &(proc)->link)
 
 /** Schedule to another process *without* adding the current to the ready list. */
index d59bc749ad6d1517b26bf827ff079598d7337a20..96c4a9bdf7c88eb3a20e5f26b3f55f28e57ac1e6 100644 (file)
@@ -45,9 +45,9 @@
 /**
  * Proc scheduling test subthread 1
  */
-static void NORETURN proc_test_thread1(void)
+static void proc_test_thread1(void)
 {
-       for (;;)
+       for (int i = 0; i < 30; ++i)
        {
                kputs(">task 1\n");
                timer_delay(50);
@@ -58,9 +58,9 @@ static void NORETURN proc_test_thread1(void)
 /**
  * Proc scheduling test subthread 2
  */
-static void NORETURN proc_test_thread2(void)
+static void proc_test_thread2(void)
 {
-       for (;;)
+       for (int i = 0; i < 30; ++i)
        {
                kputs(">task 2\n");
                timer_delay(75);
@@ -72,9 +72,9 @@ static cpustack_t proc_test_stack1[CONFIG_PROC_DEFSTACKSIZE / sizeof(cpustack_t)
 static cpustack_t proc_test_stack2[CONFIG_PROC_DEFSTACKSIZE / sizeof(cpustack_t)];
 
 /**
- * Proc scheduling test
+ * Process scheduling test
  */
-void NORETURN proc_test(void)
+void proc_test(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);
@@ -87,12 +87,10 @@ void NORETURN proc_test(void)
 //     #warning FIXME
        kdump(proc_test_stack2+sizeof(proc_test_stack1)-64, 64);
 
-       for (;;)
+       for (int i = 0; i < 30; ++i)
        {
                kputs(">main task\n");
                timer_delay(93);
                proc_switch();
        }
-
-       ASSERT(false);
 }