Hi,
Is it possible to add a static bluetooth address to the whitelist?
I am using SDK 14.2.0, device is nrf52832 + peer manager.
BR
bjarke
Hi,
Is it possible to add a static bluetooth address to the whitelist?
I am using SDK 14.2.0, device is nrf52832 + peer manager.
BR
bjarke
Hi,
Whitelist can be used both by peripheral (to filter which centrals can connect) and by central (to filter what peripherals to connect to.) I assume that you need this for a peripheral.
If you use the Advertising Module then it is your responsibility to provide a whitelist on the BLE_ADV_EVT_WHITELIST_REQUEST event.
You may then choose to fetch a whitelist from peer manager using pm_whitelist_get(), as is done for instance in the HID Mouse Application example.
Or, in your case, you may make a whitelist manually using any Bluetooth addresses that you would like. The whitelist is an array of ble_gap_addr_t structures and an array of ble_gap_irk_t structures. (The IRK structure is only needed for resolvable addresses, not for static ones.)
In any case you must reply to the whitelist request event with a call to ble_advertising_whitelist_reply(), where you provide the whitelist.
Regards,
Terje
Hi,
I have been looking at ble_advertising.c, and can see that for Softdevice >2, the adresses are not used in the ble_advertising_whitelist_reply(...
from ble_advertising.c:
uint32_t ble_advertising_whitelist_reply(ble_advertising_t * const p_advertising,
ble_gap_addr_t const * p_gap_addrs,
uint32_t addr_cnt,
ble_gap_irk_t const * p_gap_irks,
uint32_t irk_cnt)
{
if (!p_advertising->whitelist_reply_expected)
{
return NRF_ERROR_INVALID_STATE;
}
p_advertising->whitelist_reply_expected = false;
#if (NRF_SD_BLE_API_VERSION <= 2)
p_advertising->whitelist.addr_count = addr_cnt;
p_advertising->whitelist.irk_count = irk_cnt;
for (uint32_t i = 0; i < addr_cnt; i++)
{
*p_advertising->whitelist.pp_addrs[i] = p_gap_addrs[i];
}
for (uint32_t i = 0; i < irk_cnt; i++)
{
*p_advertising->whitelist.pp_irks[i] = p_gap_irks[i];
}
#else
p_advertising->whitelist_in_use = ((addr_cnt > 0) || (irk_cnt > 0));
#endif
return NRF_SUCCESS;
}
Any ideas?
Regards
Hi,
I have been looking at ble_advertising.c, and can see that for Softdevice >2, the adresses are not used in the ble_advertising_whitelist_reply(...
from ble_advertising.c:
uint32_t ble_advertising_whitelist_reply(ble_advertising_t * const p_advertising,
ble_gap_addr_t const * p_gap_addrs,
uint32_t addr_cnt,
ble_gap_irk_t const * p_gap_irks,
uint32_t irk_cnt)
{
if (!p_advertising->whitelist_reply_expected)
{
return NRF_ERROR_INVALID_STATE;
}
p_advertising->whitelist_reply_expected = false;
#if (NRF_SD_BLE_API_VERSION <= 2)
p_advertising->whitelist.addr_count = addr_cnt;
p_advertising->whitelist.irk_count = irk_cnt;
for (uint32_t i = 0; i < addr_cnt; i++)
{
*p_advertising->whitelist.pp_addrs[i] = p_gap_addrs[i];
}
for (uint32_t i = 0; i < irk_cnt; i++)
{
*p_advertising->whitelist.pp_irks[i] = p_gap_irks[i];
}
#else
p_advertising->whitelist_in_use = ((addr_cnt > 0) || (irk_cnt > 0));
#endif
return NRF_SUCCESS;
}
Any ideas?
Regards