X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=kern%2Fproc.h;h=26cbc57998965d2d7ae90397b908d27ccb0f8139;hb=f78e7b82ce293dabb9695e3656c244b955fbb9d2;hp=d5866993a129372c105c3c267f4823355fa808c2;hpb=1cc167e20f21d2e81527ca47ccd4a21a6198f86f;p=bertos.git diff --git a/kern/proc.h b/kern/proc.h index d5866993..26cbc579 100755 --- a/kern/proc.h +++ b/kern/proc.h @@ -1,9 +1,9 @@ -/** +/*! * \file * * * \brief Process scheduler (public interface). @@ -15,6 +15,15 @@ /* * $Log$ + * Revision 1.4 2004/08/14 19:37:57 rasky + * Merge da SC: macros.h, pool.h, BIT_CHANGE, nome dei processi, etc. + * + * Revision 1.3 2004/07/30 14:31:23 rasky + * Hunk sfuggito al commit precedente (aggiornamento kernel) + * + * 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. * @@ -32,11 +41,25 @@ struct Process; /* Task scheduling services */ void proc_init(void); -struct Process *proc_new(void (*entry)(void), size_t stacksize, cpustack_t *stack); +struct Process *proc_new_with_name(const char* name, void (*entry)(void), IPTR data, size_t stacksize, cpustack_t *stack); + +#if !CONFIG_KERN_MONITOR + #define proc_new(entry,data,size,stack) proc_new_with_name(NULL,(entry),(data),(size),(stack)) +#else + #define proc_new(entry,data,size,stack) proc_new_with_name(#entry,(entry),(data),(size),(stack)) +#endif + void proc_exit(void); void proc_switch(void); void proc_test(void); struct Process* proc_current(void); +IPTR proc_current_user_data(void); + + +#if CONFIG_KERN_MONITOR +size_t monitor_check_stack(cpustack_t* stack_base, size_t stack_size); +void monitor_debug_stacks(void); +#endif #if CONFIG_KERN_PREEMPTIVE #define FORBID proc_forbid()