2018-04-05 11:10:40 +02:00
|
|
|
/*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2019-03-26 21:56:05 +01:00
|
|
|
* @defgroup ble_skald Skald, who advertises to the world
|
|
|
|
* @ingroup ble
|
2018-04-05 11:10:40 +02:00
|
|
|
* @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+=-DSKALD_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 "xtimer.h"
|
|
|
|
#include "net/ble.h"
|
|
|
|
#include "net/netdev/ble.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Static advertising interval
|
|
|
|
*/
|
|
|
|
#ifndef SKALD_INTERVAL
|
|
|
|
#define SKALD_INTERVAL (1 * US_PER_SEC)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Static list of used 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 */
|
|
|
|
xtimer_t timer; /**< timer for scheduling advertising events */
|
|
|
|
uint32_t last; /**< last timer trigger (for offset compensation) */
|
|
|
|
uint8_t cur_chan; /**< keep track of advertising channels */
|
|
|
|
} 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 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 */
|
|
|
|
/** @} */
|