Hello,
I'm trying to implement a set up of the ble device name from the NVMC UICR register.
But when I try to take it from the register and to set it has a name, it doesn't work very well. I think this is an issue about the utf-8 encoder of the ble device name.
Here's my code:
1) Write the device name only if it wasn't done before.
static void write_name ()
{
uint32_t* deviceName = (uint32_t*)&NRF_UICR->CUSTOMER[0];
if (*deviceName == 0xFFFFFFFF){
ret_code_t err_code;
err_code = nrf_sdh_disable_request();
APP_ERROR_CHECK(err_code);
NRF_NVMC->CONFIG = NVMC_CONFIG_WEN_Een << NVMC_CONFIG_WEN_Pos;
while (NRF_NVMC->READY == NVMC_READY_READY_Busy){}
NRF_NVMC->ERASEUICR = NVMC_ERASEUICR_ERASEUICR_Erase;
NRF_NVMC->CONFIG = NVMC_CONFIG_WEN_Ren << NVMC_CONFIG_WEN_Pos;
while (NRF_NVMC->READY == NVMC_READY_READY_Busy){}
NRF_NVMC->CONFIG = NVMC_CONFIG_WEN_Wen << NVMC_CONFIG_WEN_Pos;
while (NRF_NVMC->READY == NVMC_READY_READY_Busy){}
uint8_t* name = "WAW-TEST";
NRF_UICR->CUSTOMER[0] = 0xFFFFFFFF & *name;
NRF_NVMC->CONFIG = NVMC_CONFIG_WEN_Ren << NVMC_CONFIG_WEN_Pos;
while (NRF_NVMC->READY == NVMC_READY_READY_Busy){}
NVIC_SystemReset();
}
}
2) set the ble device name
static void gap_params_init()
{
ret_code_t err_code;
ble_gap_conn_params_t gap_conn_params;
ble_gap_conn_sec_mode_t sec_mode;
BLE_GAP_CONN_SEC_MODE_SET_OPEN(&sec_mode);
uint32_t* deviceName = (uint32_t*)&NRF_UICR->CUSTOMER[0];
uint8_t name = 0xFFFFFF00 | *deviceName;
uint8_t* n = &name;
NRF_LOG_INFO("%s", (char*)n);
if (*deviceName == 0xFFFFFFFF){
err_code = sd_ble_gap_device_name_set(&sec_mode,
(const uint8_t *)DEVICE_NAME,
strlen(DEVICE_NAME));
} else {
err_code = sd_ble_gap_device_name_set(&sec_mode,
(const uint8_t*)n,
strlen(n));
}
APP_ERROR_CHECK(err_code);
/* YOUR_JOB: Use an appearance value matching the application's use case.
err_code = sd_ble_gap_appearance_set(BLE_APPEARANCE_);
APP_ERROR_CHECK(err_code); */
memset(&gap_conn_params, 0, sizeof(gap_conn_params));
gap_conn_params.min_conn_interval = MIN_CONN_INTERVAL;
gap_conn_params.max_conn_interval = MAX_CONN_INTERVAL;
gap_conn_params.slave_latency = SLAVE_LATENCY;
gap_conn_params.conn_sup_timeout = CONN_SUP_TIMEOUT;
err_code = sd_ble_gap_ppcp_set(&gap_conn_params);
APP_ERROR_CHECK(err_code);
}
Currently, when I search for it, I'm seeing this :

When I should see "WAW-TEST"...
Does someone have a solution to this ?