Hello,
i am using nrf52810 and with my custom board and i want to know the tx power level of that and is it possible to change the range please let me know where to get and how to configure it??.
thank tou.
Hello,
i am using nrf52810 and with my custom board and i want to know the tx power level of that and is it possible to change the range please let me know where to get and how to configure it??.
thank tou.
Hello,
You can change they TX power level by using the sd_ble_gap_tx_power_set function. The valid TX power level configuration for the nRF52810 can be seen in its RADIO TXPOWER register documentation.
Best regards,
Karl
Hello ,
thanks for the reply Karl, actually i am using ble_app_template example for advertising the sensor data for connectable beacon since here i have used this function already but i don't think so the value has changed. so for more details please check my code . here the cod
at the starting i have added below line,
static uint8_t m_adv_handle = BLE_GAP_ADV_SET_HANDLE_NOT_SET;
after this in advertising_init function i made this changes,
static void advertising_init(void)
{
ret_code_t err_code;
ble_advertising_init_t init;
memset(&init, 0, sizeof(init));
int8_t tx_power_level = -40;
sd_ble_gap_tx_power_set(BLE_GAP_TX_POWER_ROLE_ADV,m_adv_handle,tx_power_level);
init.advdata.name_type = BLE_ADVDATA_FULL_NAME;
init.advdata.include_appearance = true;
init.advdata.flags = BLE_GAP_ADV_FLAGS_LE_ONLY_GENERAL_DISC_MODE;
init.advdata.uuids_complete.uuid_cnt = sizeof(m_adv_uuids) / sizeof(m_adv_uuids[0]);
init.advdata.uuids_complete.p_uuids = m_adv_uuids;
init.config.ble_adv_fast_enabled = true;
init.config.ble_adv_fast_interval = APP_ADV_INTERVAL;
init.config.ble_adv_fast_timeout = APP_ADV_DURATION;
init.evt_handler = on_adv_evt;
err_code = ble_advertising_init(&m_advertising, &init);
APP_ERROR_CHECK(err_code);
ble_advertising_conn_cfg_tag_set(&m_advertising, APP_BLE_CONN_CFG_TAG);
}
e snippet that i have added ,Please make sure to check the error code returned by the call to sd_ble_gap_tx_power_set - if you do not check the error code then you will have no way to know whether the function completed successfully or not.
Furthermore, you should call the sd_ble_gap_tx_power_set after all of the SoftDevice configuration is already done, but before you start advertising.
I would recommend moving the call to the very last line of the advertising_init function.
Best regards,
Karl
Hello,
yeah, now i have added err_code in advertising_init function and i am printing the err_code value if its zero means its success right but i am getting 12239 like some strange value so its not working advertising itself not working so what to do.??
static void advertising_init(void)
{
ret_code_t err_code;
ble_advertising_init_t init;
memset(&init, 0, sizeof(init));
init.advdata.name_type = BLE_ADVDATA_FULL_NAME;
init.advdata.include_appearance = true;
init.advdata.flags = BLE_GAP_ADV_FLAGS_LE_ONLY_GENERAL_DISC_MODE;
init.advdata.uuids_complete.uuid_cnt = sizeof(m_adv_uuids) / sizeof(m_adv_uuids[0]);
init.advdata.uuids_complete.p_uuids = m_adv_uuids;
init.config.ble_adv_fast_enabled = true;
init.config.ble_adv_fast_interval = APP_ADV_INTERVAL;
init.config.ble_adv_fast_timeout = APP_ADV_DURATION;
init.evt_handler = on_adv_evt;
err_code = ble_advertising_init(&m_advertising, &init);
APP_ERROR_CHECK(err_code);
ble_advertising_conn_cfg_tag_set(&m_advertising, APP_BLE_CONN_CFG_TAG);
int8_t tx_power_level = -40;
err_code=sd_ble_gap_tx_power_set(BLE_GAP_TX_POWER_ROLE_ADV,m_adv_handle,tx_power_level);
printf("%d\r\n",err_code);
APP_ERROR_CHECK(err_code);
}
Correct, a non-zero error code indicates that the function failed.
Please make sure to have DEBUG defined in your preprocessor definitions like shown in the included image:
This will make your logger output a detailed error message whenever a non-NRF_SUCCESS error code is passed to an APP_ERROR_CHECK.
Please do this, and let me know what this error message reads.
Best regards,
Karl
Correct, a non-zero error code indicates that the function failed.
Please make sure to have DEBUG defined in your preprocessor definitions like shown in the included image:
This will make your logger output a detailed error message whenever a non-NRF_SUCCESS error code is passed to an APP_ERROR_CHECK.
Please do this, and let me know what this error message reads.
Best regards,
Karl
Hello ,
i have tried as what you mentioned above and resulting window is attached below , in this window sheet how to find out the error message and please tell me is that i followed in right way or if any suggestions please let me know.

thank you.
Hello,
mr.Karl i am still stuck in this concept , i couldn't solve the problem if have suggestions from you as soon as possible its very useful for me .
thank you.
Hello,
You need to add the DEBUG define into the preprocessor windows you showed in your previous comment in order for the logger to produce the error message. Please do this and let me know what this error message says.
Best regards,
Karl
Hello,
yes, i have added the DEBUG in preprocessor window and after build and upload the firmware i tried to debug then i got a error like this .please find the below attachment for more information.

thank you.
Which backend are you using for your logger, RTT?
I am not seeing any error message in your Debug Terminal window - do you have a separate RTT terminal application where the messages are routed?
Best regards,
Karl