summaryrefslogtreecommitdiff
path: root/fw/fe310/eos/event.h
diff options
context:
space:
mode:
Diffstat (limited to 'fw/fe310/eos/event.h')
-rw-r--r--fw/fe310/eos/event.h28
1 files changed, 13 insertions, 15 deletions
diff --git a/fw/fe310/eos/event.h b/fw/fe310/eos/event.h
index bdc1af1..df2f546 100644
--- a/fw/fe310/eos/event.h
+++ b/fw/fe310/eos/event.h
@@ -1,28 +1,26 @@
#include <stdint.h>
#include "evt_def.h"
+#include "msgq.h"
-typedef void (*eos_evt_handler_t) (unsigned char, unsigned char *, uint16_t);
-typedef void (*eos_evt_handler_global_t) (unsigned char, unsigned char *, uint16_t, uint8_t);
+typedef void (*eos_evt_handler_t) (unsigned char, EOSMessage *, uint16_t);
+typedef void (*eos_evt_handler_global_t) (unsigned char, EOSMessage *, uint16_t, uint8_t);
+typedef void (*eos_evt_simple_handler_t) (unsigned char);
typedef void (*eos_evt_loopf_t) (void);
int eos_evtq_init(void);
int eos_evtq_len(void);
-int eos_evtq_push(unsigned char type, unsigned char *buffer, uint16_t len);
-int eos_evtq_push_widx(unsigned char type, unsigned char *buffer, uint16_t len, uint8_t *idx);
-int eos_evtq_push_isr(unsigned char type, unsigned char *buffer, uint16_t len);
-int eos_evtq_push_widx_isr(unsigned char type, unsigned char *buffer, uint16_t len, uint8_t *idx);
+int eos_evtq_push(unsigned char type, EOSMessage *msg, uint16_t len);
+int eos_evtq_push_widx(unsigned char type, EOSMessage *msg, uint16_t len, uint8_t *idx);
+int eos_evtq_push_isr(unsigned char type, EOSMessage *msg, uint16_t len);
+int eos_evtq_push_widx_isr(unsigned char type, EOSMessage *msg, uint16_t len, uint8_t *idx);
-void eos_evtq_pop(unsigned char *type, unsigned char **buffer, uint16_t *len);
-void eos_evtq_pop_widx(unsigned char *type, unsigned char **buffer, uint16_t *len, uint8_t *idx) ;
-void eos_evtq_pop_isr(unsigned char *type, unsigned char **buffer, uint16_t *len);
-void eos_evtq_pop_widx_isr(unsigned char *type, unsigned char **buffer, uint16_t *len, uint8_t *idx);
-
-int eos_evtq_get(unsigned char type, unsigned char **buffer, uint16_t *len);
-int eos_evtq_find(unsigned char type, unsigned char *selector, uint16_t sel_len, unsigned char **buffer, uint16_t *len);
-int eos_evtq_wait(unsigned char type, unsigned char *selector, uint16_t sel_len, unsigned char **buffer, uint16_t *len);
+void eos_evtq_pop(unsigned char *type, EOSMessage *msg, uint16_t *len);
+void eos_evtq_pop_widx(unsigned char *type, EOSMessage *msg, uint16_t *len, uint8_t *idx) ;
+void eos_evtq_pop_isr(unsigned char *type, EOSMessage *msg, uint16_t *len);
+void eos_evtq_pop_widx_isr(unsigned char *type, EOSMessage *msg, uint16_t *len, uint8_t *idx);
void eos_evtq_flush(void);
void eos_evtq_flush_isr(void);
@@ -30,7 +28,7 @@ void eos_evtq_loop(void);
void eos_evtq_exec(void);
void eos_evtq_set_loopf(eos_evt_loopf_t loop_f);
-void eos_evtq_bad_handler(unsigned char type, unsigned char *buffer, uint16_t len);
+void eos_evtq_bad_handler(unsigned char type, EOSMessage *msg, uint16_t len);
void eos_evtq_set_handler(unsigned char type, eos_evt_handler_t handler);
eos_evt_handler_t eos_evtq_get_handler(unsigned char type);
void eos_evtq_set_handler_global(eos_evt_handler_global_t handler);