-
Notifications
You must be signed in to change notification settings - Fork 85
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
9542ec8
commit 560505c
Showing
7 changed files
with
486 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
// | ||
// Copyright (c) 2022 ZettaScale Technology | ||
// | ||
// This program and the accompanying materials are made available under the | ||
// terms of the Eclipse Public License 2.0 which is available at | ||
// http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0 | ||
// which is available at https://www.apache.org/licenses/LICENSE-2.0. | ||
// | ||
// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 | ||
// | ||
// Contributors: | ||
// ZettaScale Zenoh Team, <[email protected]> | ||
// | ||
|
||
#ifndef ZENOH_RAWETH_JOIN_H | ||
#define ZENOH_RAWETH_JOIN_H | ||
|
||
#include "zenoh-pico/transport/transport.h" | ||
|
||
int8_t _zp_raweth_send_join(_z_transport_multicast_t *ztm); | ||
|
||
#endif /* ZENOH_RAWETH_JOIN_H */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
// | ||
// Copyright (c) 2022 ZettaScale Technology | ||
// | ||
// This program and the accompanying materials are made available under the | ||
// terms of the Eclipse Public License 2.0 which is available at | ||
// http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0 | ||
// which is available at https://www.apache.org/licenses/LICENSE-2.0. | ||
// | ||
// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 | ||
// | ||
// Contributors: | ||
// ZettaScale Zenoh Team, <[email protected]> | ||
// | ||
|
||
#ifndef ZENOH_PICO_RAWETH_LEASE_H | ||
#define ZENOH_PICO_RAWETH_LEASE_H | ||
|
||
#include "zenoh-pico/transport/transport.h" | ||
|
||
int8_t _zp_raweth_send_keep_alive(_z_transport_multicast_t *ztm); | ||
int8_t _zp_raweth_start_lease_task(_z_transport_t *zt, _z_task_attr_t *attr, _z_task_t *task); | ||
int8_t _zp_raweth_stop_lease_task(_z_transport_t *zt); | ||
void *_zp_raweth_lease_task(void *ztm_arg); // The argument is void* to avoid incompatible pointer types in tasks | ||
|
||
#endif /* ZENOH_PICO_RAWETH_LEASE_H */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
// | ||
// Copyright (c) 2022 ZettaScale Technology | ||
// | ||
// This program and the accompanying materials are made available under the | ||
// terms of the Eclipse Public License 2.0 which is available at | ||
// http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0 | ||
// which is available at https://www.apache.org/licenses/LICENSE-2.0. | ||
// | ||
// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 | ||
// | ||
// Contributors: | ||
// ZettaScale Zenoh Team, <[email protected]> | ||
// | ||
|
||
#ifndef ZENOH_PICO_RAWETH_READ_H | ||
#define ZENOH_PICO_RAWETH_READ_H | ||
|
||
#include "zenoh-pico/transport/transport.h" | ||
|
||
int8_t _zp_raweth_read(_z_transport_multicast_t *ztm); | ||
int8_t _zp_raweth_start_read_task(_z_transport_t *zt, _z_task_attr_t *attr, _z_task_t *task); | ||
int8_t _zp_raweth_stop_read_task(_z_transport_t *zt); | ||
void *_zp_raweth_read_task(void *ztm_arg); // The argument is void* to avoid incompatible pointer types in tasks | ||
|
||
#endif /* ZENOH_PICO_RAWETH_READ_H */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
// | ||
// Copyright (c) 2022 ZettaScale Technology | ||
// | ||
// This program and the accompanying materials are made available under the | ||
// terms of the Eclipse Public License 2.0 which is available at | ||
// http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0 | ||
// which is available at https://www.apache.org/licenses/LICENSE-2.0. | ||
// | ||
// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 | ||
// | ||
// Contributors: | ||
// ZettaScale Zenoh Team, <[email protected]> | ||
// | ||
|
||
#include "zenoh-pico/transport/raweth/join.h" | ||
|
||
#include "zenoh-pico/session/utils.h" | ||
#include "zenoh-pico/transport/raweth/tx.h" | ||
|
||
#if Z_FEATURE_RAWETH_TRANSPORT == 1 | ||
|
||
int8_t _zp_raweth_send_join(_z_transport_multicast_t *ztm) { | ||
_z_conduit_sn_list_t next_sn; | ||
next_sn._is_qos = false; | ||
next_sn._val._plain._best_effort = ztm->_sn_tx_best_effort; | ||
next_sn._val._plain._reliable = ztm->_sn_tx_reliable; | ||
|
||
_z_id_t zid = ((_z_session_t *)ztm->_session)->_local_zid; | ||
_z_transport_message_t jsm = _z_t_msg_make_join(Z_WHATAMI_PEER, Z_TRANSPORT_LEASE, zid, next_sn); | ||
|
||
return _z_raweth_send_t_msg(ztm, &jsm); | ||
} | ||
#else | ||
int8_t _zp_raweth_send_join(_z_transport_multicast_t *ztm) { | ||
_ZP_UNUSED(ztm); | ||
return _Z_ERR_TRANSPORT_NOT_AVAILABLE; | ||
} | ||
#endif // Z_FEATURE_RAWETH_TRANSPORT == 1 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,208 @@ | ||
// | ||
// Copyright (c) 2022 ZettaScale Technology | ||
// | ||
// This program and the accompanying materials are made available under the | ||
// terms of the Eclipse Public License 2.0 which is available at | ||
// http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0 | ||
// which is available at https://www.apache.org/licenses/LICENSE-2.0. | ||
// | ||
// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 | ||
// | ||
// Contributors: | ||
// ZettaScale Zenoh Team, <[email protected]> | ||
// | ||
|
||
#include "zenoh-pico/transport/raweth/lease.h" | ||
|
||
#include <stddef.h> | ||
|
||
#include "zenoh-pico/config.h" | ||
#include "zenoh-pico/session/utils.h" | ||
#include "zenoh-pico/transport/common/join.h" | ||
#include "zenoh-pico/transport/raweth/join.h" | ||
#include "zenoh-pico/transport/raweth/transport.h" | ||
#include "zenoh-pico/transport/raweth/tx.h" | ||
#include "zenoh-pico/utils/logging.h" | ||
|
||
#if Z_FEATURE_RAWETH_TRANSPORT == 1 | ||
|
||
static _z_zint_t _z_get_minimum_lease(_z_transport_peer_entry_list_t *peers, _z_zint_t local_lease) { | ||
_z_zint_t ret = local_lease; | ||
|
||
_z_transport_peer_entry_list_t *it = peers; | ||
while (it != NULL) { | ||
_z_transport_peer_entry_t *val = _z_transport_peer_entry_list_head(it); | ||
_z_zint_t lease = val->_lease; | ||
if (lease < ret) { | ||
ret = lease; | ||
} | ||
|
||
it = _z_transport_peer_entry_list_tail(it); | ||
} | ||
|
||
return ret; | ||
} | ||
|
||
static _z_zint_t _z_get_next_lease(_z_transport_peer_entry_list_t *peers) { | ||
_z_zint_t ret = SIZE_MAX; | ||
|
||
_z_transport_peer_entry_list_t *it = peers; | ||
while (it != NULL) { | ||
_z_transport_peer_entry_t *val = _z_transport_peer_entry_list_head(it); | ||
_z_zint_t next_lease = val->_next_lease; | ||
if (next_lease < ret) { | ||
ret = next_lease; | ||
} | ||
|
||
it = _z_transport_peer_entry_list_tail(it); | ||
} | ||
|
||
return ret; | ||
} | ||
|
||
int8_t _zp_raweth_send_keep_alive(_z_transport_multicast_t *ztm) { | ||
int8_t ret = _Z_RES_OK; | ||
|
||
_z_transport_message_t t_msg = _z_t_msg_make_keep_alive(); | ||
ret = _z_raweth_send_t_msg(ztm, &t_msg); | ||
|
||
return ret; | ||
} | ||
|
||
int8_t _zp_raweth_start_lease_task(_z_transport_t *zt, _z_task_attr_t *attr, _z_task_t *task) { | ||
// 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; | ||
// 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; | ||
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; | ||
return _Z_RES_OK; | ||
} | ||
|
||
void *_zp_raweth_lease_task(void *ztm_arg) { | ||
#if Z_FEATURE_MULTI_THREAD == 1 | ||
_z_transport_multicast_t *ztm = (_z_transport_multicast_t *)ztm_arg; | ||
ztm->_transmitted = false; | ||
|
||
// From all peers, get the next lease time (minimum) | ||
_z_zint_t next_lease = _z_get_minimum_lease(ztm->_peers, ztm->_lease); | ||
_z_zint_t next_keep_alive = (_z_zint_t)(next_lease / Z_TRANSPORT_LEASE_EXPIRE_FACTOR); | ||
_z_zint_t next_join = Z_JOIN_INTERVAL; | ||
|
||
_z_transport_peer_entry_list_t *it = NULL; | ||
while (ztm->_lease_task_running == true) { | ||
_z_mutex_lock(&ztm->_mutex_peer); | ||
|
||
if (next_lease <= 0) { | ||
it = ztm->_peers; | ||
while (it != NULL) { | ||
_z_transport_peer_entry_t *entry = _z_transport_peer_entry_list_head(it); | ||
if (entry->_received == true) { | ||
// Reset the lease parameters | ||
entry->_received = false; | ||
entry->_next_lease = entry->_lease; | ||
it = _z_transport_peer_entry_list_tail(it); | ||
} else { | ||
_Z_INFO("Remove peer from know list because it has expired after %zums\n", entry->_lease); | ||
ztm->_peers = | ||
_z_transport_peer_entry_list_drop_filter(ztm->_peers, _z_transport_peer_entry_eq, entry); | ||
it = ztm->_peers; | ||
} | ||
} | ||
} | ||
|
||
if (next_join <= 0) { | ||
_zp_raweth_send_join(ztm); | ||
ztm->_transmitted = true; | ||
|
||
// Reset the join parameters | ||
next_join = Z_JOIN_INTERVAL; | ||
} | ||
|
||
if (next_keep_alive <= 0) { | ||
// Check if need to send a keep alive | ||
if (ztm->_transmitted == false) { | ||
if (_zp_raweth_send_keep_alive(ztm) < 0) { | ||
// TODO: Handle retransmission or error | ||
} | ||
} | ||
|
||
// Reset the keep alive parameters | ||
ztm->_transmitted = false; | ||
next_keep_alive = | ||
(_z_zint_t)(_z_get_minimum_lease(ztm->_peers, ztm->_lease) / Z_TRANSPORT_LEASE_EXPIRE_FACTOR); | ||
} | ||
|
||
// Compute the target interval to sleep | ||
_z_zint_t interval; | ||
if (next_lease > 0) { | ||
interval = next_lease; | ||
if (next_keep_alive < interval) { | ||
interval = next_keep_alive; | ||
} | ||
if (next_join < interval) { | ||
interval = next_join; | ||
} | ||
} else { | ||
interval = next_keep_alive; | ||
if (next_join < interval) { | ||
interval = next_join; | ||
} | ||
} | ||
|
||
_z_mutex_unlock(&ztm->_mutex_peer); | ||
|
||
// The keep alive and lease intervals are expressed in milliseconds | ||
z_sleep_ms(interval); | ||
|
||
// Decrement all intervals | ||
_z_mutex_lock(&ztm->_mutex_peer); | ||
|
||
it = ztm->_peers; | ||
while (it != NULL) { | ||
_z_transport_peer_entry_t *entry = _z_transport_peer_entry_list_head(it); | ||
entry->_next_lease = entry->_next_lease - interval; | ||
it = _z_transport_peer_entry_list_tail(it); | ||
} | ||
next_lease = _z_get_next_lease(ztm->_peers); | ||
next_keep_alive = next_keep_alive - interval; | ||
next_join = next_join - interval; | ||
|
||
_z_mutex_unlock(&ztm->_mutex_peer); | ||
} | ||
#endif // Z_FEATURE_MULTI_THREAD == 1 | ||
|
||
return 0; | ||
} | ||
#else | ||
int8_t _zp_raweth_send_keep_alive(_z_transport_multicast_t *ztm) { | ||
_ZP_UNUSED(ztm); | ||
return _Z_ERR_TRANSPORT_NOT_AVAILABLE; | ||
} | ||
|
||
int8_t _zp_raweth_start_lease_task(_z_transport_t *zt, _z_task_attr_t *attr, _z_task_t *task) { | ||
_ZP_UNUSED(zt); | ||
_ZP_UNUSED(attr); | ||
_ZP_UNUSED(task); | ||
return _Z_ERR_TRANSPORT_NOT_AVAILABLE; | ||
} | ||
|
||
int8_t _zp_raweth_stop_lease_task(_z_transport_t *zt) { | ||
_ZP_UNUSED(zt); | ||
return _Z_ERR_TRANSPORT_NOT_AVAILABLE; | ||
} | ||
|
||
void *_zp_raweth_lease_task(void *ztm_arg) { | ||
_ZP_UNUSED(ztm_arg); | ||
return NULL; | ||
} | ||
#endif // Z_FEATURE_RAWETH_TRANSPORT == 1 |
Oops, something went wrong.