summaryrefslogtreecommitdiff
path: root/code/fe310/eos/sock.c
diff options
context:
space:
mode:
authorUros Majstorovic <majstor@majstor.org>2019-11-24 18:25:18 +0100
committerUros Majstorovic <majstor@majstor.org>2019-11-24 18:25:18 +0100
commit22a79e03a60bed3df7ba24015564c4b48bb811cb (patch)
tree51c5ec4bf4fbf52e13af34d08df71c5218e22317 /code/fe310/eos/sock.c
parent3eb69c840d1f42d6584834406bd2fb9413a8293a (diff)
fixed evt msg get; cleanup
Diffstat (limited to 'code/fe310/eos/sock.c')
-rw-r--r--code/fe310/eos/sock.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/code/fe310/eos/sock.c b/code/fe310/eos/sock.c
index b217b43..ab0fc59 100644
--- a/code/fe310/eos/sock.c
+++ b/code/fe310/eos/sock.c
@@ -13,6 +13,12 @@ static uint16_t sock_handler_flags_buf_free = 0;
static uint16_t sock_handler_flags_buf_acq = 0;
static void sock_handler_evt(unsigned char type, unsigned char *buffer, uint16_t len) {
+ if ((buffer == NULL) || (len < 2)) {
+ eos_evtq_bad_handler(type, buffer, len);
+ eos_net_free(buffer, 0);
+ return;
+ }
+
if (buffer[0] == EOS_SOCK_MTYPE_PKT) {
uint8_t sock = buffer[1];
if (sock && (sock <= EOS_SOCK_MAX_SOCK)) {
@@ -59,6 +65,7 @@ int eos_sock_open_udp(void) {
sock = buffer[1];
eos_net_free(buffer, 1);
+ if (sock == 0) return EOS_ERR_NET;
return sock;
}