[BLE NRF5] Fix bug: "purgeAllBondingState could had returned before deletion task was done"

by reimplement the btle_purgeAllBondingState as blocking function.
pull/2684/head
Andrzej Puzdrowski 2016-09-20 12:01:22 +02:00
parent e67117b8ea
commit 13a1fd5584
1 changed files with 23 additions and 2 deletions

View File

@ -31,6 +31,7 @@ static bool initialized = false;
static void pm_handler(pm_evt_t const *p_event);
static bool _enc_in_progress = false; // helper flag for distinguish between state of link connected and link connected in progres of encryption establishing.
volatile static uint32_t async_ret_code; // busy loop support variable for asyncronous API.
// default security parameters. Avoid "holes" between member assigments in order to compile by gcc++11.
static ble_gap_sec_params_t securityParameters = {
@ -140,7 +141,19 @@ btle_purgeAllBondingState(void)
{
ret_code_t rc;
rc = pm_peers_delete();
async_ret_code = NRF_ERROR_BUSY;
rc = pm_peers_delete(); // it is asynhronous API
if (rc == NRF_SUCCESS)
{
// waiting for respond from pm_handler
while (async_ret_code == NRF_ERROR_BUSY) {
// busy-loop
}
rc = async_ret_code;
}
switch (rc) {
case NRF_SUCCESS:
@ -344,6 +357,14 @@ void pm_handler(pm_evt_t const *p_event)
case PM_EVT_PEER_DATA_UPDATE_FAILED:
break;
case PM_EVT_PEERS_DELETE_SUCCEEDED:
async_ret_code = NRF_SUCCESS; // respond SUCCESS to the busy-loop in f. btle_purgeAllBondingState
break;
case PM_EVT_PEERS_DELETE_FAILED:
async_ret_code = NRF_ERROR_INTERNAL; // respond FAILURE to the busy-loop in f. btle_purgeAllBondingState
break;
case PM_EVT_STORAGE_FULL:
// Run garbage collection on the flash.
err_code = fds_gc();