Add TODO item.
[bertos.git] / kern / proc_p.h
index 5b0bc99a28235bcba7300de15ecec9eed3ef2c50..7ac481760e123f3c96208581bb8070ebcbda5b44 100755 (executable)
@@ -3,7 +3,7 @@
  * <!--
  * Copyright 2001, 2004 Develer S.r.l. (http://www.develer.com/)
  * Copyright 1999, 2000, 2001 Bernardo Innocenti <bernie@develer.com>
- * This file is part of DevLib - See devlib/README for information.
+ * This file is part of DevLib - See README.devlib for information.
  * -->
  *
  * \brief Internal scheduler structures and definitions for processes.
 
 /*#*
  *#* $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.
  *#*
 #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 <cfg/compiler.h>
+#include <cfg/cpu.h>        /* for cpu_stack_t */
 #include <mware/list.h>
+#include <config_kern.h>
+#include <appconfig.h>
 
 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
@@ -93,26 +118,24 @@ 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
@@ -122,8 +145,11 @@ void proc_schedule(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 */
+       /*! 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 */