From 66ca132dc39659365936ba10c327eebca3acbfa2 Mon Sep 17 00:00:00 2001 From: Jean-Roland Date: Fri, 1 Dec 2023 14:56:00 +0100 Subject: [PATCH] fix: remove read mutex double lock --- src/transport/raweth/lease.c | 10 +++++----- src/transport/raweth/read.c | 16 +++++----------- src/transport/raweth/rx.c | 3 +++ 3 files changed, 13 insertions(+), 16 deletions(-) diff --git a/src/transport/raweth/lease.c b/src/transport/raweth/lease.c index 672c04def..10fa08a8f 100644 --- a/src/transport/raweth/lease.c +++ b/src/transport/raweth/lease.c @@ -73,18 +73,18 @@ int8_t _zp_raweth_start_lease_task(_z_transport_t *zt, _z_task_attr_t *attr, _z_ // Init memory (void)memset(task, 0, sizeof(_z_task_t)); // Attach task - zt->_transport._multicast._lease_task = task; - zt->_transport._multicast._lease_task_running = true; + zt->_transport._raweth._lease_task = task; + zt->_transport._raweth._lease_task_running = true; // Init task - if (_z_task_init(task, attr, _zp_raweth_lease_task, &zt->_transport._multicast) != _Z_RES_OK) { - zt->_transport._multicast._lease_task_running = false; + if (_z_task_init(task, attr, _zp_raweth_lease_task, &zt->_transport._raweth) != _Z_RES_OK) { + zt->_transport._raweth._lease_task_running = false; return _Z_ERR_SYSTEM_TASK_FAILED; } return _Z_RES_OK; } int8_t _zp_raweth_stop_lease_task(_z_transport_t *zt) { - zt->_transport._multicast._lease_task_running = false; + zt->_transport._raweth._lease_task_running = false; return _Z_RES_OK; } diff --git a/src/transport/raweth/read.c b/src/transport/raweth/read.c index cf4761f56..c8c6d2ba4 100644 --- a/src/transport/raweth/read.c +++ b/src/transport/raweth/read.c @@ -43,18 +43,18 @@ int8_t _zp_raweth_start_read_task(_z_transport_t *zt, _z_task_attr_t *attr, _z_t // Init memory (void)memset(task, 0, sizeof(_z_task_t)); // Attach task - zt->_transport._multicast._read_task = task; - zt->_transport._multicast._read_task_running = true; + zt->_transport._raweth._read_task = task; + zt->_transport._raweth._read_task_running = true; // Init task - if (_z_task_init(task, attr, _zp_raweth_read_task, &zt->_transport._multicast) != _Z_RES_OK) { - zt->_transport._multicast._read_task_running = false; + if (_z_task_init(task, attr, _zp_raweth_read_task, &zt->_transport._raweth) != _Z_RES_OK) { + zt->_transport._raweth._read_task_running = false; return _Z_ERR_SYSTEM_TASK_FAILED; } return _Z_RES_OK; } int8_t _zp_raweth_stop_read_task(_z_transport_t *zt) { - zt->_transport._multicast._read_task_running = false; + zt->_transport._raweth._read_task_running = false; return _Z_RES_OK; } @@ -64,10 +64,6 @@ void *_zp_raweth_read_task(void *ztm_arg) { _z_transport_message_t t_msg; _z_bytes_t addr = _z_bytes_wrap(NULL, 0); - // Acquire and keep the lock - _z_mutex_lock(&ztm->_mutex_rx); - // Prepare the buffer - _z_zbuf_reset(&ztm->_zbuf); // Task loop while (ztm->_read_task_running == true) { // Read message from link @@ -87,8 +83,6 @@ void *_zp_raweth_read_task(void *ztm_arg) { _z_t_msg_clear(&t_msg); _z_bytes_clear(&addr); } - - _z_mutex_unlock(&ztm->_mutex_rx); #endif // Z_FEATURE_MULTI_THREAD == 1 return NULL; diff --git a/src/transport/raweth/rx.c b/src/transport/raweth/rx.c index ef189b4f4..180106c58 100644 --- a/src/transport/raweth/rx.c +++ b/src/transport/raweth/rx.c @@ -64,6 +64,9 @@ int8_t _z_raweth_recv_t_msg_na(_z_transport_multicast_t *ztm, _z_transport_messa _z_mutex_lock(&ztm->_mutex_rx); #endif // Z_FEATURE_MULTI_THREAD == 1 + // Prepare the buffer + _z_zbuf_reset(&ztm->_zbuf); + switch (ztm->_link._cap._flow) { // Datagram capable links case Z_LINK_CAP_FLOW_DATAGRAM: {