mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-02-28 16:11:24 +00:00
mesh: move Model To AppKey List to Mesh Access
This commit is contained in:
parent
df02743e80
commit
669135eb20
@ -94,8 +94,6 @@ static btstack_packet_callback_registration_t hci_event_callback_registration;
|
||||
|
||||
static void packet_handler (uint8_t packet_type, uint16_t channel, uint8_t *packet, uint16_t size);
|
||||
|
||||
static void mesh_delete_appkey_lists(void);
|
||||
|
||||
static uint8_t mesh_flags;
|
||||
|
||||
static uint16_t pb_transport_cid = MESH_PB_TRANSPORT_INVALID_CID;
|
||||
@ -941,10 +939,6 @@ const mesh_access_message_t mesh_foundation_config_heartbeat_subscription_status
|
||||
MESH_FOUNDATION_OPERATION_HEARTBEAT_SUBSCRIPTION_STATUS, "1221111"
|
||||
};
|
||||
|
||||
// to sort
|
||||
|
||||
#define MESH_APPKEY_INVALID 0xffffu
|
||||
|
||||
typedef enum {
|
||||
MESH_NODE_IDENTITY_STATE_ADVERTISING_STOPPED = 0,
|
||||
MESH_NODE_IDENTITY_STATE_ADVERTISING_RUNNING,
|
||||
@ -982,86 +976,6 @@ typedef struct {
|
||||
static mesh_heartbeat_publication_t mesh_heartbeat_publication;
|
||||
static mesh_heartbeat_subscription_t mesh_heartbeat_subscription;
|
||||
|
||||
// model to appkey list/binding
|
||||
|
||||
#define MESH_MODEL_INDEX_MAX (16)
|
||||
|
||||
static uint32_t mesh_model_tag_for_index(uint16_t internal_model_id){
|
||||
return ((uint32_t) 'M' << 24) | ((uint32_t) 'B' << 16) | ((uint32_t) internal_model_id);
|
||||
}
|
||||
|
||||
static void mesh_load_appkey_list(mesh_model_t * model){
|
||||
uint32_t tag = mesh_model_tag_for_index(model->mid);
|
||||
btstack_tlv_singleton_impl->store_tag(btstack_tlv_singleton_context, tag, (uint8_t *) &model->appkey_indices, sizeof(model->appkey_indices));
|
||||
}
|
||||
|
||||
static void mesh_store_appkey_list(mesh_model_t * model){
|
||||
if (model->mid >= MESH_MODEL_INDEX_MAX){
|
||||
printf("Warning: Model with internal model id %x (>= %u) are not persisted\n", model->mid, MESH_MODEL_INDEX_MAX);
|
||||
}
|
||||
|
||||
uint32_t tag = mesh_model_tag_for_index(model->mid);
|
||||
btstack_tlv_singleton_impl->get_tag(btstack_tlv_singleton_context, tag, (uint8_t *) &model->appkey_indices, sizeof(model->appkey_indices));
|
||||
}
|
||||
|
||||
static void mesh_load_appkey_lists(void){
|
||||
printf("Load Appkey Lists\n");
|
||||
// iterate over elements and models
|
||||
mesh_element_iterator_t element_it;
|
||||
mesh_element_iterator_init(&element_it);
|
||||
while (mesh_element_iterator_has_next(&element_it)){
|
||||
mesh_element_t * element = mesh_element_iterator_next(&element_it);
|
||||
mesh_model_iterator_t model_it;
|
||||
mesh_model_iterator_init(&model_it, element);
|
||||
while (mesh_model_iterator_has_next(&model_it)){
|
||||
mesh_model_t * model = mesh_model_iterator_next(&model_it);
|
||||
mesh_load_appkey_list(model);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static void mesh_delete_appkey_lists(void){
|
||||
printf("Delete App Keys\n");
|
||||
// iterate over elements and models
|
||||
uint16_t internal_model_id;
|
||||
for (internal_model_id = 0; internal_model_id < MESH_MODEL_INDEX_MAX; internal_model_id++){
|
||||
uint32_t tag = mesh_model_tag_for_index(internal_model_id);
|
||||
btstack_tlv_singleton_impl->delete_tag(btstack_tlv_singleton_context, tag);
|
||||
}
|
||||
}
|
||||
|
||||
static void mesh_model_reset_appkeys(mesh_model_t * mesh_model){
|
||||
int i;
|
||||
for (i=0;i<MAX_NR_MESH_APPKEYS_PER_MODEL;i++){
|
||||
mesh_model->appkey_indices[i] = MESH_APPKEY_INVALID;
|
||||
}
|
||||
}
|
||||
|
||||
static uint8_t mesh_model_bind_appkey(mesh_model_t * mesh_model, uint16_t appkey_index){
|
||||
int i;
|
||||
for (i=0;i<MAX_NR_MESH_APPKEYS_PER_MODEL;i++){
|
||||
if (mesh_model->appkey_indices[i] == appkey_index) return MESH_FOUNDATION_STATUS_SUCCESS;
|
||||
}
|
||||
for (i=0;i<MAX_NR_MESH_APPKEYS_PER_MODEL;i++){
|
||||
if (mesh_model->appkey_indices[i] == MESH_APPKEY_INVALID) {
|
||||
mesh_model->appkey_indices[i] = appkey_index;
|
||||
mesh_store_appkey_list(mesh_model);
|
||||
return MESH_FOUNDATION_STATUS_SUCCESS;
|
||||
}
|
||||
}
|
||||
return MESH_FOUNDATION_STATUS_INSUFFICIENT_RESOURCES;
|
||||
}
|
||||
|
||||
static void mesh_model_unbind_appkey(mesh_model_t * mesh_model, uint16_t appkey_index){
|
||||
int i;
|
||||
for (i=0;i<MAX_NR_MESH_APPKEYS_PER_MODEL;i++){
|
||||
if (mesh_model->appkey_indices[i] == appkey_index) {
|
||||
mesh_model->appkey_indices[i] = MESH_APPKEY_INVALID;
|
||||
mesh_store_appkey_list(mesh_model);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static int mesh_model_is_configuration_server(uint32_t model_identifier){
|
||||
return mesh_model_is_bluetooth_sig(model_identifier) && (mesh_model_get_model_id(model_identifier) == MESH_SIG_MODEL_ID_CONFIGURATION_SERVER);
|
||||
}
|
||||
|
@ -46,6 +46,7 @@
|
||||
#include "bluetooth_company_id.h"
|
||||
#include "mesh_transport.h"
|
||||
#include "mesh_foundation.h"
|
||||
#include "btstack_tlv.h"
|
||||
|
||||
static void mesh_access_message_process_handler(mesh_pdu_t * pdu);
|
||||
|
||||
@ -55,6 +56,14 @@ static btstack_linked_list_t mesh_elements;
|
||||
|
||||
static uint16_t mid_counter;
|
||||
|
||||
static const btstack_tlv_t * btstack_tlv_singleton_impl;
|
||||
static void * btstack_tlv_singleton_context;
|
||||
|
||||
static void mesh_access_setup_tlv(void){
|
||||
if (btstack_tlv_singleton_impl) return;
|
||||
btstack_tlv_get_instance(&btstack_tlv_singleton_impl, &btstack_tlv_singleton_context);
|
||||
}
|
||||
|
||||
void mesh_access_init(void){
|
||||
// Access layer - add Primary Element to list of elements
|
||||
mesh_element_add(&primary_element);
|
||||
@ -639,3 +648,88 @@ int mesh_model_contains_subscription(mesh_model_t * mesh_model, uint16_t address
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
// Model to Appkey List
|
||||
|
||||
#define MESH_MODEL_INDEX_MAX (16)
|
||||
|
||||
static uint32_t mesh_model_tag_for_index(uint16_t internal_model_id){
|
||||
return ((uint32_t) 'M' << 24) | ((uint32_t) 'B' << 16) | ((uint32_t) internal_model_id);
|
||||
}
|
||||
|
||||
static void mesh_load_appkey_list(mesh_model_t * model){
|
||||
mesh_access_setup_tlv();
|
||||
uint32_t tag = mesh_model_tag_for_index(model->mid);
|
||||
btstack_tlv_singleton_impl->store_tag(btstack_tlv_singleton_context, tag, (uint8_t *) &model->appkey_indices, sizeof(model->appkey_indices));
|
||||
}
|
||||
|
||||
static void mesh_store_appkey_list(mesh_model_t * model){
|
||||
mesh_access_setup_tlv();
|
||||
|
||||
if (model->mid >= MESH_MODEL_INDEX_MAX){
|
||||
printf("Warning: Model with internal model id %x (>= %u) are not persisted\n", model->mid, MESH_MODEL_INDEX_MAX);
|
||||
}
|
||||
|
||||
uint32_t tag = mesh_model_tag_for_index(model->mid);
|
||||
btstack_tlv_singleton_impl->get_tag(btstack_tlv_singleton_context, tag, (uint8_t *) &model->appkey_indices, sizeof(model->appkey_indices));
|
||||
}
|
||||
|
||||
void mesh_load_appkey_lists(void){
|
||||
printf("Load Appkey Lists\n");
|
||||
// iterate over elements and models
|
||||
mesh_element_iterator_t element_it;
|
||||
mesh_element_iterator_init(&element_it);
|
||||
while (mesh_element_iterator_has_next(&element_it)){
|
||||
mesh_element_t * element = mesh_element_iterator_next(&element_it);
|
||||
mesh_model_iterator_t model_it;
|
||||
mesh_model_iterator_init(&model_it, element);
|
||||
while (mesh_model_iterator_has_next(&model_it)){
|
||||
mesh_model_t * model = mesh_model_iterator_next(&model_it);
|
||||
mesh_load_appkey_list(model);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void mesh_delete_appkey_lists(void){
|
||||
printf("Delete App Keys\n");
|
||||
mesh_access_setup_tlv();
|
||||
// iterate over elements and models
|
||||
uint16_t internal_model_id;
|
||||
for (internal_model_id = 0; internal_model_id < MESH_MODEL_INDEX_MAX; internal_model_id++){
|
||||
uint32_t tag = mesh_model_tag_for_index(internal_model_id);
|
||||
btstack_tlv_singleton_impl->delete_tag(btstack_tlv_singleton_context, tag);
|
||||
}
|
||||
}
|
||||
|
||||
void mesh_model_reset_appkeys(mesh_model_t * mesh_model){
|
||||
int i;
|
||||
for (i=0;i<MAX_NR_MESH_APPKEYS_PER_MODEL;i++){
|
||||
mesh_model->appkey_indices[i] = MESH_APPKEY_INVALID;
|
||||
}
|
||||
}
|
||||
|
||||
uint8_t mesh_model_bind_appkey(mesh_model_t * mesh_model, uint16_t appkey_index){
|
||||
int i;
|
||||
for (i=0;i<MAX_NR_MESH_APPKEYS_PER_MODEL;i++){
|
||||
if (mesh_model->appkey_indices[i] == appkey_index) return MESH_FOUNDATION_STATUS_SUCCESS;
|
||||
}
|
||||
for (i=0;i<MAX_NR_MESH_APPKEYS_PER_MODEL;i++){
|
||||
if (mesh_model->appkey_indices[i] == MESH_APPKEY_INVALID) {
|
||||
mesh_model->appkey_indices[i] = appkey_index;
|
||||
mesh_store_appkey_list(mesh_model);
|
||||
return MESH_FOUNDATION_STATUS_SUCCESS;
|
||||
}
|
||||
}
|
||||
return MESH_FOUNDATION_STATUS_INSUFFICIENT_RESOURCES;
|
||||
}
|
||||
|
||||
void mesh_model_unbind_appkey(mesh_model_t * mesh_model, uint16_t appkey_index){
|
||||
int i;
|
||||
for (i=0;i<MAX_NR_MESH_APPKEYS_PER_MODEL;i++){
|
||||
if (mesh_model->appkey_indices[i] == appkey_index) {
|
||||
mesh_model->appkey_indices[i] = MESH_APPKEY_INVALID;
|
||||
mesh_store_appkey_list(mesh_model);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -50,6 +50,8 @@ extern "C"
|
||||
#define MAX_NR_MESH_APPKEYS_PER_MODEL 3u
|
||||
#define MAX_NR_MESH_SUBSCRIPTION_PER_MODEL 3u
|
||||
|
||||
#define MESH_APPKEY_INVALID 0xffffu
|
||||
|
||||
typedef struct {
|
||||
uint16_t address;
|
||||
uint16_t appkey_index;
|
||||
@ -191,6 +193,13 @@ uint8_t mesh_model_overwrite_subscription(mesh_model_t * mesh_model, uint16_t ad
|
||||
void mesh_model_delete_all_subscriptions(mesh_model_t * mesh_model);
|
||||
int mesh_model_contains_subscription(mesh_model_t * mesh_model, uint16_t address);
|
||||
|
||||
// Mesh Model to Appkey List
|
||||
void mesh_load_appkey_lists(void);
|
||||
void mesh_delete_appkey_lists(void);
|
||||
void mesh_model_reset_appkeys(mesh_model_t * mesh_model);
|
||||
uint8_t mesh_model_bind_appkey(mesh_model_t * mesh_model, uint16_t appkey_index);
|
||||
void mesh_model_unbind_appkey(mesh_model_t * mesh_model, uint16_t appkey_index);
|
||||
|
||||
// Mesh Access Parser
|
||||
int mesh_access_pdu_get_opcode(mesh_pdu_t * pdu, uint32_t * opcode, uint16_t * opcode_size);
|
||||
int mesh_access_parser_init(mesh_access_parser_state_t * state, mesh_pdu_t * pdu);
|
||||
|
Loading…
x
Reference in New Issue
Block a user