X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=kern%2Fproc_p.h;h=8fbb0ed0a723d8ddd5a440c09f8fb519f6c795a6;hb=2535cb94ec2183791128f8bbd109ca69a960cf78;hp=746cb0509873298277d82c81954067b0e6a35b06;hpb=23c24a8842abea3355937e9f67c17f4f1f1405a7;p=bertos.git diff --git a/kern/proc_p.h b/kern/proc_p.h old mode 100755 new mode 100644 index 746cb050..8fbb0ed0 --- a/kern/proc_p.h +++ b/kern/proc_p.h @@ -1,9 +1,34 @@ -/*! +/** * \file * * * \brief Internal scheduler structures and definitions for processes. @@ -13,86 +38,34 @@ * \author Bernardo Innocenti */ -/*#* - *#* $Log$ - *#* 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 - *#* - *#* 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 +#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_t user_data; /*!< Custom data passed to the process */ + Node link; /**< Link Process into scheduler lists */ + cpustack_t *stack; /**< Per-process SP */ + iptr_t user_data; /**< Custom data passed to the process */ #if CONFIG_KERN_SIGNALS - sigmask_t sig_wait; /*!< Signals the process is waiting for */ - sigmask_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(). */ + int forbid_cnt; /**< Nesting count for proc_forbid()/proc_permit(). */ #endif #if CONFIG_KERN_HEAP - uint16_t flags; /*!< Flags */ - cpustack_t *stack_base; /*!< Base of process stack */ - size_t stack_size; /*!< Size of process stack */ + uint16_t flags; /**< Flags */ + cpustack_t *stack_base; /**< Base of process stack */ + size_t stack_size; /**< Size of process stack */ #endif #if CONFIG_KERN_MONITOR @@ -108,38 +81,38 @@ typedef struct Process } Process; -/*! +/** * \name Flags for Process.flags. * \{ */ -#define PF_FREESTACK BV(0) /*!< Free the stack when process dies */ +#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 */ + /** Initialize the monitor */ void monitor_init(void); - /*! Register a process into the monitor */ + /** 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 */ + /** Unregister a process from the monitor */ void monitor_remove(Process *proc); - /*! Rename a process */ + /** Rename a process */ void monitor_rename(Process *proc, const char* name); #endif /* CONFIG_KERN_MONITOR */