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
inc/net/pana_nvm_api.h
- Committer:
- Mika Karjalainen 
- Date:
- 2014-06-24
- Revision:
- 4:c449bead5cf3
- Child:
- 11:1b7aaf37a131
File content as of revision 4:c449bead5cf3:
/**
 * \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_ */
            
    