X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=kern%2Fproc_p.h;h=7ac481760e123f3c96208581bb8070ebcbda5b44;hb=22ea75fdc24002bc8b2a6fea2be1080cc3b39b1c;hp=30189b7f34b6497b1de387811d5648c5b433dfcc;hpb=277b540c0764dd376dcf583acdc97a2b2fd3d8e6;p=bertos.git diff --git a/kern/proc_p.h b/kern/proc_p.h index 30189b7f..7ac48176 100755 --- a/kern/proc_p.h +++ b/kern/proc_p.h @@ -3,7 +3,7 @@ * * * \brief Internal scheduler structures and definitions for processes. @@ -15,6 +15,30 @@ /*#* *#* $Log$ + *#* Revision 1.15 2005/11/27 23:36:19 bernie + *#* Use appconfig.h instead of cfg/config.h. + *#* + *#* Revision 1.14 2005/11/04 16:20:02 bernie + *#* Fix reference to README.devlib in header. + *#* + *#* Revision 1.13 2005/04/11 19:10:28 bernie + *#* Include top-level headers from cfg/ subdir. + *#* + *#* Revision 1.12 2004/12/08 08:57:35 bernie + *#* Rename sigset_t to sigmask_t. + *#* + *#* Revision 1.11 2004/11/16 22:37:14 bernie + *#* Replace IPTR with iptr_t. + *#* + *#* Revision 1.10 2004/10/19 11:47:07 bernie + *#* Add missing #endif. + *#* + *#* Revision 1.9 2004/10/19 08:55:31 bernie + *#* Define forbid_cnt. + *#* + *#* 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 *#* @@ -53,21 +77,25 @@ #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 +#include /* for cpu_stack_t */ #include +#include +#include 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 */ + iptr_t user_data; /*!< Custom data passed to the process */ #if CONFIG_KERN_SIGNALS - sigset_t sig_wait; /*!< Signals the process is waiting for */ - sigset_t sig_recv; /*!< Received signals */ + sigmask_t sig_wait; /*!< Signals the process is waiting for */ + sigmask_t sig_recv; /*!< Received signals */ +#endif + +#if CONFIG_KERN_PREEMPTIVE + int forbid_cnt; /*!< Nesting count for proc_forbid()/proc_permit(). */ #endif #if CONFIG_KERN_HEAP @@ -90,27 +118,39 @@ typedef struct Process /*! - * \name Flags for Process.flags + * \name Flags for Process.flags. * \{ */ #define PF_FREESTACK BV(0) /*!< Free the stack when process dies */ /*\}*/ -/*! Track running processes */ +/*! Track running processes. */ extern REGISTER Process *CurrentProcess; -/*! Track ready processes */ +/*! Track ready processes. */ extern REGISTER List ProcReadyList; -/*! - * Enqueue a task in the ready list - */ +/*! Enqueue a task in the ready list. */ #define SCHED_ENQUEUE(proc) ADDTAIL(&ProcReadyList, &(proc)->link) -/*! Schedule to another process *without* adding the current to the ready list */ +/*! 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); + + /*! Unregister a process from the monitor */ + void monitor_remove(Process *proc); + + /*! Rename a process */ + void monitor_rename(Process *proc, const char* name); +#endif /* CONFIG_KERN_MONITOR */ + #endif /* KERN_PROC_P_H */