Merge da SC: macros.h, pool.h, BIT_CHANGE, nome dei processi, etc.
[bertos.git] / kern / proc_p.h
index 5cd44a94f9d2bc9e9fa02690232e844223cd4377..79e97b9230cbe16bd7b9cbbfafc38622cb1e1f34 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>
- * All Rights Reserved.
+ * This file is part of DevLib - See devlib/README for information.
  * -->
  *
  * \brief Internal scheduler structures and definitions for processes.
 
 /*
  * $Log$
+ * 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.
  *
 #include "config.h"
 #include "config_kern.h"
 #include <mware/list.h>
-#include <drv/timer.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 */
 
 #if CONFIG_KERN_SIGNALS
        sigset_t     sig_wait;    /*!< Signals the process is waiting for */
        sigset_t     sig_recv;    /*!< Received signals */
 #endif
 
-#if CONFIG_KERN_TIMER
-       struct Timer proc_timer;  /*!< Process own timer */
-#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 */
 #endif
+
+#if CONFIG_KERN_MONITOR
+       struct ProcMonitor
+       {
+               Node link;
+               const char* name;
+               cpustack_t* stack_base;
+               size_t stack_size;
+       } monitor;
+#endif
+
 } Process;