X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=mware%2Fevent.h;h=4270e94698100af607168b8e6a1a0590155bc0c7;hb=45add65abd59bd79f528501c85f3e5891a9c2c29;hp=baa6493e805ac1d1731c32377304f55931787c83;hpb=218e4428411094ac785e00a719c7d84337dfdd1c;p=bertos.git diff --git a/mware/event.h b/mware/event.h old mode 100755 new mode 100644 index baa6493e..4270e946 --- a/mware/event.h +++ b/mware/event.h @@ -1,9 +1,34 @@ -/*! +/** * \file * * * \brief Events handling @@ -16,66 +41,24 @@ * \author Bernardo Innocenti */ -/*#* - *#* $Log$ - *#* Revision 1.3 2006/01/16 03:27:49 bernie - *#* Rename sig_t to sigbit_t to avoid clash with POSIX. - *#* - *#* Revision 1.2 2005/11/27 03:02:55 bernie - *#* Convert to appconfig.h. - *#* - *#* Revision 1.1 2005/11/27 01:39:48 bernie - *#* Move event.[ch] from kern/ to mware/. - *#* - *#* Revision 1.11 2005/04/11 19:10:28 bernie - *#* Include top-level headers from cfg/ subdir. - *#* - *#* Revision 1.10 2005/01/24 04:22:02 bernie - *#* Update copyright information. - *#* - *#* Revision 1.9 2005/01/24 04:19:55 bernie - *#* Remove obsolete names. - *#* - *#* Revision 1.8 2005/01/24 04:19:05 bernie - *#* Function pointer based event dispatching. - *#* - *#* Revision 1.7 2004/08/25 14:12:09 rasky - *#* Aggiornato il comment block dei log RCS - *#* - *#* Revision 1.6 2004/08/14 19:37:57 rasky - *#* Merge da SC: macros.h, pool.h, BIT_CHANGE, nome dei processi, etc. - *#* - *#* Revision 1.5 2004/07/30 14:30:27 rasky - *#* Resa la sig_signal interrupt safe (con il nuovo scheduler IRQ-safe) - *#* Rimossa event_doIntr (ora inutile) e semplificata la logica delle macro con funzioni inline - *#* - *#* Revision 1.4 2004/06/07 15:58:00 aleph - *#* Add function prototypes - *#* - *#* Revision 1.3 2004/06/06 18:25:44 bernie - *#* Rename event macros to look like regular functions. - *#* - *#* 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. - *#* - *#*/ #ifndef KERN_EVENT_H #define KERN_EVENT_H +#include #include #if CONFIG_KERNEL - #include + #include #if defined(CONFIG_KERN_SIGNALS) && CONFIG_KERN_SIGNALS - #include "signal.h" + #include #endif + + /* Forward decl */ + struct Process; #endif -//! User defined callback type +/// User defined callback type typedef void (*Hook)(void *); typedef struct Event @@ -102,11 +85,11 @@ void event_hook_ignore(Event *event); void event_hook_signal(Event *event); void event_hook_softint(Event *event); -/*! Initialize the event \a e as a no-op */ +/** Initialize the event \a e as a no-op */ #define event_initNone(e) \ ((e)->action = event_hook_ignore) -/*! Same as event_initNone(), but returns the initialized event */ +/** Same as event_initNone(), but returns the initialized event */ INLINE Event event_createNone(void); INLINE Event event_createNone(void) { @@ -115,11 +98,11 @@ INLINE Event event_createNone(void) return e; } -/*! Initialize the event \a e with a software interrupt (call function \a f, with parameter \a u) */ +/** Initialize the event \a e with a software interrupt (call function \a f, with parameter \a u) */ #define event_initSoftInt(e,f,u) \ ((e)->action = event_hook_softint,(e)->Ev.Int.func = (f), (e)->Ev.Int.user_data = (u)) -/*! Same as event_initSoftInt(), but returns the initialized event */ +/** Same as event_initSoftInt(), but returns the initialized event */ INLINE Event event_createSoftInt(Hook func, void *user_data) { Event e; @@ -132,11 +115,11 @@ INLINE Event event_createSoftInt(Hook func, void *user_data) #if defined(CONFIG_KERN_SIGNALS) && CONFIG_KERN_SIGNALS -/*! Initialize the event \a e with a signal (send signal \a s to process \a p) */ +/** Initialize the event \a e with a signal (send signal \a s to process \a p) */ #define event_initSignal(e,p,s) \ ((e)->action = event_hook_signal,(e)->Ev.Sig.sig_proc = (p), (e)->Ev.Sig.sig_bit = (s)) -/*! Same as event_initSignal(), but returns the initialized event */ +/** Same as event_initSignal(), but returns the initialized event */ INLINE Event event_createSignal(struct Process *proc, sigbit_t bit) { Event e; @@ -148,7 +131,7 @@ INLINE Event event_createSignal(struct Process *proc, sigbit_t bit) #endif -/*! Trigger an event */ +/** Trigger an event */ INLINE void event_do(struct Event *e) { e->action(e);