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.
Fork of nRF51822 by
Persistent Storage Access Routines
[Persistent Storage Interface]
  Functions/Interface SDK modules use to persistently store data. More...
| Functions | |
| uint32_t | pstorage_init (void) | 
| Module Initialization Routine. | |
| uint32_t | pstorage_register (pstorage_module_param_t *p_module_param, pstorage_handle_t *p_block_id) | 
| Register with persistent storage interface. | |
| uint32_t | pstorage_block_identifier_get (pstorage_handle_t *p_base_id, pstorage_size_t block_num, pstorage_handle_t *p_block_id) | 
| Function to get block id with reference to base block identifier provided at time of registration. | |
| uint32_t | pstorage_store (pstorage_handle_t *p_dest, uint8_t *p_src, pstorage_size_t size, pstorage_size_t offset) | 
| Routine to persistently store data of length 'size' contained in 'p_src' address in storage module at 'p_dest' address; Equivalent to Storage Write. | |
| uint32_t | pstorage_update (pstorage_handle_t *p_dest, uint8_t *p_src, pstorage_size_t size, pstorage_size_t offset) | 
| Routine to update persistently stored data of length 'size' contained in 'p_src' address in storage module at 'p_dest' address. | |
| uint32_t | pstorage_load (uint8_t *p_dest, pstorage_handle_t *p_src, pstorage_size_t size, pstorage_size_t offset) | 
| Routine to load persistently stored data of length 'size' from 'p_src' address to 'p_dest' address; Equivalent to Storage Read. | |
| uint32_t | pstorage_clear (pstorage_handle_t *p_base_id, pstorage_size_t size) | 
| Routine to clear data in persistent memory. | |
| uint32_t | pstorage_access_status_get (uint32_t *p_count) | 
| API to get status of number of pending operations with the module. | |
| uint32_t | pstorage_raw_register (pstorage_module_param_t *p_module_param, pstorage_handle_t *p_block_id) | 
| Function for registering with persistent storage interface. | |
| uint32_t | pstorage_raw_store (pstorage_handle_t *p_dest, uint8_t *p_src, pstorage_size_t size, pstorage_size_t offset) | 
| Raw mode function for persistently storing data of length 'size' contained in 'p_src' address in storage module at 'p_dest' address; Equivalent to Storage Write. | |
| uint32_t | pstorage_raw_clear (pstorage_handle_t *p_dest, pstorage_size_t size) | 
| Function for clearing data in persistent memory in raw mode. | |
Detailed Description
Functions/Interface SDK modules use to persistently store data.
Interface for Application & SDK module to load/store information persistently. Note: that while implementation of each of the persistent storage access function depends on the system and can specific to system/solution, the signature of the interface routines should not be altered.
Function Documentation
| uint32_t pstorage_access_status_get | ( | uint32_t * | p_count ) | 
API to get status of number of pending operations with the module.
- Parameters:
- 
  [out] p_count Number of storage operations pending with the module, if 0, there are no outstanding requests. 
- Return values:
- 
  NRF_SUCCESS on success, else an error code indicating reason for failure. NRF_ERROR_INVALID_STATE is returned is API is called without module initialization. NRF_ERROR_NULL if NULL parameter has been passed. 
Definition at line 1058 of file pstorage.cpp.
| uint32_t pstorage_block_identifier_get | ( | pstorage_handle_t * | p_base_id, | 
| pstorage_size_t | block_num, | ||
| pstorage_handle_t * | p_block_id | ||
| ) | 
Function to get block id with reference to base block identifier provided at time of registration.
Function to get block id with reference to base block identifier provided at time of registration. In case more than one memory blocks were requested when registering, the identifier provided here is the base identifier for the first block and to identify subsequent block, application shall use this routine to get block identifier providing input as base identifier and block number. Therefore if 10 blocks of size 64 are requested and application wishes to store memory in 6th block, it shall use @ref pstorage_block_identifier_get with based id and provide a block number of 5. This way application is only expected to remember the base block identifier.
- Parameters:
- 
  [in] p_base_id Base block id received at the time of registration. [in] block_num Block Number, with first block numbered zero. [out] p_block_id Block identifier for the block number requested in case the API succeeds. 
- Return values:
- 
  NRF_SUCCESS on success, else an error code indicating reason for failure. NRF_ERROR_INVALID_STATE is returned is API is called without module initialization. NRF_ERROR_NULL if NULL parameter has been passed. NRF_ERROR_INVALID_PARAM if invalid parameters are passed to the API. 
Definition at line 918 of file pstorage.cpp.
| uint32_t pstorage_clear | ( | pstorage_handle_t * | p_base_id, | 
| pstorage_size_t | size | ||
| ) | 
Routine to clear data in persistent memory.
- Parameters:
- 
  [in] p_base_id Base block identifier in persistent memory that needs to cleared; Equivalent to an Erase Operation. [in] size Size of data to be cleared from persistent memory expressed in bytes. This parameter is to provision for clearing of certain blocks of memory, or all memory blocks in a registered module. If the total size of the application module is used (blocks * block size) in combination with the identifier for the first block in the module, all blocks in the module will be erased. 
- Return values:
- 
  NRF_SUCCESS on success, else an error code indicating reason for failure. NRF_ERROR_INVALID_STATE is returned is API is called without module initialization. NRF_ERROR_NULL if NULL parameter has been passed. NRF_ERROR_INVALID_PARAM if invalid parameters are passed to the API. NRF_ERROR_INVALID_ADDR in case data address 'p_dst' is not aligned. NRF_ERROR_NO_MEM in case request cannot be processed. 
- Note:
- Clear operations may take time. This API however, does not block until the clear procedure is complete. Application is notified of procedure completion using notification callback registered by the application. 'result' parameter of the callback suggests if the procedure was successful or not.
Definition at line 1028 of file pstorage.cpp.
| uint32_t pstorage_init | ( | void | ) | 
Module Initialization Routine.
Initializes module. To be called once before any other APIs of the module are used.
- Return values:
- 
  NRF_SUCCESS on success, else an error code indicating reason for failure. 
Definition at line 820 of file pstorage.cpp.
| uint32_t pstorage_load | ( | uint8_t * | p_dest, | 
| pstorage_handle_t * | p_src, | ||
| pstorage_size_t | size, | ||
| pstorage_size_t | offset | ||
| ) | 
Routine to load persistently stored data of length 'size' from 'p_src' address to 'p_dest' address; Equivalent to Storage Read.
- Parameters:
- 
  [in] p_dest Destination address where persistently stored data is to be loaded. [in] p_src Source from where data is to be loaded from persistent memory. [in] size Size of data to be loaded from persistent memory expressed in bytes. Should be word aligned. [in] offset Offset in bytes to be applied when loading from the block. For example, if within a block of 100 bytes, application wishes to load 20 bytes from offset of 12, then this field should be set to 12. Should be word aligned. 
- Return values:
- 
  NRF_SUCCESS on success, else an error code indicating reason for failure. NRF_ERROR_INVALID_STATE is returned is API is called without module initialization. NRF_ERROR_NULL if NULL parameter has been passed. NRF_ERROR_INVALID_PARAM if invalid parameters are passed to the API. NRF_ERROR_INVALID_ADDR in case data address 'p_dst' is not aligned. NRF_ERROR_NO_MEM in case request cannot be processed. 
Definition at line 996 of file pstorage.cpp.
| uint32_t pstorage_raw_clear | ( | pstorage_handle_t * | p_dest, | 
| pstorage_size_t | size | ||
| ) | 
Function for clearing data in persistent memory in raw mode.
- Parameters:
- 
  [in] p_dest Base block identifier in persistent memory that needs to cleared; Equivalent to an Erase Operation. [in] size Size of data to be cleared from persistent memory expressed in bytes. This is currently unused. And a clear would mean clearing all blocks, however, this parameter is to provision for clearing of certain blocks of memory only and not all if need be. 
- Return values:
- 
  NRF_SUCCESS on success, else an error code indicating reason for failure. NRF_ERROR_INVALID_STATE is returned is API is called without module initialization. NRF_ERROR_NULL if NULL parameter has been passed. NRF_ERROR_INVALID_PARAM if invalid parameters are passed to the API. NRF_ERROR_NO_MEM in case request cannot be processed. 
- Note:
- Clear operations may take time. This API however, does not block until the clear procedure is complete. Application is notified of procedure completion using notification callback registered by the application. 'result' parameter of the callback suggests if the procedure was successful or not.
Definition at line 1111 of file pstorage.cpp.
| uint32_t pstorage_raw_register | ( | pstorage_module_param_t * | p_module_param, | 
| pstorage_handle_t * | p_block_id | ||
| ) | 
Function for registering with persistent storage interface.
- Parameters:
- 
  [in] p_module_param Module registration param. [out] p_block_id Block identifier to identify persistent memory blocks in case registration succeeds. Application is expected to use the block ids for subsequent operations on requested persistent memory. In case more than one memory blocks are requested, the identifier provided here is the base identifier for the first block and to identify subsequent block, application shall use @ref pstorage_block_identifier_get with this base identifier and block number. Therefore if 10 blocks of size 64 are requested and application wishes to store memory in 6th block, it shall use @ref pstorage_block_identifier_get with based id and provide a block number of 5. This way application is only expected to remember the base block identifier. 
- Return values:
- 
  NRF_SUCCESS on success, else an error code indicating reason for failure. NRF_ERROR_INVALID_STATE is returned is API is called without module initialization. NRF_ERROR_NULL if NULL parameter has been passed. NRF_ERROR_INVALID_PARAM if invalid parameters are passed to the API. NRF_ERROR_NO_MEM in case no more registrations can be supported. 
Definition at line 1071 of file pstorage.cpp.
| uint32_t pstorage_raw_store | ( | pstorage_handle_t * | p_dest, | 
| uint8_t * | p_src, | ||
| pstorage_size_t | size, | ||
| pstorage_size_t | offset | ||
| ) | 
Raw mode function for persistently storing data of length 'size' contained in 'p_src' address in storage module at 'p_dest' address; Equivalent to Storage Write.
- Parameters:
- 
  [in] p_dest Destination address where data is to be stored persistently. [in] p_src Source address containing data to be stored. API assumes this to be resident memory and no intermediate copy of data is made by the API. [in] size Size of data to be stored expressed in bytes. Should be word aligned. [in] offset Offset in bytes to be applied when writing to the block. For example, if within a block of 100 bytes, application wishes to write 20 bytes at offset of 12, then this field should be set to 12. Should be word aligned. 
- Return values:
- 
  NRF_SUCCESS on success, else an error code indicating reason for failure. NRF_ERROR_INVALID_STATE is returned is API is called without module initialization. NRF_ERROR_NULL if NULL parameter has been passed. NRF_ERROR_INVALID_PARAM if invalid parameters are passed to the API. NRF_ERROR_INVALID_ADDR in case data address 'p_src' is not aligned. NRF_ERROR_NO_MEM in case request cannot be processed. 
- Warning:
- No copy of the data is made, and hence memory provided for data source to be written to flash cannot be freed or reused by the application until this procedure is complete. End of this procedure is notified to the application using the notification callback registered by the application.
Definition at line 1091 of file pstorage.cpp.
| uint32_t pstorage_register | ( | pstorage_module_param_t * | p_module_param, | 
| pstorage_handle_t * | p_block_id | ||
| ) | 
Register with persistent storage interface.
- Parameters:
- 
  [in] p_module_param Module registration param. [out] p_block_id Block identifier to identify persistent memory blocks in case registration succeeds. Application is expected to use the block ids for subsequent operations on requested persistent memory. Maximum registrations permitted is determined by configuration parameter PSTORAGE_MAX_APPLICATIONS. In case more than one memory blocks are requested, the identifier provided here is the base identifier for the first block and to identify subsequent block, application shall use @ref pstorage_block_identifier_get with this base identifier and block number. Therefore if 10 blocks of size 64 are requested and application wishes to store memory in 6th block, it shall use @ref pstorage_block_identifier_get with based id and provide a block number of 5. This way application is only expected to remember the base block identifier. 
- Return values:
- 
  NRF_SUCCESS on success, else an error code indicating reason for failure. NRF_ERROR_INVALID_STATE is returned is API is called without module initialization. NRF_ERROR_NULL if NULL parameter has been passed. NRF_ERROR_INVALID_PARAM if invalid parameters are passed to the API. NRF_ERROR_NO_MEM in case no more registrations can be supported. 
Definition at line 861 of file pstorage.cpp.
| uint32_t pstorage_store | ( | pstorage_handle_t * | p_dest, | 
| uint8_t * | p_src, | ||
| pstorage_size_t | size, | ||
| pstorage_size_t | offset | ||
| ) | 
Routine to persistently store data of length 'size' contained in 'p_src' address in storage module at 'p_dest' address; Equivalent to Storage Write.
- Parameters:
- 
  [in] p_dest Destination address where data is to be stored persistently. [in] p_src Source address containing data to be stored. API assumes this to be resident memory and no intermediate copy of data is made by the API. [in] size Size of data to be stored expressed in bytes. Should be word aligned. [in] offset Offset in bytes to be applied when writing to the block. For example, if within a block of 100 bytes, application wishes to write 20 bytes at offset of 12, then this field should be set to 12. Should be word aligned. 
- Return values:
- 
  NRF_SUCCESS on success, else an error code indicating reason for failure. NRF_ERROR_INVALID_STATE is returned is API is called without module initialization. NRF_ERROR_NULL if NULL parameter has been passed. NRF_ERROR_INVALID_PARAM if invalid parameters are passed to the API. NRF_ERROR_INVALID_ADDR in case data address 'p_src' is not aligned. NRF_ERROR_NO_MEM in case request cannot be processed. 
- Warning:
- No copy of the data is made, and hence memory provided for data source to be written to flash cannot be freed or reused by the application until this procedure is complete. End of this procedure is notified to the application using the notification callback registered by the application.
Definition at line 940 of file pstorage.cpp.
| uint32_t pstorage_update | ( | pstorage_handle_t * | p_dest, | 
| uint8_t * | p_src, | ||
| pstorage_size_t | size, | ||
| pstorage_size_t | offset | ||
| ) | 
Routine to update persistently stored data of length 'size' contained in 'p_src' address in storage module at 'p_dest' address.
- Parameters:
- 
  [in] p_dest Destination address where data is to be updated. [in] p_src Source address containing data to be stored. API assumes this to be resident memory and no intermediate copy of data is made by the API. [in] size Size of data to be stored expressed in bytes. Should be word aligned. [in] offset Offset in bytes to be applied when writing to the block. For example, if within a block of 100 bytes, application wishes to write 20 bytes at offset of 12, then this field should be set to 12. Should be word aligned. 
- Return values:
- 
  NRF_SUCCESS on success, else an error code indicating reason for failure. NRF_ERROR_INVALID_STATE is returned is API is called without module initialization. NRF_ERROR_NULL if NULL parameter has been passed. NRF_ERROR_INVALID_PARAM if invalid parameters are passed to the API. NRF_ERROR_INVALID_ADDR in case data address 'p_src' is not aligned. NRF_ERROR_NO_MEM in case request cannot be processed. 
- Warning:
- No copy of the data is made, and hence memory provided for data source to be written to flash cannot be freed or reused by the application until this procedure is complete. End of this procedure is notified to the application using the notification callback registered by the application.
Definition at line 968 of file pstorage.cpp.
Generated on Tue Jul 12 2022 19:04:39 by
 1.7.2
 1.7.2 
    