X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;ds=sidebyside;f=mware%2Fevent.h;h=4270e94698100af607168b8e6a1a0590155bc0c7;hb=faf2f6bfd5933ff75e6cc01e3d48f9277f731d8f;hp=23c1e9b8daf9e55aa76e028cc6880e3034bff5c9;hpb=56068931f6cfe45f14fd183dfe549692719701bc;p=bertos.git diff --git a/mware/event.h b/mware/event.h old mode 100755 new mode 100644 index 23c1e9b8..4270e946 --- a/mware/event.h +++ b/mware/event.h @@ -1,9 +1,34 @@ -/*! +/** * \file * * * \brief Events handling @@ -16,58 +41,6 @@ * \author Bernardo Innocenti */ -/*#* - *#* $Log$ - *#* Revision 1.5 2006/02/24 00:26:21 bernie - *#* Fix header name. - *#* - *#* Revision 1.4 2006/02/10 12:24:42 bernie - *#* Fix standalone build. - *#* - *#* 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 @@ -77,12 +50,15 @@ #if CONFIG_KERNEL #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 @@ -109,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) { @@ -122,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; @@ -139,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; @@ -155,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);