1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 08:32:43 +01:00
RIOT/sys/include/net/skald.h
2022-05-24 13:02:10 +02:00

119 lines
3.1 KiB
C

/*
* Copyright (C) 2018 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 ble_skald Skald, who advertises to the world
* @ingroup ble
* @brief Skald, a minimalistic BLE advertising stack
*
* # About
*
* Skald is a very minimalistic BLE implementation, implementing the
* `broadcaster` role only. With this focus, the stack allows for setting up
* different kind of beacons using an extremely low memory footprint.
*
* # Design Decisions and Limitations
* - support for local addresses only (using `luid` to generate them)
* - advertising interval is configured during compile time, override by setting
* `CFLAGS+=-DCONFIG_SKALD_INTERVAL=xxx`
* - advertising channels are configured during compile time, override by
* setting `CFLAGS+=-DSKALD_ADV_CHAN={37,39}`
*
* # Implementation state
* Supported:
* - advertising of custom GAP payloads
* - iBeacon (full support)
* - Eddystone (partly supported)
*
* Limitations:
* - currently Skald supports random static addresses only (generated using
* the `luid` module)
*
* @{
* @file
* @brief Skald's basic interface
*
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
*/
#ifndef NET_SKALD_H
#define NET_SKALD_H
#include <stdint.h>
#include "ztimer.h"
#include "net/ble.h"
#include "net/netdev/ble.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief List of advertising channels
*/
#ifndef SKALD_ADV_CHAN
#define SKALD_ADV_CHAN { 37, 38, 39 }
#endif
/**
* @brief UUID representation format used by Skald
*/
typedef struct {
uint8_t u8[16]; /**< UUID with byte-wise access */
} skald_uuid_t;
/**
* @brief Advertising context holding the advertising data and state
*/
typedef struct {
netdev_ble_pkt_t pkt; /**< packet holding the advertisement (GAP) data */
ztimer_t timer; /**< timer for scheduling advertising events */
ztimer_now_t last; /**< last timer trigger (for offset compensation) */
uint8_t cur_chan; /**< keep track of advertising channels */
uint32_t adv_itvl_ms; /**< advertising interval [ms] */
} skald_ctx_t;
/**
* @brief Initialize Skald and the underlying radio
*/
void skald_init(void);
/**
* @brief Start advertising the given packet
*
* The packet will be send out each advertising interval (see CONFIG_SKALD_INTERVAL) on
* each of the defined advertising channels (see SKALD_ADV_CHAN).
*
* @param[in,out] ctx start advertising this context
*/
void skald_adv_start(skald_ctx_t *ctx);
/**
* @brief Stop the ongoing advertisement
*
* @param[in,out] ctx stop advertising this context
*/
void skald_adv_stop(skald_ctx_t *ctx);
/**
* @brief Generate a random public address
*
* @note @p buf must be able to hold BLE_ADDR_LEN (6) bytes
*
* @param[out] buf the generated address is written to this buffer
*/
void skald_generate_random_addr(uint8_t *buf);
#ifdef __cplusplus
}
#endif
#endif /* NET_SKALD_H */
/** @} */