1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 08:32:43 +01:00
RIOT/pkg/nimble/statconn/include/nimble_statconn.h
2022-01-27 10:30:29 +01:00

198 lines
5.9 KiB
C

/*
* Copyright (C) 2020 Freie Universität Berlin
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @defgroup pkg_nimble_statconn Statconn
* @ingroup pkg_nimble
* @brief Static connection manager for NimBLE netif that keeps opens
* connections on demand and takes care of keeping them open.
*
* @experimental
*
* # WARNING
* This module is highly experimental! Expect bugs, instabilities and sudden API
* changes :-)
*
*
* # About
* Statconn is the implementation of a static connection manager for the NimBLE
* netif module. It initiates new connections when told and additionally takes
* care of reopening connections in case of connection loss.
*
*
* # Usage
* A node can either be a master, the one initiating the connection, or a
* slave, the one advertising its presence, w.r.t. to BLE connections. To open
* a connection between two nodes, call nimble_statconn_add_slave() with the
* BLE address of the slave node on the designated master node and call
* nimble_statconn_add_master() with the address of the master node on the
* designated slave node. From that point on, statconn will take care of
* opening and maintaining the connection between these two nodes.
*
*
* # Configuration
* This module is configured completely statically. All relevant configuration
* options are set at compile time using a couple of macros.
*
* @{
*
* @file
* @brief Simple static connection manager for NimBLE netif
*
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
*/
#ifndef NIMBLE_STATCONN_H
#define NIMBLE_STATCONN_H
#include <errno.h>
#include <stdint.h>
#include "nimble_netif.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief Advertising interval used when in advertising mode [in ms]
*/
#ifndef NIMBLE_STATCONN_ADV_ITVL_MS
#define NIMBLE_STATCONN_ADV_ITVL_MS (90U)
#endif
/**
* @brief Scan window used when opening new connections [in ms]
*/
#ifndef NIMBLE_STATCONN_CONN_WIN_MS
#define NIMBLE_STATCONN_CONN_WIN_MS (100U)
#endif
/**
* @brief Opening a new connection is aborted after this time [in ms]
*/
#ifndef NIMBLE_STATCONN_CONN_TIMEOUT_MS
#define NIMBLE_STATCONN_CONN_TIMEOUT_MS (600U)
#endif
/**
* @brief Minimum connection interval used when opening a new connection. The
* actual used connection interval will be a random value ranging from
* @ref NIMBLE_STATCONN_CONN_ITVL_MIN_MS to
* @ref NIMBLE_STATCONN_CONN_ITVL_MAX_MS. Set both variables to the same
* value to use a fixed connection interval. [in ms]
*/
#ifndef NIMBLE_STATCONN_CONN_ITVL_MIN_MS
#define NIMBLE_STATCONN_CONN_ITVL_MIN_MS (75U)
#endif
/**
* @brief Maximum connection interval to use. See
* @ref NIMBLE_STATCONN_CONN_ITVL_MIN_MS for more information. [in ms]
*/
#ifndef NIMBLE_STATCONN_CONN_ITVL_MAX_MS
#define NIMBLE_STATCONN_CONN_ITVL_MAX_MS (75U)
#endif
/**
* @brief Slave latency used for new connections [# of connection events]
*/
#ifndef NIMBLE_STATCONN_CONN_LATENCY
#define NIMBLE_STATCONN_CONN_LATENCY (0)
#endif
/**
* @brief Supervision timeout used for new connections [in ms]
*/
#ifndef NIMBLE_STATCONN_CONN_SUPERTO_MS
#define NIMBLE_STATCONN_CONN_SUPERTO_MS (2500U)
#endif
/**
* @brief BLE PHY mode used by statconn. This value is only used if statconn
* is used in its extended mode (module `nimble_statconn_ext`)
*/
#ifndef NIMBLE_STATCONN_PHY_MODE
#define NIMBLE_STATCONN_PHY_MODE NIMBLE_PHY_1M
#endif
/**
* @brief Statconn connection parameters
*/
typedef struct {
nimble_phy_t phy_mode; /**< BLE PHY mode used for the connection */
} nimble_statconn_cfg_t;
/**
* @brief Initialize the statconn module
*
* @warning This function **must** only be called once. Typically this is done
* during system initialization via auto-init.
*/
void nimble_statconn_init(void);
/**
* @brief Register a callback that is called on netif events
*
* The registered callback function is a simple pass-through of nimble_netif
* events. The callback is executed in the context of NimBLE's host thread.
*
* @param[in] cb event callback to register, may be NULL
*/
void nimble_statconn_eventcb(nimble_netif_eventcb_t cb);
/**
* @brief Connect to peer (master) with a given address as slave
*
* Adding a master will make this node advertise itself to wait for an incoming
* connection by that master.
*
* @param[in] addr BLE address of the peer
* @param[in] cfg additional connection parameters, set to NULL to apply
* default values
*
* @return 0 if peer was successfully added
* @return -EALREADY if the peer address is already in use
* @return -ENOMEM if no empty connection slot is available
* @return -EINVAL if invalid configuration parameters are given
*/
int nimble_statconn_add_master(const uint8_t *addr,
const nimble_statconn_cfg_t *cfg);
/**
* @brief Connect to a peer (slave) with a given address as master
*
* @param[in] addr BLE address of the peer
* @param[in] cfg additional connection parameters, set to NULL to apply
* default values
*
* @return 0 if peer was successfully added
* @return -EALREADY if the peer address is already in use
* @return -ENOMEM if no empty connection slot is available
* @return -EINVAL if invalid configuration parameters are given
*/
int nimble_statconn_add_slave(const uint8_t *addr,
const nimble_statconn_cfg_t *cfg);
/**
* @brief Remove the connection to the given peer
*
* @param[in] addr BLE address of the peer
*
* @return 0 if peer was successfully removed
* @return -ENOTCONN if given address is not managed
*/
int nimble_statconn_rm(const uint8_t *addr);
#ifdef __cplusplus
}
#endif
#endif /* NIMBLE_STATCONN_H */
/** @} */