Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: mbedEndpointNetwork mbedEndpointNetworkMJK
Fork of Nanostack_lib by
Diff: inc/net/pana_nvm_api.h
- Revision:
- 4:c449bead5cf3
- Child:
- 11:1b7aaf37a131
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/inc/net/pana_nvm_api.h Tue Jun 24 16:48:01 2014 +0300
@@ -0,0 +1,137 @@
+/**
+ * \file pana_nvm_api.h
+ * \brief ZigBeeIP Library Pana NVM API for Client and Server.
+ *
+ * \section server-api Server NVM API
+ *
+ * Pana Server Security material is crypted always and if you change border router RF module
+ * decrypt does not work properly.
+ *
+ * - pana_server_nvm_callback_set(), Init Pana Server NVM functionality
+ * - pana_server_restore_from_nvm(), Load crypted Pana server base and security material from NVM
+ * - pana_server_nvm_client_session_load(), Load crypted Client session from NVM
+ *
+ * \section client-api Client NVM API
+ *
+ * nw_nvm.c use already this API and Application can just use net_nvm_api.h.
+ *
+ * - pana_client_nvm_callback_set(), Init Pana session NVM
+ * - net_read_persistent_data(), Read NWK ID & MAC 16-bit Address
+ * - net_nvm_data_load(), Load Pana session, NWK-ID and short address to stack for re-use.
+ *
+ */
+#ifndef PANA_NVM_API_H_
+#define PANA_NVM_API_H_
+/*!
+ * \enum pana_nvm_update_process_t
+ * \brief Pana Server NVM update states.
+ */
+typedef enum pana_nvm_update_process_t
+{
+ PANA_SERVER_MATERIAL_UPDATE, /**< Pana Server Security Material Update */
+ PANA_SERVER_CLIENT_SESSION_UPDATE, /**< Pana Client Session Update */
+ PANA_SERVER_CLIENT_SESSION_SEQ_UPDATE, /**< Pana Client Session Sequence number Update */
+ PANA_SERVER_CLIENT_SESSION_REMOVE_UPDATE, /**< Pana Client Session remove */
+}pana_nvm_update_process_t;
+
+/*!
+ * \enum pana_client_nvm_update_process_t
+ * \brief Pana Client NVM update states.
+ */
+typedef enum pana_client_nvm_update_process_t
+{
+ PANA_CLIENT_SESSION_UPDATE, /**< Pana Session information Fully Update */
+ PANA_CLIENT_SESSION_SEQ_UPDATE, /**< Pana key Pull or Push Operation update REQ and RES sequence number */
+}pana_client_nvm_update_process_t;
+
+/* NVM API PART */
+/**
+ * \brief Pana Server NVM functionality init
+ *
+ * \param passed_fptr function pointer to NVM update process
+ * \param nvm_static_buffer pointer to Application allocated static memory, Needed minimal size is 115 bytes
+ *
+ *
+ * Reference Callback function structure which use EEPROM:
+ * - nvm_static_buffer is application is allocated static buffer
+ *
+ * \return 0, Init OK
+ * \return -1, Null parameter detect
+ *
+ */
+extern int8_t pana_server_nvm_callback_set(uint16_t (*passed_fptr)(pana_nvm_update_process_t), uint8_t * nvm_static_buffer);
+/**
+ * \brief Pana Server Base restore form NVM
+ *
+ * \param nvm_data pointer to Crypted Pana server base data
+ *
+ * \return 0, Restore OK
+ * \return -1, Memory Allocation fail
+ *
+ */
+extern int8_t pana_server_restore_from_nvm(uint8_t * nvm_data, int8_t interface_id);
+/**
+ * \brief Pana Client session load from NVM API
+ *
+ * \param nvm_data pointer to Crypted Pana client session
+ *
+ * \return 0, Restore OK
+ * \return -1, Memory Allocation fail
+ *
+ */
+extern int8_t pana_server_nvm_client_session_load(uint8_t *nvm_pointer);
+
+/**
+ * \brief Pana Client NVM functionality init
+ *
+ * \param passed_fptr function pointer to NVM update process
+ * \param nvm_static_buffer pointer to Application allocated static memory, Needed minimal size is 88 bytes
+ *
+ * Reference Callback function structure which use EEPROM:
+ * - nvm_static_buffer is application is allocated static buffer
+ *
+ * \return 0, Init OK
+ * \return -1, Null parameter detect
+ *
+ */
+extern int8_t pana_client_nvm_callback_set(void (*passed_fptr)(pana_client_nvm_update_process_t), uint8_t * nvm_static_buffer);
+/**
+ * \brief Read Network persistent data
+ *
+ * \param data_buffer pointer to where stack save 18 bytes [NWK-ID 16bytes, Short Address 2bytes]
+ *
+ *
+ * \return 0, Read OK
+ * \return -1, Null parameter detect
+ * \return -2 Bootstrap not ready yet
+ *
+ * This function should call when network bootstrap is ready.
+ *
+ */
+extern int8_t net_read_persistent_data(uint8_t *data_buffer, int8_t interface_id);
+/**
+ * \brief Load ZigBeeIP node persistent data to stack for re-use
+ *
+ * \param data_buffer pointer to data which should include 88 bytes[NWK-ID 16bytes, Short Address 2bytes, Pana 70 bytes]
+ *
+ *
+ * \return 0, Read OK
+ * \return -1, Null parameter detect
+ * \return -2, Stack is active
+ * \return <-2 Memory allocation fail
+ *
+ */
+extern int8_t net_nvm_data_load(uint8_t *data_buffer, int8_t interface_id);
+/**
+ * \brief Clean ZigBeeIP node persistent data from stack
+ *
+ * Function disable Network ID filter, set EUID-16 to 0xffff and remove Pana client session. Function is only for client purpose.
+ *
+ *
+ * \return 0, Clean OK
+ * \return -1, Stack is active
+ *
+ */
+extern int8_t net_nvm_data_clean(int8_t interface_id);
+
+#endif /* PANA_NVM_API_H_ */
