From 6b4876d3acd240eb6a513dee7a90cc4c714d4fba Mon Sep 17 00:00:00 2001 From: Alexander Bushnev Date: Fri, 5 Apr 2024 11:04:31 +0200 Subject: [PATCH] Apply review feedback --- examples/unix/c11/z_pull.c | 2 +- examples/unix/c11/z_sub_channel.c | 2 +- include/zenoh-pico/api/handlers.h | 18 +++---- include/zenoh-pico/collections/fifo_mt.h | 2 +- include/zenoh-pico/collections/ring_mt.h | 2 +- src/api/api.c | 12 ++--- src/api/handlers.c | 7 ++- src/collections/fifo_mt.c | 69 ++++++------------------ src/collections/ring_mt.c | 39 ++++---------- tests/z_channels_test.c | 56 +++++++++---------- 10 files changed, 81 insertions(+), 128 deletions(-) diff --git a/examples/unix/c11/z_pull.c b/examples/unix/c11/z_pull.c index 69dc67d32..c6bb58f20 100644 --- a/examples/unix/c11/z_pull.c +++ b/examples/unix/c11/z_pull.c @@ -72,7 +72,7 @@ int main(int argc, char **argv) { } printf("Declaring Subscriber on '%s'...\n", keyexpr); - z_owned_sample_ring_channel_t channel = z_sample_ring_channel(size); + z_owned_sample_ring_channel_t channel = z_sample_ring_channel_new(size); z_owned_subscriber_t sub = z_declare_subscriber(z_loan(s), z_keyexpr(keyexpr), z_move(channel.send), NULL); if (!z_check(sub)) { printf("Unable to declare subscriber.\n"); diff --git a/examples/unix/c11/z_sub_channel.c b/examples/unix/c11/z_sub_channel.c index 743966c59..43548d1ba 100644 --- a/examples/unix/c11/z_sub_channel.c +++ b/examples/unix/c11/z_sub_channel.c @@ -64,7 +64,7 @@ int main(int argc, char **argv) { } printf("Declaring Subscriber on '%s'...\n", keyexpr); - z_owned_sample_fifo_channel_t channel = z_sample_fifo_channel(3); + z_owned_sample_fifo_channel_t channel = z_sample_fifo_channel_new(3); z_owned_subscriber_t sub = z_declare_subscriber(z_loan(s), z_keyexpr(keyexpr), z_move(channel.send), NULL); if (!z_check(sub)) { printf("Unable to declare subscriber.\n"); diff --git a/include/zenoh-pico/api/handlers.h b/include/zenoh-pico/api/handlers.h index 2543066e0..d48c2e8fc 100644 --- a/include/zenoh-pico/api/handlers.h +++ b/include/zenoh-pico/api/handlers.h @@ -49,19 +49,19 @@ z_owned_sample_t *_z_sample_to_owned_ptr(const _z_sample_t *src); if (internal_elem == NULL) { \ return; \ } \ - int8_t res = collection_push_f(internal_elem, context, _z_##name##_elem_free); \ - if (res) { \ - _Z_ERROR("%s failed: %i", #collection_push_f, res); \ + int8_t ret = collection_push_f(internal_elem, context, _z_##name##_elem_free); \ + if (ret != _Z_RES_OK) { \ + _Z_ERROR("%s failed: %i", #collection_push_f, ret); \ } \ } \ static inline void _z_##name##_recv(recv_type *elem, void *context) { \ - int8_t res = collection_pull_f(elem, context, _z_##name##_elem_move); \ - if (res) { \ - _Z_ERROR("%s failed: %i", #collection_pull_f, res); \ + int8_t ret = collection_pull_f(elem, context, _z_##name##_elem_move); \ + if (ret != _Z_RES_OK) { \ + _Z_ERROR("%s failed: %i", #collection_pull_f, ret); \ } \ } \ \ - static inline z_owned_##name##_t z_##name(size_t capacity) { \ + static inline z_owned_##name##_t z_##name##_new(size_t capacity) { \ z_owned_##name##_t channel; \ channel.collection = collection_new_f(capacity); \ channel.send = z_##send_closure_name(_z_##name##_send, NULL, channel.collection); \ @@ -77,12 +77,12 @@ z_owned_sample_t *_z_sample_to_owned_ptr(const _z_sample_t *src); // z_owned_sample_ring_channel_t _Z_CHANNEL_DEFINE(sample_ring_channel, closure_sample, closure_owned_sample, z_sample_t, z_owned_sample_t, _z_ring_mt_t, - _z_ring_mt, _z_ring_mt_free, _z_ring_mt_push, _z_ring_mt_pull, _z_owned_sample_move, + _z_ring_mt_new, _z_ring_mt_free, _z_ring_mt_push, _z_ring_mt_pull, _z_owned_sample_move, _z_sample_to_owned_ptr, z_sample_drop) // z_owned_sample_fifo_channel_t _Z_CHANNEL_DEFINE(sample_fifo_channel, closure_sample, closure_owned_sample, z_sample_t, z_owned_sample_t, _z_fifo_mt_t, - _z_fifo_mt, _z_fifo_mt_free, _z_fifo_mt_push, _z_fifo_mt_pull, _z_owned_sample_move, + _z_fifo_mt_new, _z_fifo_mt_free, _z_fifo_mt_push, _z_fifo_mt_pull, _z_owned_sample_move, _z_sample_to_owned_ptr, z_sample_drop) #endif // INCLUDE_ZENOH_PICO_API_HANDLERS_H diff --git a/include/zenoh-pico/collections/fifo_mt.h b/include/zenoh-pico/collections/fifo_mt.h index 573e6ad95..bcf8d700c 100644 --- a/include/zenoh-pico/collections/fifo_mt.h +++ b/include/zenoh-pico/collections/fifo_mt.h @@ -31,7 +31,7 @@ typedef struct { } _z_fifo_mt_t; int8_t _z_fifo_mti_init(size_t capacity); -_z_fifo_mt_t *_z_fifo_mt(size_t capacity); +_z_fifo_mt_t *_z_fifo_mt_new(size_t capacity); void _z_fifo_mt_clear(_z_fifo_mt_t *fifo, z_element_free_f free_f); void _z_fifo_mt_free(_z_fifo_mt_t *fifo, z_element_free_f free_f); diff --git a/include/zenoh-pico/collections/ring_mt.h b/include/zenoh-pico/collections/ring_mt.h index 15373cf1c..98a413e20 100644 --- a/include/zenoh-pico/collections/ring_mt.h +++ b/include/zenoh-pico/collections/ring_mt.h @@ -29,7 +29,7 @@ typedef struct { } _z_ring_mt_t; int8_t _z_ring_mt_init(_z_ring_mt_t *ring, size_t capacity); -_z_ring_mt_t *_z_ring_mt(size_t capacity); +_z_ring_mt_t *_z_ring_mt_new(size_t capacity); void _z_ring_mt_clear(_z_ring_mt_t *ring, z_element_free_f free_f); void _z_ring_mt_free(_z_ring_mt_t *ring, z_element_free_f free_f); diff --git a/src/api/api.c b/src/api/api.c index 2812059b8..19527e0a5 100644 --- a/src/api/api.c +++ b/src/api/api.c @@ -312,37 +312,37 @@ _Bool z_value_is_initialized(z_value_t *value) { } void z_closure_sample_call(const z_owned_closure_sample_t *closure, const z_sample_t *sample) { - if (closure->call) { + if (closure->call != NULL) { (closure->call)(sample, closure->context); } } void z_closure_owned_sample_call(const z_owned_closure_owned_sample_t *closure, z_owned_sample_t *sample) { - if (closure->call) { + if (closure->call != NULL) { (closure->call)(sample, closure->context); } } void z_closure_query_call(const z_owned_closure_query_t *closure, const z_query_t *query) { - if (closure->call) { + if (closure->call != NULL) { (closure->call)(query, closure->context); } } void z_closure_reply_call(const z_owned_closure_reply_t *closure, z_owned_reply_t *reply) { - if (closure->call) { + if (closure->call != NULL) { (closure->call)(reply, closure->context); } } void z_closure_hello_call(const z_owned_closure_hello_t *closure, z_owned_hello_t *hello) { - if (closure->call) { + if (closure->call != NULL) { (closure->call)(hello, closure->context); } } void z_closure_zid_call(const z_owned_closure_zid_t *closure, const z_id_t *id) { - if (closure->call) { + if (closure->call != NULL) { (closure->call)(id, closure->context); } } diff --git a/src/api/handlers.c b/src/api/handlers.c index 783855694..e1f0594b9 100644 --- a/src/api/handlers.c +++ b/src/api/handlers.c @@ -24,9 +24,14 @@ void _z_owned_sample_move(z_owned_sample_t *dst, const z_owned_sample_t *src) { z_owned_sample_t *_z_sample_to_owned_ptr(const _z_sample_t *src) { z_owned_sample_t *dst = (z_owned_sample_t *)zp_malloc(sizeof(z_owned_sample_t)); - if (dst && src) { + if (dst == NULL) { + return NULL; + } + if (src != NULL) { dst->_value = (_z_sample_t *)zp_malloc(sizeof(_z_sample_t)); _z_sample_copy(dst->_value, src); + } else { + dst->_value = NULL; } return dst; } diff --git a/src/collections/fifo_mt.c b/src/collections/fifo_mt.c index b36141c25..48837b5dd 100644 --- a/src/collections/fifo_mt.c +++ b/src/collections/fifo_mt.c @@ -14,44 +14,33 @@ #include "zenoh-pico/collections/fifo_mt.h" +#include "zenoh-pico/protocol/codec/core.h" #include "zenoh-pico/protocol/core.h" #include "zenoh-pico/utils/logging.h" /*-------- Fifo Buffer Multithreaded --------*/ int8_t _z_fifo_mt_init(_z_fifo_mt_t *fifo, size_t capacity) { - int8_t res = _z_fifo_init(&fifo->_fifo, capacity); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(_z_fifo_init(&fifo->_fifo, capacity)) #if Z_FEATURE_MULTI_THREAD == 1 - res = zp_mutex_init(&fifo->_mutex); - if (res) { - return res; - } - res = zp_condvar_init(&fifo->_cv_not_full); - if (res) { - return res; - } - res = zp_condvar_init(&fifo->_cv_not_empty); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_mutex_init(&fifo->_mutex)) + _Z_RETURN_IF_ERR(zp_condvar_init(&fifo->_cv_not_full)) + _Z_RETURN_IF_ERR(zp_condvar_init(&fifo->_cv_not_empty)) #endif return _Z_RES_OK; } -_z_fifo_mt_t *_z_fifo_mt(size_t capacity) { +_z_fifo_mt_t *_z_fifo_mt_new(size_t capacity) { _z_fifo_mt_t *fifo = (_z_fifo_mt_t *)zp_malloc(sizeof(_z_fifo_mt_t)); if (fifo == NULL) { _Z_ERROR("zp_malloc failed"); return NULL; } - int8_t res = _z_fifo_mt_init(fifo, capacity); - if (res) { - _Z_ERROR("_z_fifo_mt_init failed: %i", res); + int8_t ret = _z_fifo_mt_init(fifo, capacity); + if (ret != _Z_RES_OK) { + _Z_ERROR("_z_fifo_mt_init failed: %i", ret); zp_free(fifo); return NULL; } @@ -82,28 +71,16 @@ int8_t _z_fifo_mt_push(const void *elem, void *context, z_element_free_f element _z_fifo_mt_t *f = (_z_fifo_mt_t *)context; #if Z_FEATURE_MULTI_THREAD == 1 - int res = zp_mutex_lock(&f->_mutex); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_mutex_lock(&f->_mutex)) while (elem != NULL) { elem = _z_fifo_push(&f->_fifo, (void *)elem); if (elem != NULL) { - res = zp_condvar_wait(&f->_cv_not_full, &f->_mutex); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_condvar_wait(&f->_cv_not_full, &f->_mutex)) } else { - res = zp_condvar_signal(&f->_cv_not_empty); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_condvar_signal(&f->_cv_not_empty)) } } - res = zp_mutex_unlock(&f->_mutex); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_mutex_unlock(&f->_mutex)) #else // Z_FEATURE_MULTI_THREAD == 1 _z_fifo_push_drop(&f->_fifo, elem, element_free); #endif // Z_FEATURE_MULTI_THREAD == 1 @@ -116,28 +93,16 @@ int8_t _z_fifo_mt_pull(void *dst, void *context, z_element_move_f element_move) #if Z_FEATURE_MULTI_THREAD == 1 void *src = NULL; - int res = zp_mutex_lock(&f->_mutex); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_mutex_lock(&f->_mutex)) while (src == NULL) { src = _z_fifo_pull(&f->_fifo); if (src == NULL) { - res = zp_condvar_wait(&f->_cv_not_empty, &f->_mutex); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_condvar_wait(&f->_cv_not_empty, &f->_mutex)) } else { - res = zp_condvar_signal(&f->_cv_not_full); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_condvar_signal(&f->_cv_not_full)) } } - res = zp_mutex_unlock(&f->_mutex); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_mutex_unlock(&f->_mutex)) element_move(dst, src); #else // Z_FEATURE_MULTI_THREAD == 1 void *src = _z_fifo_pull(&f->_fifo); diff --git a/src/collections/ring_mt.c b/src/collections/ring_mt.c index ec934c543..ab7083be0 100644 --- a/src/collections/ring_mt.c +++ b/src/collections/ring_mt.c @@ -14,35 +14,30 @@ #include "zenoh-pico/collections/ring_mt.h" +#include "zenoh-pico/protocol/codec/core.h" #include "zenoh-pico/protocol/core.h" #include "zenoh-pico/utils/logging.h" /*-------- Ring Buffer Multithreaded --------*/ int8_t _z_ring_mt_init(_z_ring_mt_t *ring, size_t capacity) { - int8_t res = _z_ring_init(&ring->_ring, capacity); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(_z_ring_init(&ring->_ring, capacity)) #if Z_FEATURE_MULTI_THREAD == 1 - res = zp_mutex_init(&ring->_mutex); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_mutex_init(&ring->_mutex)) #endif return _Z_RES_OK; } -_z_ring_mt_t *_z_ring_mt(size_t capacity) { +_z_ring_mt_t *_z_ring_mt_new(size_t capacity) { _z_ring_mt_t *ring = (_z_ring_mt_t *)zp_malloc(sizeof(_z_ring_mt_t)); if (ring == NULL) { _Z_ERROR("zp_malloc failed"); return NULL; } - int8_t res = _z_ring_mt_init(ring, capacity); - if (res) { - _Z_ERROR("_z_ring_mt_init failed: %i", res); + int8_t ret = _z_ring_mt_init(ring, capacity); + if (ret != _Z_RES_OK) { + _Z_ERROR("_z_ring_mt_init failed: %i", ret); return NULL; } @@ -71,19 +66,13 @@ int8_t _z_ring_mt_push(const void *elem, void *context, z_element_free_f element _z_ring_mt_t *r = (_z_ring_mt_t *)context; #if Z_FEATURE_MULTI_THREAD == 1 - int8_t res = zp_mutex_lock(&r->_mutex); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_mutex_lock(&r->_mutex)) #endif _z_ring_push_force_drop(&r->_ring, (void *)elem, element_free); #if Z_FEATURE_MULTI_THREAD == 1 - res = zp_mutex_unlock(&r->_mutex); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_mutex_unlock(&r->_mutex)) #endif return _Z_RES_OK; } @@ -92,19 +81,13 @@ int8_t _z_ring_mt_pull(void *dst, void *context, z_element_move_f element_move) _z_ring_mt_t *r = (_z_ring_mt_t *)context; #if Z_FEATURE_MULTI_THREAD == 1 - int res = zp_mutex_lock(&r->_mutex); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_mutex_lock(&r->_mutex)) #endif void *src = _z_ring_pull(&r->_ring); #if Z_FEATURE_MULTI_THREAD == 1 - res = zp_mutex_unlock(&r->_mutex); - if (res) { - return res; - } + _Z_RETURN_IF_ERR(zp_mutex_unlock(&r->_mutex)) #endif if (src) { diff --git a/tests/z_channels_test.c b/tests/z_channels_test.c index 0e5f1df0d..b390908d7 100644 --- a/tests/z_channels_test.c +++ b/tests/z_channels_test.c @@ -44,68 +44,68 @@ } while (0); void sample_fifo_channel_test(void) { - z_owned_sample_fifo_channel_t channel = z_sample_fifo_channel(10); + z_owned_sample_fifo_channel_t channel = z_sample_fifo_channel_new(10); - SEND(channel, "v1"); - SEND(channel, "v22"); - SEND(channel, "v333"); - SEND(channel, "v4444"); + SEND(channel, "v1") + SEND(channel, "v22") + SEND(channel, "v333") + SEND(channel, "v4444") char buf[100]; - RECV(channel, buf); + RECV(channel, buf) assert(strcmp(buf, "v1") == 0); - RECV(channel, buf); + RECV(channel, buf) assert(strcmp(buf, "v22") == 0); - RECV(channel, buf); + RECV(channel, buf) assert(strcmp(buf, "v333") == 0); - RECV(channel, buf); + RECV(channel, buf) assert(strcmp(buf, "v4444") == 0); z_drop(z_move(channel)); } void sample_ring_channel_test_in_size(void) { - z_owned_sample_ring_channel_t channel = z_sample_ring_channel(10); + z_owned_sample_ring_channel_t channel = z_sample_ring_channel_new(10); - SEND(channel, "v1"); - SEND(channel, "v22"); - SEND(channel, "v333"); - SEND(channel, "v4444"); + SEND(channel, "v1") + SEND(channel, "v22") + SEND(channel, "v333") + SEND(channel, "v4444") char buf[100]; - RECV(channel, buf); + RECV(channel, buf) assert(strcmp(buf, "v1") == 0); - RECV(channel, buf); + RECV(channel, buf) assert(strcmp(buf, "v22") == 0); - RECV(channel, buf); + RECV(channel, buf) assert(strcmp(buf, "v333") == 0); - RECV(channel, buf); + RECV(channel, buf) assert(strcmp(buf, "v4444") == 0); - RECV(channel, buf); + RECV(channel, buf) assert(strcmp(buf, "") == 0); z_drop(z_move(channel)); } void sample_ring_channel_test_over_size(void) { - z_owned_sample_ring_channel_t channel = z_sample_ring_channel(3); + z_owned_sample_ring_channel_t channel = z_sample_ring_channel_new(3); - SEND(channel, "v1"); - SEND(channel, "v22"); - SEND(channel, "v333"); - SEND(channel, "v4444"); + SEND(channel, "v1") + SEND(channel, "v22") + SEND(channel, "v333") + SEND(channel, "v4444") char buf[100]; - RECV(channel, buf); + RECV(channel, buf) assert(strcmp(buf, "v22") == 0); - RECV(channel, buf); + RECV(channel, buf) assert(strcmp(buf, "v333") == 0); - RECV(channel, buf); + RECV(channel, buf) assert(strcmp(buf, "v4444") == 0); - RECV(channel, buf); + RECV(channel, buf) assert(strcmp(buf, "") == 0); z_drop(z_move(channel));