mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 22:33:03 +01:00
fb3860dd05
These fields can be omitted if all other FLAGS are 0 and the advertising packets is not connectable, allowing for 3 extra bytes for advertisement payload. Co-authored-by: Roudy Dagher <roudy.dagher@inria.fr>
154 lines
4.9 KiB
C
154 lines
4.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_autoadv Automated advertising
|
|
* @ingroup pkg_nimble
|
|
*
|
|
* @brief Module for automated bluetooth advertising. Advertising is
|
|
* restarted on disconnect events automatically. Defaults to the
|
|
* following characteristics:
|
|
* - General discoverable mode (BLE_GAP_DISC_MODE_GEN)
|
|
* - Undirected connectable mode (BLE_GAP_CONN_MODE_UND)
|
|
* - No expiration (BLE_HS_FOREVER)
|
|
* - No name
|
|
*
|
|
* @{
|
|
*
|
|
* @file
|
|
*
|
|
* @author Hendrik van Essen <hendrik.ve@fu-berlin.de>
|
|
*/
|
|
|
|
#ifndef NIMBLE_AUTOADV_H
|
|
#define NIMBLE_AUTOADV_H
|
|
|
|
#include "host/ble_gap.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Name of the device for the advertising procedure. If this is not
|
|
* defined, it will be defined as NULL, resulting in not configuring
|
|
* a name at all.
|
|
*/
|
|
#ifndef NIMBLE_AUTOADV_DEVICE_NAME
|
|
#define NIMBLE_AUTOADV_DEVICE_NAME NULL
|
|
#endif
|
|
|
|
/**
|
|
* @brief If an application is calling functions from nimble, e.g.
|
|
* ble_svc_gap_device_name_set(), NIMBLE_AUTOADV_START_MANUALLY should
|
|
* be set to 1 and then the application should call
|
|
* nimble_autoadv_start() after all of its nimble calls to prevent
|
|
* errors like BLE_HS_EBUSY.
|
|
*
|
|
* Defined as 0 by default.
|
|
*/
|
|
#ifndef NIMBLE_AUTOADV_START_MANUALLY
|
|
#define NIMBLE_AUTOADV_START_MANUALLY 0
|
|
#endif
|
|
|
|
/**
|
|
* @brief Include the advetisement flag field. If this is not
|
|
* defined, it will be defined as 1, resulting in including the field.
|
|
* The Flags data type shall be included when any of the Flag bits
|
|
* are non-zero and the advertising packet is connectable, otherwise
|
|
* the Flags data type may be omitted.
|
|
*/
|
|
#ifndef NIMBLE_AUTOADV_FLAG_FIELD
|
|
#define NIMBLE_AUTOADV_FLAG_FIELD 1
|
|
#endif
|
|
|
|
/**
|
|
* @brief Initialize autoadv module.
|
|
*/
|
|
void nimble_autoadv_init(void);
|
|
|
|
/**
|
|
* @brief Set struct for additional arguments specifying the particulars of
|
|
* the advertising procedure. Uses memcpy internally.
|
|
*
|
|
* If there is an active advertising process, it will be restarted.
|
|
*
|
|
* @param[in] params struct with customized additional arguments
|
|
*/
|
|
void nimble_autoadv_set_ble_gap_adv_params(struct ble_gap_adv_params *params);
|
|
|
|
/**
|
|
* @brief Add a new field to the given advertising data.
|
|
*
|
|
* If there is an active advertising process, it will be restarted.
|
|
*
|
|
* @param[in] type field type to add
|
|
* @param[in] data payload for the field
|
|
* @param[in] data_len length of the payload in bytes
|
|
*
|
|
* @return BLUETIL_AD_OK if the new field was added
|
|
* @return BLUETIL_AD_NOMEM if there is not enough space to write add field
|
|
*/
|
|
int nimble_autoadv_add_field(uint8_t type, const void *data, size_t data_len);
|
|
|
|
/**
|
|
* @brief Set the duration for the advertising procedure.
|
|
*
|
|
* If there is an active advertising process, it will be restarted.
|
|
*
|
|
* @param[in] duration_ms duration of advertising procedure in ms
|
|
*/
|
|
void nimble_auto_adv_set_adv_duration(int32_t duration_ms);
|
|
|
|
/**
|
|
* @brief Set the callback for gap events. Callback is used for the logic when
|
|
* to start the advertising procedure.
|
|
*
|
|
* If there is an active advertising process, it will be restarted.
|
|
*
|
|
* @param[in] cb The callback to associate with this advertising
|
|
* procedure. If advertising ends, the event is reported
|
|
* through this callback. If advertising results in a
|
|
* connection, the connection inherits this callback as its
|
|
* event-reporting mechanism.
|
|
*
|
|
* @param[in] cb_arg The optional argument to pass to the callback function.
|
|
*/
|
|
void nimble_auto_adv_set_gap_cb(ble_gap_event_fn *cb, void *cb_arg);
|
|
|
|
/**
|
|
* @brief Start the automated advertising procedure.
|
|
*
|
|
* Needs to be called manually when NIMBLE_AUTOADV_START_MANUALLY was
|
|
* set to true and after every call of nimble_autoadv_stop() to start
|
|
* advertising again.
|
|
*/
|
|
void nimble_autoadv_start(void);
|
|
|
|
/**
|
|
* @brief Stop the automated advertising procedure. After calling this, you
|
|
* have to call nimble_autoadv_start() manually to restart the process.
|
|
*/
|
|
void nimble_autoadv_stop(void);
|
|
|
|
/**
|
|
* @brief Reset all data regarding the advertising process.
|
|
* Following characteristics will be applied:
|
|
* - General discoverable mode (BLE_GAP_DISC_MODE_GEN)
|
|
* - Undirected connectable mode (BLE_GAP_CONN_MODE_UND)
|
|
* - No expiration (BLE_HS_FOREVER)
|
|
* - No name
|
|
*/
|
|
void nimble_autoadv_reset(void);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
/** @} */
|
|
#endif /* NIMBLE_AUTOADV_H */
|