Hello,
I am using nrf52840 and SDK 16.0.0
I have integrated two examples, ble_app_template and nrf_calendar example. Now I have a problem. I wanna update the manufacturer specific data every 1 sec, so I put the advertisement update function(advertisement_update()) inside the callback function so that the advertisement_update() can be called every 1 sec. My code looks like below. (advertising_init() , advertisement_update(), callback function, and main())
/**@brief Function for initializing the Advertising functionality. */ static void advertising_init(void) { ret_code_t err_code; ble_advertising_init_t init; // Struct containing advertising parameters // Build advertising data struct to pass into @ref ble_advertising_init. memset(&init, 0, sizeof(init)); ble_advdata_manuf_data_t manuf_data; // Variable to hold manufacturer specific data uint8_t eg_data[] = {0x12, 0x34, 0x56}; // Our data to advertise manuf_data.company_identifier = 0x0059; // Nordics company ID manuf_data.data.p_data = eg_data; manuf_data.data.size = sizeof(eg_data); init.advdata.p_manuf_specific_data = &manuf_data; init.advdata.name_type = BLE_ADVDATA_SHORT_NAME; // Use a shortened name init.advdata.short_name_len = 5; // Advertise only first 8 letters of name init.advdata.include_appearance = false; 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); } /**@ Function for updating Timestamp data **/ static void advertising_update(void) { ret_code_t err_code; static ble_advdata_t new_data; // SDK 16.x.x implementation is similar to advertising_init // Variables used for manufacturer specific data ble_advdata_manuf_data_t manuf_data_2; uint8_t timestamp_data[4]; // Encoding the timestamp uint8_t *time_ptr = timestamp_encode(nrf_cal_get_time()->tm_mon, nrf_cal_get_time()->tm_mday, nrf_cal_get_time()->tm_hour, nrf_cal_get_time()->tm_min, nrf_cal_get_time()->tm_sec); // Encoded timestamp into the data buffer. timestamp_data[0] = *(time_ptr); timestamp_data[1] = *(time_ptr+1); timestamp_data[2] = *(time_ptr+2); timestamp_data[3] = *(time_ptr+3); manuf_data_2.company_identifier = 0x0059; manuf_data_2.data.p_data = timestamp_data; manuf_data_2.data.size = sizeof(timestamp_data); new_data.p_manuf_specific_data = &manuf_data_2; new_data.name_type = BLE_ADVDATA_SHORT_NAME; new_data.short_name_len = 5; new_data.include_appearance = false; new_data.flags = BLE_GAP_ADV_FLAGS_LE_ONLY_GENERAL_DISC_MODE; new_data.uuids_complete.uuid_cnt = 0; new_data.uuids_complete.p_uuids = m_adv_uuids; //SDK16.x.x implementation will handle all buffering and encoding inside the update function err_code = ble_advertising_advdata_update(&m_advertising, &new_data, NULL); APP_ERROR_CHECK(err_code); } // Function to call back every 1 sec void calendar_stamp_update() { advertising_update(); if(run_time_updates) { print_current_time(); } } // Main function int main(void) { bool erase_bonds; /** Calendar example merging starts from here **/ uint8_t uart_byte; uint32_t year, month, day, hour, minute, second; NRF_CLOCK->EVENTS_HFCLKSTARTED = 0; NRF_CLOCK->TASKS_HFCLKSTART = 1; while(NRF_CLOCK->EVENTS_HFCLKSTARTED == 0); nrf_cal_init(); nrf_cal_set_callback(calendar_stamp_update, 1); uart_init(); /** Ble example code starts from here **/ // Initialize. //log_init(); timers_init(); buttons_leds_init(&erase_bonds); power_management_init(); ble_stack_init(); gap_params_init(); gatt_init(); advertising_init(); services_init(); conn_params_init(); peer_manager_init(); // Start execution. //NRF_LOG_INFO("Template example started."); application_timers_start(); advertising_start(erase_bonds); /** Calendar example **/ printf("\r\nCalendar demo\r\n\n"); printf("s - Set time\r\n"); printf("g - Get time\r\n"); printf("r - Run continuous time updates\r\n\n"); while (true) { if(app_uart_get(&uart_byte) == NRF_SUCCESS) { switch(uart_byte) { case 's': run_time_updates = false; year = (uint32_t)uart_get_parameter("Enter year", 1970, 2100); month = (uint32_t)uart_get_parameter("Enter month", 0, 11); day = (uint32_t)uart_get_parameter("Enter day", 1, 31); hour = (uint32_t)uart_get_parameter("Enter hour", 0, 23); minute = (uint32_t)uart_get_parameter("Enter minute", 0, 59); second = (uint32_t)uart_get_parameter("Enter second", 0, 59); nrf_cal_set_time(year, month, day, hour, minute, second); printf("Time set: "); printf("%s", nrf_cal_get_time_string(false)); printf("\r\n\n"); break; case 'g': print_current_time(); //advertising_update_mfg_data(); break; case 'r': run_time_updates = !run_time_updates; printf(run_time_updates ? "Time updates on\r\n" : "Time updates off\r\n"); break; } } } // Enter main loop. for (;;) { idle_state_handle(); } }
Problem #1
Whenever I reboot and try to execute nrf_set_callback() inside main(), it stops running and always returns NRF_BREAKPOINT_COND. What more confused me is when I put the advertisement_update() on the just main function (not inside the callback) it updates the data without any error.
void nrf_cal_set_callback(void (*callback)(void), uint32_t interval) { // Set the calendar callback, and set the callback interval in seconds cal_event_callback = callback; m_rtc_increment = interval; m_time += CAL_RTC->COUNTER / 8; CAL_RTC->TASKS_CLEAR = 1; CAL_RTC->CC[0] = interval * 8; }
Problem #2
When I tried to merge the two examples before, I had to change the RTC setting in nrf_calendar example from RTC0 to RTC2, because RTO0 was already used by SoftDevice in ble_app_template example. I was trying to use RTC1 so I did like below in nrf_calendar.h
#define CAL_RTC NRF_RTC1 #define CAL_RTC_IRQn RTC1_IRQn #define CAL_RTC_IRQHandler RTC1_IRQHandler #define CAL_RTC_IRQ_Priority 3
but the compile failed like below. I have no idea what that means. I appreciate if you could you explain it to me?
Always thanks to Nordic support team. Thanks !!