X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=kern%2Fproc_p.h;h=5b0bc99a28235bcba7300de15ecec9eed3ef2c50;hb=0168eb0bee0da568cd3ea8f8dfffa9343175efd9;hp=5daf0dd0d47568c7c610c308fc7152a45faa5e24;hpb=99ebec567d8485806f6ebe23b8c8a1b825d0cf4d;p=bertos.git diff --git a/kern/proc_p.h b/kern/proc_p.h index 5daf0dd0..5b0bc99a 100755 --- a/kern/proc_p.h +++ b/kern/proc_p.h @@ -1,8 +1,8 @@ /*! * \file * * @@ -13,39 +13,51 @@ * \author Bernardo Innocenti */ -/* - * $Log$ - * Revision 1.4 2004/07/30 14:24:16 rasky - * Task switching con salvataggio perfetto stato di interrupt (SR) - * Kernel monitor per dump informazioni su stack dei processi - * - * Revision 1.3 2004/07/14 14:18:09 rasky - * Merge da SC: Rimosso timer dentro il task, che è uno spreco di memoria per troppi task - * - * Revision 1.2 2004/06/03 11:27:09 bernie - * Add dual-license information. - * - * Revision 1.1 2004/05/23 17:27:00 bernie - * Import kern/ subdirectory. - * - * Revision 1.3 2004/05/14 12:52:13 rasky - * Importato supporto kernel per AVR da Stefano - * - * Revision 1.2 2004/04/28 16:13:49 rasky - * proc_schedule() is now semi-private (used only within the kernel) - * - * Revision 1.1 2004/04/26 18:02:40 rasky - * Importato microkernel - * - * Revision 1.1 2004/04/04 17:40:26 aleph - * Add multithreading kernel - * - */ - +/*#* + *#* $Log$ + *#* Revision 1.8 2004/10/03 20:39:28 bernie + *#* Import changes from sc/firmware. + *#* + *#* Revision 1.7 2004/08/25 14:12:09 rasky + *#* Aggiornato il comment block dei log RCS + *#* + *#* Revision 1.6 2004/08/24 16:05:15 bernie + *#* Add missing headers; Reformat. + *#* + *#* Revision 1.5 2004/08/14 19:37:57 rasky + *#* Merge da SC: macros.h, pool.h, BIT_CHANGE, nome dei processi, etc. + *#* + *#* Revision 1.4 2004/07/30 14:24:16 rasky + *#* Task switching con salvataggio perfetto stato di interrupt (SR) + *#* Kernel monitor per dump informazioni su stack dei processi + *#* + *#* Revision 1.3 2004/07/14 14:18:09 rasky + *#* Merge da SC: Rimosso timer dentro il task, che è uno spreco di memoria per troppi task + *#* + *#* Revision 1.2 2004/06/03 11:27:09 bernie + *#* Add dual-license information. + *#* + *#* Revision 1.1 2004/05/23 17:27:00 bernie + *#* Import kern/ subdirectory. + *#* + *#* Revision 1.3 2004/05/14 12:52:13 rasky + *#* Importato supporto kernel per AVR da Stefano + *#* + *#* Revision 1.2 2004/04/28 16:13:49 rasky + *#* proc_schedule() is now semi-private (used only within the kernel) + *#* + *#* Revision 1.1 2004/04/26 18:02:40 rasky + *#* Importato microkernel + *#* + *#* Revision 1.1 2004/04/04 17:40:26 aleph + *#* Add multithreading kernel + *#* + *#*/ #ifndef KERN_PROC_P_H #define KERN_PROC_P_H #include "compiler.h" +#include "cpu.h" /* for cpu_stack_t */ #include "config.h" #include "config_kern.h" #include @@ -54,6 +66,7 @@ typedef struct Process { Node link; /*!< Link Process into scheduler lists */ cpustack_t *stack; /*!< Per-process SP */ + IPTR user_data; /*!< Custom data passed to the process */ #if CONFIG_KERN_SIGNALS sigset_t sig_wait; /*!< Signals the process is waiting for */ @@ -69,9 +82,10 @@ typedef struct Process #if CONFIG_KERN_MONITOR struct ProcMonitor { - Node link; - cpustack_t* stack_base; - size_t stack_size; + Node link; + const char *name; + cpustack_t *stack_base; + size_t stack_size; } monitor; #endif @@ -101,5 +115,16 @@ extern REGISTER List ProcReadyList; /*! Schedule to another process *without* adding the current to the ready list */ void proc_schedule(void); +#if CONFIG_KERN_MONITOR + /*! Initialize the monitor */ + void monitor_init(void); + + /*! Register a process into the monitor */ + void monitor_add(Process *proc, const char *name, cpustack_t *stack, size_t stacksize); + + /*! Deregister a process from the monitor */ + void monitor_remove(Process *proc); +#endif /* CONFIG_KERN_MONITOR */ + #endif /* KERN_PROC_P_H */