X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=bertos%2Fkern%2Fmonitor.c;h=5759c5334b2418c437bebbd21a8c2479cc7c64e7;hb=e62ca0b357f09804d7d894949df44224c9d74bb7;hp=9dcc38b0b666543e116f75909f7d4a0817b909dd;hpb=4108302ecc1a63518e91b3ee0ade5d50d89453b6;p=bertos.git diff --git a/bertos/kern/monitor.c b/bertos/kern/monitor.c index 9dcc38b0..5759c533 100644 --- a/bertos/kern/monitor.c +++ b/bertos/kern/monitor.c @@ -42,9 +42,10 @@ #if CONFIG_KERN_MONITOR #include "proc_p.h" -#include +#include #include #include +#include /* CPU_STACK_GROWS_UPWARD */ #include #include @@ -77,21 +78,23 @@ void monitor_rename(Process *proc, const char *name) proc->monitor.name = name; } -size_t monitor_checkStack(cpustack_t *stack_base, size_t stack_size) +size_t monitor_checkStack(cpu_stack_t *stack_base, size_t stack_size) { - cpustack_t *beg; - cpustack_t *cur; - cpustack_t *end; + cpu_stack_t *beg; + cpu_stack_t *cur; + cpu_stack_t *end; + int inc; size_t sp_free; + beg = stack_base; - end = stack_base + stack_size / sizeof(cpustack_t) - 1; + end = stack_base + stack_size / sizeof(cpu_stack_t); + inc = +1; if (CPU_STACK_GROWS_UPWARD) { - cur = beg; - beg = end; - end = cur; + SWAP(beg, end); + inc = -1; } cur = beg; @@ -100,13 +103,10 @@ size_t monitor_checkStack(cpustack_t *stack_base, size_t stack_size) if (*cur != CONFIG_KERN_STACKFILLCODE) break; - if (CPU_STACK_GROWS_UPWARD) - cur--; - else - cur++; + cur += inc; } - sp_free = ABS(cur - beg) * sizeof(cpustack_t); + sp_free = ABS(cur - beg) * sizeof(cpu_stack_t); return sp_free; } @@ -116,8 +116,8 @@ void monitor_report(void) Node *node; int i; - kprintf("%-24s%-8s%-8s%-8s%-8s\n", "Process name", "TCB", "SPbase", "SPsize", "SPfree"); - for (i = 0; i<56; i++) + kprintf("%-9s%-9s%-9s%-9s%s\n", "TCB", "SPbase", "SPsize", "SPfree", "Name"); + for (i = 0; i < 56; i++) kputchar('-'); kputchar('\n'); @@ -126,8 +126,8 @@ void monitor_report(void) { 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); + kprintf("%-9p%-9p%-9zu%-9zu%s\n", + p, p->stack_base, p->stack_size, free, p->monitor.name); } proc_permit(); } @@ -135,7 +135,6 @@ void monitor_report(void) static void NORETURN monitor(void) { - Process *p; Node *node; for (;;) @@ -158,7 +157,7 @@ static void NORETURN monitor(void) } -void monitor_start(size_t stacksize, cpustack_t *stack) +void monitor_start(size_t stacksize, cpu_stack_t *stack) { proc_new(monitor, NULL, stacksize, stack); }