X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=mware%2Fevent.h;h=65ad31c2d3a351c82ba69623b1abd2d84cb038b0;hb=65d5e175830e8c2a6a70b419e28714661e42e4fa;hp=a289db805203beb350e2c55defdfb2660a1504d6;hpb=2c0a02c963204a96304619bc5146d89c435faa2a;p=bertos.git diff --git a/mware/event.h b/mware/event.h old mode 100755 new mode 100644 index a289db80..65ad31c2 --- a/mware/event.h +++ b/mware/event.h @@ -1,9 +1,34 @@ -/*! +/** * \file * * * \brief Events handling @@ -18,6 +43,27 @@ /*#* *#* $Log$ + *#* Revision 1.8 2006/07/19 12:56:27 bernie + *#* Convert to new Doxygen style. + *#* + *#* Revision 1.7 2006/03/20 17:52:22 bernie + *#* Add missing forward declaration. + *#* + *#* Revision 1.6 2006/02/24 01:17:44 bernie + *#* Update for new emulator. + *#* + *#* 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/. *#* @@ -59,17 +105,21 @@ #ifndef KERN_EVENT_H #define KERN_EVENT_H -#include +#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 @@ -81,7 +131,7 @@ typedef struct Event struct { struct Process *sig_proc; /* Process to be signalled */ - sig_t sig_bit; /* Signal to send */ + sigbit_t sig_bit; /* Signal to send */ } Sig; #endif struct @@ -96,11 +146,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) { @@ -109,12 +159,12 @@ 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 */ -INLINE Event event_createSoftInt(Hook func, void* user_data) +/** Same as event_initSoftInt(), but returns the initialized event */ +INLINE Event event_createSoftInt(Hook func, void *user_data) { Event e; e.action = event_hook_softint; @@ -126,12 +176,12 @@ 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 */ -INLINE Event event_createSignal(struct Process* proc, sig_t bit) +/** Same as event_initSignal(), but returns the initialized event */ +INLINE Event event_createSignal(struct Process *proc, sigbit_t bit) { Event e; e.action = event_hook_signal; @@ -142,8 +192,8 @@ INLINE Event event_createSignal(struct Process* proc, sig_t bit) #endif -/*! Trigger an event */ -INLINE void event_do(struct Event* e) +/** Trigger an event */ +INLINE void event_do(struct Event *e) { e->action(e); }