b19671e0d4
1. BLE Mesh Core * Provisioning: Node Role * PB-ADV and PB-GATT * Authentication OOB * Provisioning: Provisioner Role * PB-ADV and PB-GATT * Authentication OOB * Networking * Relay * Segmentation and Reassembly * Key Refresh * IV Update * Proxy Support * Multiple Client Models Run Simultaneously * Support multiple client models send packets to different nodes simultaneously * No blocking between client model and server * NVS Storage * Store BLE Mesh node related information in flash * Store BLE Mesh Provisioner related information in flash 2. BLE Mesh Models * Foundation Models * Configuration Server Model * Configuration Client Model * Health Server Model * Health Client Model * Generic * Generic OnOff Server * Generic OnOff Client * Generic Level Server * Generic Level Client * Generic Default Transition Time Server * Generic Default Transition Time Client * Generic Power OnOff Server * Generic Power OnOff Setup Server * Generic Power OnOff Client * Generic Power Level Server * Generic Power Level Setup Server * Generic Power Level Client * Generic Battery Server * Generic Battery Client * Generic Location Server * Generic Location Setup Server * Generic Location Client * Generic Admin Property Server * Generic Manufacturer Property Server * Generic User Property Server * Generic Client Property Server * Generic Property Client * Sensor Server Model * Sensor Server * Sensor Setup Server * Sensor Client * Time and Scenes * Time Server * Time Setup Server * Time Client * Scene Server * Scene Setup Server * Scene Client * Scheduler Server * Scheduler Setup Server * Scheduler Client * Lighting * Light Lightness Server * Light Lightness Setup Server * Light Lightness Client * Light CTL Server * Light CTL Setup Server * Light CTL Client * Light CTL Temperature Server * Light HSL Server * Light HSL Setup Server * Light HSL Client * Light HSL Hue Server * Light HSL Saturation Server * Light xyL Server * Light xyL Setup Server * Light xyL Client * Light LC Server * Light LC Setup Server * Light LC Client 3. BLE Mesh Applications * BLE Mesh Node * OnOff Client Example * OnOff Server Example * BLE Mesh Provisioner * Example * Fast Provisioning * Vendor Fast Prov Server Model * Vendor Fast Prov Client Model * Examples * Wi-Fi & BLE Mesh Coexistence * Example * BLE Mesh Console Commands * Examples
101 lines
2.8 KiB
C
101 lines
2.8 KiB
C
/* Bluetooth Mesh */
|
|
|
|
/*
|
|
* Copyright (c) 2017 Intel Corporation
|
|
* Additional Copyright (c) 2018 Espressif Systems (Shanghai) PTE LTD
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#ifndef _ADV_H_
|
|
#define _ADV_H_
|
|
|
|
#include "mesh_access.h"
|
|
#include "mesh_bearer_adapt.h"
|
|
|
|
/* Maximum advertising data payload for a single data type */
|
|
#define BLE_MESH_ADV_DATA_SIZE 29
|
|
|
|
/* The user data is a pointer (4 bytes) to struct bt_mesh_adv */
|
|
#define BLE_MESH_ADV_USER_DATA_SIZE 4
|
|
|
|
#define BLE_MESH_ADV(buf) (*(struct bt_mesh_adv **)net_buf_user_data(buf))
|
|
|
|
typedef struct bt_mesh_msg {
|
|
bool relay; /* Flag indicates if the packet is a relayed one */
|
|
void *arg; /* Pointer to the struct net_buf */
|
|
u16_t src; /* Source address for relay packets */
|
|
u16_t dst; /* Destination address for relay packets */
|
|
u32_t timestamp; /* Timestamp recorded when the relay packet is posted to queue */
|
|
} bt_mesh_msg_t;
|
|
|
|
enum bt_mesh_adv_type {
|
|
BLE_MESH_ADV_PROV,
|
|
BLE_MESH_ADV_DATA,
|
|
BLE_MESH_ADV_BEACON,
|
|
BLE_MESH_ADV_URI,
|
|
};
|
|
|
|
typedef void (*bt_mesh_adv_func_t)(struct net_buf *buf, u16_t duration,
|
|
int err, void *user_data);
|
|
|
|
struct bt_mesh_adv {
|
|
const struct bt_mesh_send_cb *cb;
|
|
void *cb_data;
|
|
|
|
u8_t type: 2,
|
|
busy: 1;
|
|
u8_t xmit;
|
|
|
|
/* For transport layer segment sending */
|
|
struct {
|
|
u8_t attempts;
|
|
} seg;
|
|
};
|
|
|
|
typedef struct bt_mesh_adv *(*bt_mesh_adv_alloc_t)(int id);
|
|
|
|
/* xmit_count: Number of retransmissions, i.e. 0 == 1 transmission */
|
|
struct net_buf *bt_mesh_adv_create(enum bt_mesh_adv_type type, u8_t xmit,
|
|
s32_t timeout);
|
|
|
|
typedef enum {
|
|
BLE_MESH_BUF_REF_EQUAL,
|
|
BLE_MESH_BUF_REF_SMALL,
|
|
BLE_MESH_BUF_REF_MAX,
|
|
} bt_mesh_buf_ref_flag_t;
|
|
|
|
void bt_mesh_adv_buf_ref_debug(const char *func, struct net_buf *buf,
|
|
u8_t ref_cmp, bt_mesh_buf_ref_flag_t flag);
|
|
|
|
struct net_buf *bt_mesh_adv_create_from_pool(struct net_buf_pool *pool,
|
|
bt_mesh_adv_alloc_t get_id,
|
|
enum bt_mesh_adv_type type,
|
|
u8_t xmit, s32_t timeout);
|
|
|
|
void bt_mesh_unref_buf_from_pool(struct net_buf_pool *pool);
|
|
|
|
void bt_mesh_adv_send(struct net_buf *buf, const struct bt_mesh_send_cb *cb,
|
|
void *cb_data);
|
|
|
|
const bt_mesh_addr_t *bt_mesh_pba_get_addr(void);
|
|
|
|
struct net_buf *bt_mesh_relay_adv_create(enum bt_mesh_adv_type type, u8_t xmit,
|
|
s32_t timeout);
|
|
|
|
void bt_mesh_relay_adv_send(struct net_buf *buf, const struct bt_mesh_send_cb *cb,
|
|
void *cb_data, u16_t src, u16_t dst);
|
|
|
|
u16_t bt_mesh_get_stored_relay_count(void);
|
|
|
|
void bt_mesh_adv_update(void);
|
|
|
|
void bt_mesh_adv_init(void);
|
|
void bt_mesh_adv_deinit(void);
|
|
|
|
int bt_mesh_scan_enable(void);
|
|
|
|
int bt_mesh_scan_disable(void);
|
|
|
|
#endif /* _ADV_H_ */
|