diff options
author | Uros Majstorovic <majstor@majstor.org> | 2020-08-09 02:46:08 +0200 |
---|---|---|
committer | Uros Majstorovic <majstor@majstor.org> | 2020-08-09 02:46:08 +0200 |
commit | 21dbc40e58a79f487d1ee34129f16e26cb6ba120 (patch) | |
tree | 8e45719fce0029090792fac08ba42ac2a0371f0e /fw/fe310/eos/power.c | |
parent | 9dd66a7dd0c5ba39f9b602daafea88a00cef75e8 (diff) |
message handling iface updated
Diffstat (limited to 'fw/fe310/eos/power.c')
-rw-r--r-- | fw/fe310/eos/power.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/fw/fe310/eos/power.c b/fw/fe310/eos/power.c index 5c874e0..2b13c9f 100644 --- a/fw/fe310/eos/power.c +++ b/fw/fe310/eos/power.c @@ -19,14 +19,16 @@ static eos_evt_handler_t evt_handler[EOS_PWR_MAX_MTYPE]; static unsigned char power_btn_down; static void power_handle_evt(unsigned char type, unsigned char *buffer, uint16_t len) { + unsigned char mtype; + if ((buffer == NULL) || (len < 1)) { eos_net_bad_handler(type, buffer, len); return; } - unsigned char mtype = buffer[0]; - if (mtype < EOS_PWR_MAX_MTYPE) { - evt_handler[mtype](type, buffer, len); + mtype = buffer[0]; + if ((mtype < EOS_PWR_MAX_MTYPE) && evt_handler[mtype]) { + evt_handler[mtype](mtype, buffer, len); } else { eos_net_bad_handler(type, buffer, len); } @@ -49,7 +51,7 @@ void eos_power_init(void) { int i; for (i=0; i<EOS_PWR_MAX_MTYPE; i++) { - evt_handler[i] = eos_net_bad_handler; + evt_handler[i] = NULL; } eos_net_set_handler(EOS_NET_MTYPE_POWER, power_handle_evt); eos_power_set_handler(EOS_PWR_MTYPE_BUTTON, power_handle_btn); @@ -106,6 +108,5 @@ void eos_power_wake_disable(void) { } void eos_power_set_handler(unsigned char mtype, eos_evt_handler_t handler) { - if (handler == NULL) handler = eos_net_bad_handler; if (mtype < EOS_PWR_MAX_MTYPE) evt_handler[mtype] = handler; } |