2018-02-28 14:50:58 +01:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2016, Nordic Semiconductor
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. Neither the name of the Institute nor the names of its contributors
|
|
|
|
* may be used to endorse or promote products derived from this software
|
|
|
|
* without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup pkg_nordic-softdevice-ble
|
|
|
|
* @brief Public API and definitions of Nordic Softdevice BLE
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2016-07-09 11:25:34 +02:00
|
|
|
#ifndef BLE_MAC_H
|
|
|
|
#define BLE_MAC_H
|
|
|
|
|
2018-02-28 14:50:58 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2016-07-09 11:25:34 +02:00
|
|
|
typedef enum {
|
|
|
|
BLE_EVENT_RX_DONE = 20000,
|
|
|
|
} ble_mac_event_enum_t;
|
|
|
|
|
|
|
|
#define BLE_IFACE_ADDED (10000)
|
|
|
|
|
|
|
|
#define BLE_SIXLOWPAN_MTU (1280U)
|
|
|
|
#define BLE_SIXLOWPAN_L2_ADDR_LEN (8)
|
|
|
|
|
|
|
|
#define IPV6_IID_FLIP_VALUE (0x02)
|
|
|
|
|
|
|
|
#include "net/eui64.h"
|
|
|
|
|
2018-02-28 14:50:58 +01:00
|
|
|
/**
|
|
|
|
* @brief Get BLE EUI64 from EUI48
|
|
|
|
*
|
|
|
|
* @param[out] eui64 The output EUI64 (8 bytes long)
|
|
|
|
* @param[in] eui48 The input EUI48 (6 bytes long)
|
|
|
|
* @param[in] _public True if public interface, false otherwise
|
|
|
|
*/
|
2016-07-09 11:25:34 +02:00
|
|
|
static inline void ble_eui64_from_eui48(uint8_t eui64[8], uint8_t eui48[6], int _public)
|
|
|
|
{
|
|
|
|
eui64[0] = eui48[5];
|
|
|
|
eui64[1] = eui48[4];
|
|
|
|
eui64[2] = eui48[3];
|
|
|
|
eui64[3] = 0xFF;
|
|
|
|
eui64[4] = 0xFE;
|
|
|
|
eui64[5] = eui48[2];
|
|
|
|
eui64[6] = eui48[1];
|
|
|
|
eui64[7] = eui48[0];
|
|
|
|
if (_public) {
|
|
|
|
eui64[0] &= ~(IPV6_IID_FLIP_VALUE);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
eui64[0] |= IPV6_IID_FLIP_VALUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-02-28 14:50:58 +01:00
|
|
|
/**
|
|
|
|
* @brief Structure handling a received BLE mac packet
|
|
|
|
*/
|
2016-07-09 11:25:34 +02:00
|
|
|
typedef struct {
|
2018-02-28 14:50:58 +01:00
|
|
|
uint8_t src[8]; /**< Source address of the packet */
|
|
|
|
uint8_t payload[BLE_SIXLOWPAN_MTU]; /**< Payload of the packet */
|
|
|
|
uint16_t len; /**< Length of the packet */
|
|
|
|
int8_t rssi; /**< RSSI of the received packet */
|
2016-07-09 11:25:34 +02:00
|
|
|
} ble_mac_inbuf_t;
|
|
|
|
|
2018-02-28 14:50:58 +01:00
|
|
|
/**
|
|
|
|
* @brief Mac event callback function definition
|
|
|
|
*/
|
2016-07-09 11:25:34 +02:00
|
|
|
typedef void (*ble_mac_callback_t)(ble_mac_event_enum_t event, void*arg);
|
2018-02-28 14:50:58 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize the BLE mac
|
|
|
|
*
|
|
|
|
* @param[in] callback The callback function triggered on mac event
|
|
|
|
*/
|
2016-07-09 11:25:34 +02:00
|
|
|
void ble_mac_init(ble_mac_callback_t callback);
|
2018-02-28 14:50:58 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Send a BLE message
|
|
|
|
*
|
|
|
|
* @param[in] dest The destination address
|
|
|
|
* @param[in] data The data to send
|
|
|
|
* @param[in] len The length of the data to send
|
|
|
|
*
|
|
|
|
* @return 0 if send is successful
|
|
|
|
* @return <0 if send failed
|
|
|
|
*/
|
2016-07-09 11:25:34 +02:00
|
|
|
int ble_mac_send(uint8_t dest[8], void *data, size_t len);
|
|
|
|
|
|
|
|
extern volatile int ble_mac_busy_tx; /**< Flag is set to 1 when the driver
|
|
|
|
is busy transmitting a packet. */
|
|
|
|
extern volatile int ble_mac_busy_rx; /**< Flag is set to 1 when there is a
|
|
|
|
received packet pending. */
|
2018-02-28 14:50:58 +01:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2016-07-09 11:25:34 +02:00
|
|
|
#endif /* BLE_MAC_H */
|
2018-02-28 14:50:58 +01:00
|
|
|
/** @} */
|