mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-04-16 08:42:28 +00:00
mesh: add new keys at end of key list, add key_refresh field
This commit is contained in:
parent
02b5f73ab5
commit
01496892a1
@ -57,7 +57,7 @@ void mesh_network_key_init(void){
|
|||||||
}
|
}
|
||||||
|
|
||||||
void mesh_network_key_add(mesh_network_key_t * network_key){
|
void mesh_network_key_add(mesh_network_key_t * network_key){
|
||||||
btstack_linked_list_add(&network_keys, (btstack_linked_item_t *) network_key);
|
btstack_linked_list_add_tail(&network_keys, (btstack_linked_item_t *) network_key);
|
||||||
}
|
}
|
||||||
|
|
||||||
int mesh_network_key_remove(mesh_network_key_t * network_key){
|
int mesh_network_key_remove(mesh_network_key_t * network_key){
|
||||||
@ -163,7 +163,7 @@ void mesh_transport_set_device_key(const uint8_t * device_key){
|
|||||||
}
|
}
|
||||||
|
|
||||||
void mesh_transport_key_add(mesh_transport_key_t * transport_key){
|
void mesh_transport_key_add(mesh_transport_key_t * transport_key){
|
||||||
btstack_linked_list_add(&application_keys, (btstack_linked_item_t *) transport_key);
|
btstack_linked_list_add_tail(&application_keys, (btstack_linked_item_t *) transport_key);
|
||||||
}
|
}
|
||||||
|
|
||||||
int mesh_transport_key_remove(mesh_transport_key_t * transport_key){
|
int mesh_transport_key_remove(mesh_transport_key_t * transport_key){
|
||||||
|
@ -64,13 +64,17 @@ typedef struct {
|
|||||||
uint8_t identity_key[16];
|
uint8_t identity_key[16];
|
||||||
uint8_t beacon_key[16];
|
uint8_t beacon_key[16];
|
||||||
|
|
||||||
|
// k3
|
||||||
|
uint8_t network_id[8];
|
||||||
|
|
||||||
// k2
|
// k2
|
||||||
uint8_t nid;
|
uint8_t nid;
|
||||||
uint8_t encryption_key[16];
|
uint8_t encryption_key[16];
|
||||||
uint8_t privacy_key[16];
|
uint8_t privacy_key[16];
|
||||||
|
|
||||||
// k3
|
// key refresth
|
||||||
uint8_t network_id[8];
|
uint8_t key_refresh;
|
||||||
|
|
||||||
} mesh_network_key_t;
|
} mesh_network_key_t;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
@ -96,6 +100,10 @@ typedef struct {
|
|||||||
|
|
||||||
// application key hash id
|
// application key hash id
|
||||||
uint8_t aid;
|
uint8_t aid;
|
||||||
|
|
||||||
|
// key refresth
|
||||||
|
uint8_t key_refresh;
|
||||||
|
|
||||||
} mesh_transport_key_t;
|
} mesh_transport_key_t;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
@ -152,14 +160,14 @@ void mesh_network_key_list_add_from_provisioning_data(const mesh_provisioning_da
|
|||||||
void mesh_network_key_iterator_init(mesh_network_key_iterator_t *it);
|
void mesh_network_key_iterator_init(mesh_network_key_iterator_t *it);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check if another network_key is available
|
* @brief Check if another network_key is available
|
||||||
* @param it
|
* @param it
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
int mesh_network_key_iterator_has_more(mesh_network_key_iterator_t *it);
|
int mesh_network_key_iterator_has_more(mesh_network_key_iterator_t *it);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get net network_key
|
* @brief Get net network_key
|
||||||
* @param it
|
* @param it
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
@ -173,14 +181,14 @@ mesh_network_key_t * mesh_network_key_iterator_get_next(mesh_network_key_iterato
|
|||||||
void mesh_network_key_nid_iterator_init(mesh_network_key_iterator_t *it, uint8_t nid);
|
void mesh_network_key_nid_iterator_init(mesh_network_key_iterator_t *it, uint8_t nid);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check if another network_key with given NID is available
|
* @brief Check if another network_key with given NID is available
|
||||||
* @param it
|
* @param it
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
int mesh_network_key_nid_iterator_has_more(mesh_network_key_iterator_t *it);
|
int mesh_network_key_nid_iterator_has_more(mesh_network_key_iterator_t *it);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get next network_key with given NID
|
* @brief Get next network_key with given NID
|
||||||
* @param it
|
* @param it
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
@ -191,20 +199,20 @@ mesh_network_key_t * mesh_network_key_nid_iterator_get_next(mesh_network_key_ite
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set device key
|
* @brief Set device key
|
||||||
* @param device_key
|
* @param device_key
|
||||||
*/
|
*/
|
||||||
void mesh_transport_set_device_key(const uint8_t * device_key);
|
void mesh_transport_set_device_key(const uint8_t * device_key);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Add network key to list
|
* @brief Add application key to list
|
||||||
* @param application key
|
* @param application key
|
||||||
* @note AID needs to be set
|
* @note AID needs to be set
|
||||||
*/
|
*/
|
||||||
void mesh_transport_key_add(mesh_transport_key_t * transport_key);
|
void mesh_transport_key_add(mesh_transport_key_t * transport_key);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Remove network key from list
|
* @brief Remove application key from list
|
||||||
* @param application key
|
* @param application key
|
||||||
* @return 0 if removed
|
* @return 0 if removed
|
||||||
* @note key is only removed from list, memory is not released
|
* @note key is only removed from list, memory is not released
|
||||||
@ -226,21 +234,21 @@ mesh_transport_key_t * mesh_transport_key_get(uint16_t appkey_index);
|
|||||||
void mesh_transport_key_iterator_init(mesh_transport_key_iterator_t *it, uint16_t netkey_index);
|
void mesh_transport_key_iterator_init(mesh_transport_key_iterator_t *it, uint16_t netkey_index);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check if another transport key (AppKey) is available
|
* @brief Check if another transport key (AppKey) is available
|
||||||
* @param it
|
* @param it
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
int mesh_transport_key_iterator_has_more(mesh_transport_key_iterator_t *it);
|
int mesh_transport_key_iterator_has_more(mesh_transport_key_iterator_t *it);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get next transport key (AppKey)
|
* @brief Get next transport key (AppKey)
|
||||||
* @param it
|
* @param it
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
mesh_transport_key_t * mesh_transport_key_iterator_get_next(mesh_transport_key_iterator_t *it);
|
mesh_transport_key_t * mesh_transport_key_iterator_get_next(mesh_transport_key_iterator_t *it);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Transport Key Iterator by AID - init
|
* @brief Transport Key Iterator by AID - init
|
||||||
* @param it
|
* @param it
|
||||||
* @param netkey_index
|
* @param netkey_index
|
||||||
* @param akf
|
* @param akf
|
||||||
@ -250,14 +258,14 @@ void mesh_transport_key_aid_iterator_init(mesh_transport_key_iterator_t *it, uin
|
|||||||
uint8_t aid);
|
uint8_t aid);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Transport Key Iterator by AID - has more?
|
* @brief Transport Key Iterator by AID - has more?
|
||||||
* @param it
|
* @param it
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
int mesh_transport_key_aid_iterator_has_more(mesh_transport_key_iterator_t *it);
|
int mesh_transport_key_aid_iterator_has_more(mesh_transport_key_iterator_t *it);
|
||||||
|
|
||||||
/** Transport Key Iterator by AID - get next
|
/**
|
||||||
*
|
* @brief Transport Key Iterator by AID - get next
|
||||||
* @param it
|
* @param it
|
||||||
* @return transport key
|
* @return transport key
|
||||||
*/
|
*/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user