Sukkin Pang / nrf51-sdk

Fork of nrf51-sdk by Lancaster University

Embed: (wiki syntax)

« Back to documentation index

Peer Database

An internal module of Peer_manager. More...

Data Structures

struct  pdb_evt_t
 Events that can come from the peer_database module. More...

Typedefs

typedef void(* pdb_evt_handler_t )(pdb_evt_t const *p_event)
 Event handler for events from the peer_data_storage module.

Enumerations

enum  pdb_evt_id_t {
  PDB_EVT_WRITE_BUF_STORED, PDB_EVT_RAW_STORED, PDB_EVT_RAW_STORE_FAILED, PDB_EVT_CLEARED,
  PDB_EVT_CLEAR_FAILED, PDB_EVT_COMPRESSED, PDB_EVT_ERROR_NO_MEM, PDB_EVT_ERROR_UNEXPECTED
}
 

Events that can come from the peer_database module.

More...

Functions

ret_code_t pdb_register (pdb_evt_handler_t evt_handler)
 Function for registering for events from the peer database.
pm_peer_id_t pdb_peer_allocate (void)
 Function for allocating persistent bond storage for a peer.
ret_code_t pdb_peer_free (pm_peer_id_t peer_id)
 Function for freeing a peer's persistent bond storage.
ret_code_t pdb_read_buf_get (pm_peer_id_t peer_id, pm_peer_data_id_t data_id, pm_peer_data_flash_t *p_peer_data, pm_store_token_t *p_token)
 Function for retrieving pointers to read-only peer data.
ret_code_t pdb_write_buf_get (pm_peer_id_t peer_id, pm_peer_data_id_t data_id, uint32_t n_bufs, pm_peer_data_t *p_peer_data)
 Function for retrieving pointers to a write buffer for peer data.
ret_code_t pdb_write_buf_release (pm_peer_id_t peer_id, pm_peer_data_id_t data_id)
 Function for freeing a write buffer allocated with pdb_write_buf_get.
ret_code_t pdb_write_buf_store_prepare (pm_peer_id_t peer_id, pm_peer_data_id_t data_id)
 Function for reserving space in persistent storage for data in a buffer.
ret_code_t pdb_write_buf_store (pm_peer_id_t peer_id, pm_peer_data_id_t data_id)
 Function for writing data into persistent storage.
ret_code_t pdb_clear (pm_peer_id_t peer_id, pm_peer_data_id_t data_id)
 Function for clearing data from persistent storage.
uint32_t pdb_n_peers (void)
 Function for querying the number of valid peer IDs available.
pm_peer_id_t pdb_next_peer_id_get (pm_peer_id_t prev_peer_id)
 Function for getting the next peer ID in the sequence of all used peer IDs.
ret_code_t pdb_peer_data_update (pm_peer_data_const_t peer_data, pm_store_token_t old_token, pm_store_token_t *p_store_token)
 Function for updating currently stored peer data to a new version.
ret_code_t pdb_raw_read (pm_peer_id_t peer_id, pm_peer_data_id_t data_id, pm_peer_data_t *p_peer_data)
 Function for reading data directly from persistent storage to external memory.
ret_code_t pdb_raw_store (pm_peer_id_t peer_id, pm_peer_data_const_t *p_peer_data, pm_store_token_t *p_store_token)
 Function for writing data directly to persistent storage from external memory.

Detailed Description

An internal module of Peer_manager.

A module for simple management of reading and writing of peer data into persistent storage.


Typedef Documentation

typedef void(* pdb_evt_handler_t)(pdb_evt_t const *p_event)

Event handler for events from the peer_data_storage module.

Parameters:
[in]p_eventThe event that has happened.

Definition at line 90 of file peer_database.h.


Enumeration Type Documentation

Events that can come from the peer_database module.

Enumerator:
PDB_EVT_WRITE_BUF_STORED 

A pdb_write_buf_store operation has completed successfully.

PDB_EVT_RAW_STORED 

A pdb_raw_store operation has completed successfully.

PDB_EVT_RAW_STORE_FAILED 

A pdb_raw_store operation has failed.

PDB_EVT_CLEARED 

A pdb_clear operation has completed successfully.

PDB_EVT_CLEAR_FAILED 

A pdb_clear operation has failed.

PDB_EVT_COMPRESSED 

A compress procedure has completed.

PDB_EVT_ERROR_NO_MEM 

An operation is blocked because the flash is full.

It will be reattempted automatically after the next compress procedure.

PDB_EVT_ERROR_UNEXPECTED 

An unexpected error occurred.

This is a fatal error.

Definition at line 54 of file peer_database.h.


Function Documentation

ret_code_t pdb_clear ( pm_peer_id_t  peer_id,
pm_peer_data_id_t  data_id 
)

Function for clearing data from persistent storage.

Parameters:
[in]peer_idID of peer to clear data for.
[in]data_idWhich piece of data to clear.
Return values:
NRF_SUCCESSData clear was successfully started.
NRF_ERROR_INVALID_PARAMData ID was invalid.
NRF_ERROR_NOT_FOUNDNothing to clear for this data for this peer ID.
NRF_ERROR_BUSYCould not process request at this time. Reattempt later.
NRF_ERROR_INVALID_STATEModule is not initialized.

Definition at line 721 of file peer_database.c.

uint32_t pdb_n_peers ( void   )

Function for querying the number of valid peer IDs available.

I.E the number of peers in persistent storage.

Returns:
The number of valid peer IDs.

Definition at line 729 of file peer_database.c.

pm_peer_id_t pdb_next_peer_id_get ( pm_peer_id_t  prev_peer_id )

Function for getting the next peer ID in the sequence of all used peer IDs.

Can be used to loop through all used peer IDs.

Note:
PM_PEER_ID_INVALID is considered to be before the first and after the last ordinary peer ID.
Parameters:
[in]prev_peer_idThe previous peer ID.
Returns:
The next peer ID.
The first ordinary peer ID if prev_peer_id was PM_PEER_ID_INVALID.
Return values:
PM_PEER_ID_INVALIDif prev_peer_id was the last ordinary peer ID.

Definition at line 740 of file peer_database.c.

pm_peer_id_t pdb_peer_allocate ( void   )

Function for allocating persistent bond storage for a peer.

Returns:
The ID of the newly allocated storage.
Return values:
PM_PEER_ID_INVALIDIf no peer ID is available.

Definition at line 359 of file peer_database.c.

ret_code_t pdb_peer_data_update ( pm_peer_data_const_t  peer_data,
pm_store_token_t  old_token,
pm_store_token_t p_store_token 
)

Function for updating currently stored peer data to a new version.

Updating happens asynchronously. Expect a PDS_EVT_STORED or PDS_EVT_ERROR_STORE for the store token and a PDS_EVT_ERROR_CLEAR or PDS_EVT_ERROR_CLEAR for the old token

Parameters:
[in]peer_dataNew data
[in]old_tokenStore token for the old data
[out]p_store_tokenStore token for the new data
Return values:
NRF_SUCESSThe update was initiated successfully
NRF_ERROR_NOT_FOUNDThe old store token was invalid.
NRF_ERROR_NULLData contained a NULL pointer.
NRF_ERROR_NO_MEMNo space available in persistent storage.
NRF_ERROR_BUSYFDS or underlying modules are busy and can't take any more requests
NRF_ERROR_INVALID_STATEModule is not initialized.
ret_code_t pdb_peer_free ( pm_peer_id_t  peer_id )

Function for freeing a peer's persistent bond storage.

Note:
This function will call pdb_write_buf_release on the data for this peer.
Parameters:
[in]peer_idID to be freed.
Return values:
NRF_SUCCESSPeer ID was released and clear operation was initiated successfully.
NRF_ERROR_BUSYAnother peer_id clear was already requested or could not be started.
NRF_ERROR_INVALID_STATEModule is not initialized.

Definition at line 370 of file peer_database.c.

ret_code_t pdb_raw_read ( pm_peer_id_t  peer_id,
pm_peer_data_id_t  data_id,
pm_peer_data_t p_peer_data 
)

Function for reading data directly from persistent storage to external memory.

Parameters:
[in]peer_idID of peer to read data for.
[in]data_idWhich piece of data to read.
inout]p_peer_data Where to store the data. If the data to be read has variable length, the appropriate length field needs to reflect the available buffer space. On a successful read, the length field is updated to match the length of the read data.
Return values:
NRF_SUCCESSData successfully read.
NRF_ERROR_INVALID_PARAMData ID or Peer ID was invalid or unallocated.
NRF_ERROR_NULLp_peer_data contained a NULL pointer.
NRF_ERROR_NOT_FOUNDThis data was not found for this peer ID.
NRF_ERROR_DATA_SIZEThe provided buffer was not large enough.
NRF_ERROR_INVALID_STATEModule is not initialized.

Definition at line 751 of file peer_database.c.

ret_code_t pdb_raw_store ( pm_peer_id_t  peer_id,
pm_peer_data_const_t p_peer_data,
pm_store_token_t p_store_token 
)

Function for writing data directly to persistent storage from external memory.

Parameters:
[in]peer_idID of peer to write data for.
[in]p_peer_dataData to store.
[out]p_store_tokenA token identifying this particular store operation. The token can be used to identify events pertaining to this operation.
Return values:
NRF_SUCCESSData successfully written.
NRF_ERROR_INVALID_PARAMData ID or Peer ID was invalid or unallocated.
NRF_ERROR_NULLp_peer_data contained a NULL pointer.
NRF_ERROR_NO_MEMNo space available in persistent storage.
NRF_ERROR_INVALID_LENGTHData length above the maximum allowed.
NRF_ERROR_INVALID_STATEModule is not initialized.

Definition at line 760 of file peer_database.c.

ret_code_t pdb_read_buf_get ( pm_peer_id_t  peer_id,
pm_peer_data_id_t  data_id,
pm_peer_data_flash_t p_peer_data,
pm_store_token_t p_token 
)

Function for retrieving pointers to read-only peer data.

Note:
Reading this pointer is not safe in the strictest sense. If a safe read is required:
  • Disable interrupts
  • Call this function. If the return code is NRF_SUCCESS, the following read is safe.
  • Read memory.
  • Enable interrupts.
This buffer does not need to be released. It is a pointer directly to flash.
Parameters:
[in]peer_idID of peer to retrieve data for.
[in]data_idWhich piece of data to get.
[out]p_peer_dataPointer to immutable peer data.
[out]p_tokenToken that can be used to lock data in flash and check data validity.
Return values:
NRF_SUCCESSData retrieved successfully.
NRF_ERROR_INVALID_PARAMData ID or Peer ID was invalid or unallocated.
NRF_ERROR_NULLp_peer_data was NULL.
NRF_ERROR_NOT_FOUNDThis data was not found for this peer ID.
NRF_ERROR_INVALID_STATEModule is not initialized.

Definition at line 378 of file peer_database.c.

ret_code_t pdb_register ( pdb_evt_handler_t  evt_handler )

Function for registering for events from the peer database.

Note:
This function will initialize the module if it is not already initialized.
Parameters:
[in]evt_handlerEvent handler to register.
Return values:
NRF_SUCCESSRegistration successful.
NRF_ERROR_NO_MEMNo more event handlers can be registered.
NRF_ERROR_NULLevt_handler was NULL.
NRF_ERROR_INVALID_PARAMUnexpected return code from pm_buffer_init.
NRF_ERROR_INVALID_STATEFDS has not been initalized.

Definition at line 326 of file peer_database.c.

ret_code_t pdb_write_buf_get ( pm_peer_id_t  peer_id,
pm_peer_data_id_t  data_id,
uint32_t  n_bufs,
pm_peer_data_t p_peer_data 
)

Function for retrieving pointers to a write buffer for peer data.

This function will provide pointers to a buffer of the data. The data buffer will not be written to persistent storage until pdb_write_buf_store is called. The buffer is released by calling either pdb_write_buf_release, pdb_write_buf_store, or pdb_peer_free.

When the data_id refers to a variable length data type, the available size is written to the data, both the top-level, and any internal length fields.

Note:
Calling this function on a peer_id/data_id pair that already has a buffer created will give the same buffer, not create a new one. If n_bufs was increased since last time, the buffer might be relocated to be able to provide additional room. In this case, the data will be copied. If n_bufs was increased since last time, this function might return NRF_ERROR_BUSY. In that case, the buffer is automatically released.
Parameters:
[in]peer_idID of peer to get a write buffer for.
[in]data_idWhich piece of data to get.
[in]n_bufsThe number of contiguous buffers needed.
[out]p_peer_dataPointers to mutable peer data.
Return values:
NRF_SUCCESSData retrieved successfully.
NRF_ERROR_INVALID_PARAMData ID or Peer ID was invalid or unallocated, or n_bufs was 0 or more than the total available buffers.
NRF_ERROR_NULLp_peer_data was NULL.
NRF_ERROR_BUSYNot enough buffer(s) available.
NRF_ERROR_INTERNALUnexpected internal error.
NRF_ERROR_INVALID_STATEModule is not initialized.

Definition at line 429 of file peer_database.c.

ret_code_t pdb_write_buf_release ( pm_peer_id_t  peer_id,
pm_peer_data_id_t  data_id 
)

Function for freeing a write buffer allocated with pdb_write_buf_get.

Note:
This function will not write peer data to persistent memory. Data in released buffer will be lost.
This function will undo any previous call to pdb_write_buf_store_prepare for this piece of data.
Parameters:
[in]peer_idID of peer to release buffer for.
[in]data_idWhich piece of data to release buffer for.
Return values:
NRF_SUCCESSSuccessfully released buffer.
NRF_ERROR_NOT_FOUNDNo buffer was allocated for this peer ID/data ID pair.
NRF_ERROR_INVALID_STATEModule is not initialized.
NRF_ERROR_INTERNALUnexpected internal error.

Definition at line 536 of file peer_database.c.

ret_code_t pdb_write_buf_store ( pm_peer_id_t  peer_id,
pm_peer_data_id_t  data_id 
)

Function for writing data into persistent storage.

Writing happens asynchronously.

Note:
This will unlock the data after it has been written.
Parameters:
[in]peer_idID of peer to store data for.
[in]data_idWhich piece of data to store.
Return values:
NRF_SUCCESSData storing was successfully started.
NRF_ERROR_NO_MEMNo space available in persistent storage. Please clear some space, the operation will be reattempted after the next compress procedure. This error will not happen if pdb_write_buf_store_prepare is called beforehand.
NRF_ERROR_INVALID_PARAMData ID was invalid.
NRF_ERROR_NOT_FOUNDNo buffer has been allocated for this peer ID/data ID pair.
NRF_ERROR_INVALID_STATEModule is not initialized.
NRF_ERROR_INTERNALUnexpected internal error.

Definition at line 630 of file peer_database.c.

ret_code_t pdb_write_buf_store_prepare ( pm_peer_id_t  peer_id,
pm_peer_data_id_t  data_id 
)

Function for reserving space in persistent storage for data in a buffer.

Note:
This function only works for data which has a write buffer allocated. If the write buffer is released, this prepare is undone.
If space has already been reserved for this data, nothing is done.
Parameters:
[in]peer_idThe peer whose data to reserve space for.
[in]data_idThe type of data to reserve space for.
Return values:
NRF_SUCCESSSuccessfully reserved space in persistent storage.
NRF_ERROR_NO_MEMNot enough room in persistent storage.
NRF_ERROR_BUSYCould not process request at this time. Reattempt later.
NRF_ERROR_NOT_FOUNDNo buffer has been allocated for this peer ID/data ID pair.
NRF_ERROR_INVALID_PARAMData ID or Peer ID was invalid or unallocated.
NRF_ERROR_INVALID_STATEModule is not initialized.

Definition at line 564 of file peer_database.c.