<!doctype html public "-//w3c//dtd html 4.0 transitional//en"> <html><head> <title>Static Call Graph - [centralCtrSys\centralCtrSys.axf]</title></head> <body><HR> <H1>Static Call Graph for image centralCtrSys\centralCtrSys.axf</H1><HR> <BR><P>#<CALLGRAPH># ARM Linker, 5060750: Last Updated: Tue Apr 30 14:33:30 2024 <BR><P> <H3>Maximum Stack Usage = 872 bytes + Unknown(Cycles, Untraceable Function Pointers)</H3><H3> Call chain for Maximum Stack Depth:</H3> Task_communication ⇒ task_communication_content ⇒ EC800_FTP_OTA_Upgrade ⇒ EC800_FTP_DownloadText ⇒ UpdateFirmware ⇒ writeFlashPage ⇒ FLASH_Write ⇒ HAL_FLASH_Program ⇒ FLASH_WaitForLastOperation <P> <H3> Mutually Recursive functions </H3> <LI><a href="#[1e]">ADC1_2_IRQHandler</a> ⇒ <a href="#[1e]">ADC1_2_IRQHandler</a><BR> <LI><a href="#[194]">print_object</a> ⇒ <a href="#[159]">print_value</a><BR> <LI><a href="#[18e]">print_array</a> ⇒ <a href="#[159]">print_value</a><BR> <LI><a href="#[b1]">cJSON_Delete</a> ⇒ <a href="#[b1]">cJSON_Delete</a><BR> <LI><a href="#[18a]">parse_object</a> ⇒ <a href="#[158]">parse_value</a><BR> <LI><a href="#[188]">parse_array</a> ⇒ <a href="#[158]">parse_value</a><BR> </UL> <P> <H3> Function Pointers </H3><UL> <LI><a href="#[1e]">ADC1_2_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[3b]">ADC3_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[6]">BusFault_Handler</a> from stm32f1xx_it.o(i.BusFault_Handler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[21]">CAN1_RX1_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[22]">CAN1_SCE_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[17]">DMA1_Channel1_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[18]">DMA1_Channel2_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[19]">DMA1_Channel3_IRQHandler</a> from stm32f1xx_it.o(i.DMA1_Channel3_IRQHandler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[1a]">DMA1_Channel4_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[1b]">DMA1_Channel5_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[1c]">DMA1_Channel6_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[1d]">DMA1_Channel7_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[44]">DMA2_Channel1_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[45]">DMA2_Channel2_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[46]">DMA2_Channel3_IRQHandler</a> from stm32f1xx_it.o(i.DMA2_Channel3_IRQHandler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[47]">DMA2_Channel4_5_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[9]">DebugMon_Handler</a> from stm32f1xx_it.o(i.DebugMon_Handler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[12]">EXTI0_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[34]">EXTI15_10_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[13]">EXTI1_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[14]">EXTI2_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[15]">EXTI3_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[16]">EXTI4_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[23]">EXTI9_5_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[10]">FLASH_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[3c]">FSMC_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[4]">HardFault_Handler</a> from stm32f1xx_it.o(i.HardFault_Handler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[2c]">I2C1_ER_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[2b]">I2C1_EV_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[2e]">I2C2_ER_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[2d]">I2C2_EV_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[5]">MemManage_Handler</a> from stm32f1xx_it.o(i.MemManage_Handler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[3]">NMI_Handler</a> from stm32f1xx_it.o(i.NMI_Handler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[d]">PVD_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[a]">PendSV_Handler</a> from port.o(.emb_text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[11]">RCC_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[35]">RTC_Alarm_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[f]">RTC_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[2]">Reset_Handler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[3d]">SDIO_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[2f]">SPI1_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[30]">SPI2_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[3f]">SPI3_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[8]">SVC_Handler</a> from port.o(.emb_text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[51]">StartDefaultTask</a> from freertos.o(i.StartDefaultTask) referenced from freertos.o(i.MX_FREERTOS_Init) <LI><a href="#[b]">SysTick_Handler</a> from port.o(i.SysTick_Handler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[49]">SystemInit</a> from system_stm32f1xx.o(i.SystemInit) referenced from startup_stm32f103xe.o(.text) <LI><a href="#[e]">TAMPER_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[24]">TIM1_BRK_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[27]">TIM1_CC_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[26]">TIM1_TRG_COM_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[25]">TIM1_UP_IRQHandler</a> from stm32f1xx_it.o(i.TIM1_UP_IRQHandler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[28]">TIM2_IRQHandler</a> from stm32f1xx_it.o(i.TIM2_IRQHandler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[29]">TIM3_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[2a]">TIM4_IRQHandler</a> from stm32f1xx_it.o(i.TIM4_IRQHandler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[3e]">TIM5_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[42]">TIM6_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[43]">TIM7_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[37]">TIM8_BRK_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[3a]">TIM8_CC_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[39]">TIM8_TRG_COM_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[38]">TIM8_UP_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[53]">Task_communication</a> from freertos.o(i.Task_communication) referenced from freertos.o(i.MX_FREERTOS_Init) <LI><a href="#[52]">Task_ec800_upload</a> from freertos.o(i.Task_ec800_upload) referenced from freertos.o(i.MX_FREERTOS_Init) <LI><a href="#[50]">Time2_Callback</a> from freertos.o(i.Time2_Callback) referenced from freertos.o(i.MX_FREERTOS_Init) <LI><a href="#[5a]">TimerCallback</a> from cmsis_os2.o(i.TimerCallback) referenced from cmsis_os2.o(i.osTimerNew) <LI><a href="#[40]">UART4_IRQHandler</a> from stm32f1xx_it.o(i.UART4_IRQHandler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[41]">UART5_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[4f]">UART_DMAAbortOnError</a> from stm32f1xx_hal_uart.o(i.UART_DMAAbortOnError) referenced from stm32f1xx_hal_uart.o(i.HAL_UART_IRQHandler) <LI><a href="#[56]">UART_DMAError</a> from stm32f1xx_hal_uart.o(i.UART_DMAError) referenced from stm32f1xx_hal_uart.o(i.UART_Start_Receive_DMA) <LI><a href="#[54]">UART_DMAReceiveCplt</a> from stm32f1xx_hal_uart.o(i.UART_DMAReceiveCplt) referenced from stm32f1xx_hal_uart.o(i.UART_Start_Receive_DMA) <LI><a href="#[55]">UART_DMARxHalfCplt</a> from stm32f1xx_hal_uart.o(i.UART_DMARxHalfCplt) referenced from stm32f1xx_hal_uart.o(i.UART_Start_Receive_DMA) <LI><a href="#[31]">USART1_IRQHandler</a> from stm32f1xx_it.o(i.USART1_IRQHandler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[32]">USART2_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[33]">USART3_IRQHandler</a> from stm32f1xx_it.o(i.USART3_IRQHandler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[36]">USBWakeUp_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[1f]">USB_HP_CAN1_TX_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[20]">USB_LP_CAN1_RX0_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[7]">UsageFault_Handler</a> from stm32f1xx_it.o(i.UsageFault_Handler) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[c]">WWDG_IRQHandler</a> from startup_stm32f103xe.o(.text) referenced from startup_stm32f103xe.o(RESET) <LI><a href="#[4a]">__main</a> from entry.o(.ARM.Collect$$$$00000000) referenced from startup_stm32f103xe.o(.text) <LI><a href="#[4c]">_sbackspace</a> from _sgetc.o(.text) referenced from __0sscanf.o(.text) <LI><a href="#[4d]">_scanf_char_input</a> from scanf_char.o(.text) referenced from scanf_char.o(.text) <LI><a href="#[4b]">_sgetc</a> from _sgetc.o(.text) referenced from __0sscanf.o(.text) <LI><a href="#[58]">_snputc</a> from printfa.o(i._snputc) referenced from printfa.o(i.__0snprintf) <LI><a href="#[59]">_sputc</a> from printfa.o(i._sputc) referenced from printfa.o(i.__0sprintf) <LI><a href="#[57]">fputc</a> from main.o(i.fputc) referenced from printfa.o(i.__0printf) <LI><a href="#[1]">free</a> from malloc.o(i.free) referenced 2 times from cjson.o(.data) <LI><a href="#[4e]">isspace</a> from isspace_o.o(.text) referenced from scanf_char.o(.text) <LI><a href="#[48]">main</a> from main.o(i.main) referenced from entry9a.o(.ARM.Collect$$$$0000000B) <LI><a href="#[0]">malloc</a> from malloc.o(i.malloc) referenced 2 times from cjson.o(.data) <LI><a href="#[5c]">prvIdleTask</a> from tasks.o(i.prvIdleTask) referenced from tasks.o(i.vTaskStartScheduler) <LI><a href="#[5b]">prvTaskExitError</a> from port.o(i.prvTaskExitError) referenced from port.o(i.pxPortInitialiseStack) <LI><a href="#[5d]">prvTimerTask</a> from timers.o(i.prvTimerTask) referenced from timers.o(i.xTimerCreateTimerTask) </UL> <P> <H3> Global Symbols </H3> <P><STRONG><a name="[4a]"></a>__main</STRONG> (Thumb, 0 bytes, Stack size unknown bytes, entry.o(.ARM.Collect$$$$00000000)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(.text) </UL> <P><STRONG><a name="[1de]"></a>_main_stk</STRONG> (Thumb, 0 bytes, Stack size unknown bytes, entry2.o(.ARM.Collect$$$$00000001)) <P><STRONG><a name="[5e]"></a>_main_scatterload</STRONG> (Thumb, 0 bytes, Stack size unknown bytes, entry5.o(.ARM.Collect$$$$00000004)) <BR><BR>[Calls]<UL><LI><a href="#[5f]">>></a> __scatterload </UL> <P><STRONG><a name="[87]"></a>__main_after_scatterload</STRONG> (Thumb, 0 bytes, Stack size unknown bytes, entry5.o(.ARM.Collect$$$$00000004)) <BR><BR>[Called By]<UL><LI><a href="#[5f]">>></a> __scatterload </UL> <P><STRONG><a name="[1df]"></a>_main_clock</STRONG> (Thumb, 0 bytes, Stack size unknown bytes, entry7b.o(.ARM.Collect$$$$00000008)) <P><STRONG><a name="[1e0]"></a>_main_cpp_init</STRONG> (Thumb, 0 bytes, Stack size unknown bytes, entry8b.o(.ARM.Collect$$$$0000000A)) <P><STRONG><a name="[1e1]"></a>_main_init</STRONG> (Thumb, 0 bytes, Stack size unknown bytes, entry9a.o(.ARM.Collect$$$$0000000B)) <P><STRONG><a name="[1e2]"></a>__rt_final_cpp</STRONG> (Thumb, 0 bytes, Stack size unknown bytes, entry10a.o(.ARM.Collect$$$$0000000D)) <P><STRONG><a name="[1e3]"></a>__rt_final_exit</STRONG> (Thumb, 0 bytes, Stack size unknown bytes, entry11a.o(.ARM.Collect$$$$0000000F)) <P><STRONG><a name="[8]"></a>SVC_Handler</STRONG> (Thumb, 32 bytes, Stack size 0 bytes, port.o(.emb_text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[1d4]"></a>__asm___6_port_c_39a90d8d__prvStartFirstTask</STRONG> (Thumb, 28 bytes, Stack size 0 bytes, port.o(.emb_text)) <BR><BR>[Called By]<UL><LI><a href="#[1d0]">>></a> xPortStartScheduler </UL> <P><STRONG><a name="[a]"></a>PendSV_Handler</STRONG> (Thumb, 72 bytes, Stack size 0 bytes, port.o(.emb_text)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = PendSV_Handler ⇒ vTaskSwitchContext </UL> <BR>[Calls]<UL><LI><a href="#[60]">>></a> vTaskSwitchContext </UL> <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[1c9]"></a>vPortGetIPSR</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, port.o(.emb_text)) <BR><BR>[Called By]<UL><LI><a href="#[1c8]">>></a> vPortValidateInterruptPriority </UL> <P><STRONG><a name="[2]"></a>Reset_Handler</STRONG> (Thumb, 8 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[1e]"></a>ADC1_2_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR><BR>[Calls]<UL><LI><a href="#[1e]">>></a> ADC1_2_IRQHandler </UL> <BR>[Called By]<UL><LI><a href="#[1e]">>></a> ADC1_2_IRQHandler </UL> <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[3b]"></a>ADC3_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[21]"></a>CAN1_RX1_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[22]"></a>CAN1_SCE_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[17]"></a>DMA1_Channel1_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[18]"></a>DMA1_Channel2_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[1a]"></a>DMA1_Channel4_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[1b]"></a>DMA1_Channel5_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[1c]"></a>DMA1_Channel6_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[1d]"></a>DMA1_Channel7_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[44]"></a>DMA2_Channel1_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[45]"></a>DMA2_Channel2_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[47]"></a>DMA2_Channel4_5_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[12]"></a>EXTI0_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[34]"></a>EXTI15_10_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[13]"></a>EXTI1_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[14]"></a>EXTI2_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[15]"></a>EXTI3_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[16]"></a>EXTI4_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[23]"></a>EXTI9_5_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[10]"></a>FLASH_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[3c]"></a>FSMC_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[2c]"></a>I2C1_ER_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[2b]"></a>I2C1_EV_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[2e]"></a>I2C2_ER_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[2d]"></a>I2C2_EV_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[d]"></a>PVD_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[11]"></a>RCC_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[35]"></a>RTC_Alarm_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[f]"></a>RTC_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[3d]"></a>SDIO_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[2f]"></a>SPI1_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[30]"></a>SPI2_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[3f]"></a>SPI3_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[e]"></a>TAMPER_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[24]"></a>TIM1_BRK_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[27]"></a>TIM1_CC_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[26]"></a>TIM1_TRG_COM_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[29]"></a>TIM3_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[3e]"></a>TIM5_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[42]"></a>TIM6_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[43]"></a>TIM7_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[37]"></a>TIM8_BRK_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[3a]"></a>TIM8_CC_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[39]"></a>TIM8_TRG_COM_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[38]"></a>TIM8_UP_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[41]"></a>UART5_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[32]"></a>USART2_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[36]"></a>USBWakeUp_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[1f]"></a>USB_HP_CAN1_TX_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[20]"></a>USB_LP_CAN1_RX0_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[c]"></a>WWDG_IRQHandler</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, startup_stm32f103xe.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[80]"></a>__aeabi_llsr</STRONG> (Thumb, 32 bytes, Stack size 0 bytes, llushr.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[7f]">>></a> __aeabi_d2iz <LI><a href="#[cd]">>></a> HAL_FLASH_Program <LI><a href="#[85]">>></a> _dsqrt <LI><a href="#[82]">>></a> __aeabi_uldivmod <LI><a href="#[75]">>></a> _double_epilogue <LI><a href="#[86]">>></a> __aeabi_d2ulz </UL> <P><STRONG><a name="[1e4]"></a>_ll_ushift_r</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, llushr.o(.text), UNUSED) <P><STRONG><a name="[61]"></a>__rt_ctype_table</STRONG> (Thumb, 4 bytes, Stack size 0 bytes, ctype_o.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[96]">>></a> EC800_getIMSI <LI><a href="#[4e]">>></a> isspace <LI><a href="#[6b]">>></a> strtol </UL> <P><STRONG><a name="[4e]"></a>isspace</STRONG> (Thumb, 18 bytes, Stack size 8 bytes, isspace_o.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = isspace </UL> <BR>[Calls]<UL><LI><a href="#[61]">>></a> __rt_ctype_table </UL> <BR>[Address Reference Count : 1]<UL><LI> scanf_char.o(.text) </UL> <P><STRONG><a name="[15a]"></a>tolower</STRONG> (Thumb, 12 bytes, Stack size 0 bytes, tolower.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[155]">>></a> cJSON_strcasecmp </UL> <P><STRONG><a name="[15b]"></a>__aeabi_memcpy</STRONG> (Thumb, 36 bytes, Stack size 0 bytes, memcpya.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[194]">>></a> print_object <LI><a href="#[18e]">>></a> print_array <LI><a href="#[162]">>></a> ensure <LI><a href="#[153]">>></a> cJSON_strdup <LI><a href="#[1a4]">>></a> prvCopyDataToQueue <LI><a href="#[1a3]">>></a> prvCopyDataFromQueue <LI><a href="#[128]">>></a> extract_data_as_uint32 </UL> <P><STRONG><a name="[a2]"></a>__aeabi_memcpy4</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, memcpya.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[96]">>></a> EC800_getIMSI </UL> <P><STRONG><a name="[1e5]"></a>__aeabi_memcpy8</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, memcpya.o(.text), UNUSED) <P><STRONG><a name="[63]"></a>__aeabi_memset</STRONG> (Thumb, 14 bytes, Stack size 0 bytes, memseta.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[1ac]">>></a> prvInitialiseNewTask <LI><a href="#[64]">>></a> memset <LI><a href="#[62]">>></a> __aeabi_memclr <LI><a href="#[9c]">>></a> UpdateFirmware </UL> <P><STRONG><a name="[1e6]"></a>__aeabi_memset4</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, memseta.o(.text), UNUSED) <P><STRONG><a name="[1e7]"></a>__aeabi_memset8</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, memseta.o(.text), UNUSED) <P><STRONG><a name="[62]"></a>__aeabi_memclr</STRONG> (Thumb, 4 bytes, Stack size 0 bytes, memseta.o(.text)) <BR><BR>[Calls]<UL><LI><a href="#[63]">>></a> __aeabi_memset </UL> <BR>[Called By]<UL><LI><a href="#[98]">>></a> EC800_extractSignal <LI><a href="#[b6]">>></a> EC800_stateTransition_use <LI><a href="#[a8]">>></a> EC800_readGnssDate <LI><a href="#[93]">>></a> EC800M_link <LI><a href="#[8e]">>></a> EC800M_RecRespond <LI><a href="#[128]">>></a> extract_data_as_uint32 </UL> <P><STRONG><a name="[94]"></a>__aeabi_memclr4</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, memseta.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[194]">>></a> print_object <LI><a href="#[18e]">>></a> print_array <LI><a href="#[154]">>></a> cJSON_New_Item <LI><a href="#[b6]">>></a> EC800_stateTransition_use <LI><a href="#[120]">>></a> SystemClock_Config <LI><a href="#[b9]">>></a> requesting_Fence_Data <LI><a href="#[b8]">>></a> Login_Topic <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[ba]">>></a> EC800_time_calibration <LI><a href="#[b7]">>></a> EC800_subscribeToTopic <LI><a href="#[a7]">>></a> EC800_publishMessage <LI><a href="#[93]">>></a> EC800M_link <LI><a href="#[9c]">>></a> UpdateFirmware <LI><a href="#[9f]">>></a> EC800_LogIn_FTP <LI><a href="#[9a]">>></a> EC800_FTP_DownloadText </UL> <P><STRONG><a name="[1e8]"></a>__aeabi_memclr8</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, memseta.o(.text), UNUSED) <P><STRONG><a name="[64]"></a>memset</STRONG> (Thumb, 18 bytes, Stack size 8 bytes, memseta.o(.text), UNUSED) <BR><BR>[Calls]<UL><LI><a href="#[63]">>></a> __aeabi_memset </UL> <P><STRONG><a name="[8f]"></a>strstr</STRONG> (Thumb, 36 bytes, Stack size 12 bytes, strstr.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 12<LI>Call Chain = strstr </UL> <BR>[Called By]<UL><LI><a href="#[a9]">>></a> NMEA_GNRMC_Analysis <LI><a href="#[a8]">>></a> EC800_readGnssDate <LI><a href="#[96]">>></a> EC800_getIMSI <LI><a href="#[93]">>></a> EC800M_link <LI><a href="#[8e]">>></a> EC800M_RecRespond <LI><a href="#[128]">>></a> extract_data_as_uint32 </UL> <P><STRONG><a name="[185]"></a>strncpy</STRONG> (Thumb, 24 bytes, Stack size 8 bytes, strncpy.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = strncpy </UL> <BR>[Called By]<UL><LI><a href="#[a6]">>></a> parseServerTime </UL> <P><STRONG><a name="[af]"></a>strchr</STRONG> (Thumb, 20 bytes, Stack size 0 bytes, strchr.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[195]">>></a> print_string_ptr <LI><a href="#[ae]">>></a> EC800_respondParse </UL> <P><STRONG><a name="[8b]"></a>strlen</STRONG> (Thumb, 14 bytes, Stack size 0 bytes, strlen.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[190]">>></a> update <LI><a href="#[194]">>></a> print_object <LI><a href="#[18e]">>></a> print_array <LI><a href="#[153]">>></a> cJSON_strdup <LI><a href="#[b6]">>></a> EC800_stateTransition_use <LI><a href="#[b9]">>></a> requesting_Fence_Data <LI><a href="#[b8]">>></a> Login_Topic <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[ba]">>></a> EC800_time_calibration <LI><a href="#[96]">>></a> EC800_getIMSI <LI><a href="#[88]">>></a> Accept_and_Compare_Str <LI><a href="#[128]">>></a> extract_data_as_uint32 </UL> <P><STRONG><a name="[18f]"></a>strcpy</STRONG> (Thumb, 18 bytes, Stack size 0 bytes, strcpy.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[159]">>></a> print_value <LI><a href="#[195]">>></a> print_string_ptr <LI><a href="#[194]">>></a> print_object <LI><a href="#[18e]">>></a> print_array </UL> <P><STRONG><a name="[18d]"></a>strncmp</STRONG> (Thumb, 30 bytes, Stack size 12 bytes, strncmp.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 12<LI>Call Chain = strncmp </UL> <BR>[Called By]<UL><LI><a href="#[158]">>></a> parse_value </UL> <P><STRONG><a name="[a1]"></a>strtok</STRONG> (Thumb, 62 bytes, Stack size 16 bytes, strtok.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = strtok </UL> <BR>[Called By]<UL><LI><a href="#[98]">>></a> EC800_extractSignal </UL> <P><STRONG><a name="[65]"></a>__0sscanf</STRONG> (Thumb, 48 bytes, Stack size 72 bytes, __0sscanf.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 216<LI>Call Chain = __0sscanf ⇒ __vfscanf_char ⇒ __vfscanf ⇒ _scanf_int </UL> <BR>[Calls]<UL><LI><a href="#[66]">>></a> __vfscanf_char </UL> <BR>[Called By]<UL><LI><a href="#[9a]">>></a> EC800_FTP_DownloadText </UL> <P><STRONG><a name="[67]"></a>_scanf_int</STRONG> (Thumb, 332 bytes, Stack size 56 bytes, _scanf_int.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 56<LI>Call Chain = _scanf_int </UL> <BR>[Calls]<UL><LI><a href="#[68]">>></a> _chval </UL> <BR>[Called By]<UL><LI><a href="#[83]">>></a> __vfscanf </UL> <P><STRONG><a name="[69]"></a>atoi</STRONG> (Thumb, 26 bytes, Stack size 16 bytes, atoi.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 88<LI>Call Chain = atoi ⇒ strtol ⇒ _strtoul </UL> <BR>[Calls]<UL><LI><a href="#[6b]">>></a> strtol <LI><a href="#[6a]">>></a> __aeabi_errno_addr </UL> <BR>[Called By]<UL><LI><a href="#[98]">>></a> EC800_extractSignal <LI><a href="#[a6]">>></a> parseServerTime </UL> <P><STRONG><a name="[6c]"></a>__aeabi_fadd</STRONG> (Thumb, 164 bytes, Stack size 16 bytes, fadd.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 20<LI>Call Chain = __aeabi_fadd ⇒ _float_epilogue </UL> <BR>[Calls]<UL><LI><a href="#[6e]">>></a> _float_round <LI><a href="#[6d]">>></a> _float_epilogue </UL> <BR>[Called By]<UL><LI><a href="#[a9]">>></a> NMEA_GNRMC_Analysis <LI><a href="#[6f]">>></a> __aeabi_fsub <LI><a href="#[141]">>></a> atk_ms6050_dmp_get_data <LI><a href="#[70]">>></a> __aeabi_frsub </UL> <P><STRONG><a name="[6f]"></a>__aeabi_fsub</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, fadd.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 20<LI>Call Chain = __aeabi_fsub ⇒ __aeabi_fadd ⇒ _float_epilogue </UL> <BR>[Calls]<UL><LI><a href="#[6c]">>></a> __aeabi_fadd </UL> <BR>[Called By]<UL><LI><a href="#[167]">>></a> isTurning <LI><a href="#[141]">>></a> atk_ms6050_dmp_get_data </UL> <P><STRONG><a name="[70]"></a>__aeabi_frsub</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, fadd.o(.text), UNUSED) <BR><BR>[Calls]<UL><LI><a href="#[6c]">>></a> __aeabi_fadd </UL> <P><STRONG><a name="[11d]"></a>__aeabi_fmul</STRONG> (Thumb, 100 bytes, Stack size 8 bytes, fmul.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = __aeabi_fmul </UL> <BR>[Called By]<UL><LI><a href="#[a9]">>></a> NMEA_GNRMC_Analysis <LI><a href="#[141]">>></a> atk_ms6050_dmp_get_data </UL> <P><STRONG><a name="[71]"></a>__aeabi_fdiv</STRONG> (Thumb, 124 bytes, Stack size 8 bytes, fdiv.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = __aeabi_fdiv </UL> <BR>[Calls]<UL><LI><a href="#[6e]">>></a> _float_round </UL> <BR>[Called By]<UL><LI><a href="#[a9]">>></a> NMEA_GNRMC_Analysis <LI><a href="#[141]">>></a> atk_ms6050_dmp_get_data </UL> <P><STRONG><a name="[72]"></a>__aeabi_dadd</STRONG> (Thumb, 322 bytes, Stack size 48 bytes, dadd.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 88<LI>Call Chain = __aeabi_dadd ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[74]">>></a> __aeabi_lasr <LI><a href="#[73]">>></a> __aeabi_llsl <LI><a href="#[76]">>></a> _double_round <LI><a href="#[75]">>></a> _double_epilogue </UL> <BR>[Called By]<UL><LI><a href="#[77]">>></a> __aeabi_dsub <LI><a href="#[189]">>></a> parse_number <LI><a href="#[78]">>></a> __aeabi_drsub <LI><a href="#[168]">>></a> lowPassFilter <LI><a href="#[165]">>></a> getAngularVelocity <LI><a href="#[136]">>></a> _fp_digits <LI><a href="#[166]">>></a> pow <LI><a href="#[164]">>></a> floor <LI><a href="#[13b]">>></a> asin <LI><a href="#[12e]">>></a> __kernel_poly <LI><a href="#[132]">>></a> __mathlib_dbl_infnan2 <LI><a href="#[13f]">>></a> atan </UL> <P><STRONG><a name="[77]"></a>__aeabi_dsub</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, dadd.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 88<LI>Call Chain = __aeabi_dsub ⇒ __aeabi_dadd ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[72]">>></a> __aeabi_dadd </UL> <BR>[Called By]<UL><LI><a href="#[191]">>></a> print_number <LI><a href="#[189]">>></a> parse_number <LI><a href="#[166]">>></a> pow <LI><a href="#[140]">>></a> atan2 <LI><a href="#[13b]">>></a> asin <LI><a href="#[13f]">>></a> atan </UL> <P><STRONG><a name="[78]"></a>__aeabi_drsub</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, dadd.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 88<LI>Call Chain = __aeabi_drsub ⇒ __aeabi_dadd ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[72]">>></a> __aeabi_dadd </UL> <BR>[Called By]<UL><LI><a href="#[166]">>></a> pow <LI><a href="#[164]">>></a> floor <LI><a href="#[140]">>></a> atan2 <LI><a href="#[13b]">>></a> asin <LI><a href="#[13f]">>></a> atan </UL> <P><STRONG><a name="[79]"></a>__aeabi_dmul</STRONG> (Thumb, 228 bytes, Stack size 48 bytes, dmul.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 88<LI>Call Chain = __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[75]">>></a> _double_epilogue </UL> <BR>[Called By]<UL><LI><a href="#[189]">>></a> parse_number <LI><a href="#[168]">>></a> lowPassFilter <LI><a href="#[141]">>></a> atk_ms6050_dmp_get_data <LI><a href="#[136]">>></a> _fp_digits <LI><a href="#[166]">>></a> pow <LI><a href="#[13b]">>></a> asin <LI><a href="#[12e]">>></a> __kernel_poly <LI><a href="#[13f]">>></a> atan </UL> <P><STRONG><a name="[7a]"></a>__aeabi_ddiv</STRONG> (Thumb, 222 bytes, Stack size 32 bytes, ddiv.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 40<LI>Call Chain = __aeabi_ddiv ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[76]">>></a> _double_round </UL> <BR>[Called By]<UL><LI><a href="#[136]">>></a> _fp_digits <LI><a href="#[166]">>></a> pow <LI><a href="#[140]">>></a> atan2 <LI><a href="#[13b]">>></a> asin <LI><a href="#[133]">>></a> __mathlib_dbl_invalid <LI><a href="#[12f]">>></a> __mathlib_dbl_divzero <LI><a href="#[13f]">>></a> atan </UL> <P><STRONG><a name="[7b]"></a>__aeabi_i2f</STRONG> (Thumb, 18 bytes, Stack size 0 bytes, fflti.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 4<LI>Call Chain = __aeabi_i2f ⇒ _float_epilogue </UL> <BR>[Calls]<UL><LI><a href="#[6d]">>></a> _float_epilogue </UL> <BR>[Called By]<UL><LI><a href="#[141]">>></a> atk_ms6050_dmp_get_data </UL> <P><STRONG><a name="[7c]"></a>__aeabi_ui2f</STRONG> (Thumb, 10 bytes, Stack size 0 bytes, ffltui.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 4<LI>Call Chain = __aeabi_ui2f ⇒ _float_epilogue </UL> <BR>[Calls]<UL><LI><a href="#[6d]">>></a> _float_epilogue </UL> <BR>[Called By]<UL><LI><a href="#[a9]">>></a> NMEA_GNRMC_Analysis </UL> <P><STRONG><a name="[7d]"></a>__aeabi_i2d</STRONG> (Thumb, 34 bytes, Stack size 16 bytes, dflti.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 56<LI>Call Chain = __aeabi_i2d ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[75]">>></a> _double_epilogue </UL> <BR>[Called By]<UL><LI><a href="#[191]">>></a> print_number <LI><a href="#[189]">>></a> parse_number <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[165]">>></a> getAngularVelocity <LI><a href="#[166]">>></a> pow </UL> <P><STRONG><a name="[7e]"></a>__aeabi_ui2d</STRONG> (Thumb, 26 bytes, Stack size 16 bytes, dfltui.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 56<LI>Call Chain = __aeabi_ui2d ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[75]">>></a> _double_epilogue </UL> <BR>[Called By]<UL><LI><a href="#[b9]">>></a> requesting_Fence_Data <LI><a href="#[b8]">>></a> Login_Topic <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[ba]">>></a> EC800_time_calibration </UL> <P><STRONG><a name="[11e]"></a>__aeabi_f2uiz</STRONG> (Thumb, 40 bytes, Stack size 0 bytes, ffixui.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[a9]">>></a> NMEA_GNRMC_Analysis </UL> <P><STRONG><a name="[7f]"></a>__aeabi_d2iz</STRONG> (Thumb, 62 bytes, Stack size 16 bytes, dfixi.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = __aeabi_d2iz </UL> <BR>[Calls]<UL><LI><a href="#[80]">>></a> __aeabi_llsr </UL> <BR>[Called By]<UL><LI><a href="#[c0]">>></a> cJSON_CreateNumber <LI><a href="#[189]">>></a> parse_number </UL> <P><STRONG><a name="[143]"></a>__aeabi_f2d</STRONG> (Thumb, 38 bytes, Stack size 0 bytes, f2d.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[167]">>></a> isTurning <LI><a href="#[168]">>></a> lowPassFilter <LI><a href="#[141]">>></a> atk_ms6050_dmp_get_data </UL> <P><STRONG><a name="[192]"></a>__aeabi_cdcmpeq</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, cdcmple.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[191]">>></a> print_number </UL> <P><STRONG><a name="[193]"></a>__aeabi_cdcmple</STRONG> (Thumb, 48 bytes, Stack size 0 bytes, cdcmple.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[191]">>></a> print_number </UL> <P><STRONG><a name="[137]"></a>__aeabi_cdrcmple</STRONG> (Thumb, 48 bytes, Stack size 0 bytes, cdrcmple.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[191]">>></a> print_number <LI><a href="#[167]">>></a> isTurning <LI><a href="#[136]">>></a> _fp_digits <LI><a href="#[166]">>></a> pow <LI><a href="#[164]">>></a> floor </UL> <P><STRONG><a name="[81]"></a>__aeabi_d2f</STRONG> (Thumb, 56 bytes, Stack size 8 bytes, d2f.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = __aeabi_d2f </UL> <BR>[Calls]<UL><LI><a href="#[6e]">>></a> _float_round </UL> <BR>[Called By]<UL><LI><a href="#[167]">>></a> isTurning <LI><a href="#[168]">>></a> lowPassFilter <LI><a href="#[165]">>></a> getAngularVelocity <LI><a href="#[141]">>></a> atk_ms6050_dmp_get_data </UL> <P><STRONG><a name="[1e9]"></a>__aeabi_uidiv</STRONG> (Thumb, 0 bytes, Stack size 12 bytes, uidiv.o(.text), UNUSED) <P><STRONG><a name="[13a]"></a>__aeabi_uidivmod</STRONG> (Thumb, 44 bytes, Stack size 12 bytes, uidiv.o(.text), UNUSED) <BR><BR>[Called By]<UL><LI><a href="#[12b]">>></a> _printf_core </UL> <P><STRONG><a name="[82]"></a>__aeabi_uldivmod</STRONG> (Thumb, 98 bytes, Stack size 40 bytes, uldiv.o(.text), UNUSED) <BR><BR>[Calls]<UL><LI><a href="#[80]">>></a> __aeabi_llsr <LI><a href="#[73]">>></a> __aeabi_llsl </UL> <BR>[Called By]<UL><LI><a href="#[12b]">>></a> _printf_core <LI><a href="#[136]">>></a> _fp_digits </UL> <P><STRONG><a name="[73]"></a>__aeabi_llsl</STRONG> (Thumb, 30 bytes, Stack size 0 bytes, llshl.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[72]">>></a> __aeabi_dadd <LI><a href="#[82]">>></a> __aeabi_uldivmod <LI><a href="#[75]">>></a> _double_epilogue <LI><a href="#[86]">>></a> __aeabi_d2ulz </UL> <P><STRONG><a name="[1ea]"></a>_ll_shift_l</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, llshl.o(.text), UNUSED) <P><STRONG><a name="[74]"></a>__aeabi_lasr</STRONG> (Thumb, 36 bytes, Stack size 0 bytes, llsshr.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[72]">>></a> __aeabi_dadd </UL> <P><STRONG><a name="[1eb]"></a>_ll_sshift_r</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, llsshr.o(.text), UNUSED) <P><STRONG><a name="[68]"></a>_chval</STRONG> (Thumb, 28 bytes, Stack size 0 bytes, _chval.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[84]">>></a> _strtoul <LI><a href="#[67]">>></a> _scanf_int </UL> <P><STRONG><a name="[66]"></a>__vfscanf_char</STRONG> (Thumb, 20 bytes, Stack size 0 bytes, scanf_char.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 144<LI>Call Chain = __vfscanf_char ⇒ __vfscanf ⇒ _scanf_int </UL> <BR>[Calls]<UL><LI><a href="#[83]">>></a> __vfscanf </UL> <BR>[Called By]<UL><LI><a href="#[65]">>></a> __0sscanf </UL> <P><STRONG><a name="[4b]"></a>_sgetc</STRONG> (Thumb, 30 bytes, Stack size 0 bytes, _sgetc.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> __0sscanf.o(.text) </UL> <P><STRONG><a name="[4c]"></a>_sbackspace</STRONG> (Thumb, 34 bytes, Stack size 0 bytes, _sgetc.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> __0sscanf.o(.text) </UL> <P><STRONG><a name="[6b]"></a>strtol</STRONG> (Thumb, 112 bytes, Stack size 32 bytes, strtol.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 72<LI>Call Chain = strtol ⇒ _strtoul </UL> <BR>[Calls]<UL><LI><a href="#[61]">>></a> __rt_ctype_table <LI><a href="#[84]">>></a> _strtoul <LI><a href="#[6a]">>></a> __aeabi_errno_addr </UL> <BR>[Called By]<UL><LI><a href="#[69]">>></a> atoi </UL> <P><STRONG><a name="[1ec]"></a>__I$use$fp</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, iusefp.o(.text), UNUSED) <P><STRONG><a name="[6e]"></a>_float_round</STRONG> (Thumb, 18 bytes, Stack size 0 bytes, fepilogue.o(.text)) <BR><BR>[Called By]<UL><LI><a href="#[71]">>></a> __aeabi_fdiv <LI><a href="#[6c]">>></a> __aeabi_fadd <LI><a href="#[81]">>></a> __aeabi_d2f </UL> <P><STRONG><a name="[6d]"></a>_float_epilogue</STRONG> (Thumb, 92 bytes, Stack size 4 bytes, fepilogue.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 4<LI>Call Chain = _float_epilogue </UL> <BR>[Called By]<UL><LI><a href="#[7c]">>></a> __aeabi_ui2f <LI><a href="#[6c]">>></a> __aeabi_fadd <LI><a href="#[7b]">>></a> __aeabi_i2f </UL> <P><STRONG><a name="[76]"></a>_double_round</STRONG> (Thumb, 30 bytes, Stack size 8 bytes, depilogue.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = _double_round </UL> <BR>[Called By]<UL><LI><a href="#[72]">>></a> __aeabi_dadd <LI><a href="#[7a]">>></a> __aeabi_ddiv <LI><a href="#[85]">>></a> _dsqrt <LI><a href="#[75]">>></a> _double_epilogue </UL> <P><STRONG><a name="[75]"></a>_double_epilogue</STRONG> (Thumb, 156 bytes, Stack size 32 bytes, depilogue.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 40<LI>Call Chain = _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[80]">>></a> __aeabi_llsr <LI><a href="#[73]">>></a> __aeabi_llsl <LI><a href="#[76]">>></a> _double_round </UL> <BR>[Called By]<UL><LI><a href="#[7d]">>></a> __aeabi_i2d <LI><a href="#[79]">>></a> __aeabi_dmul <LI><a href="#[72]">>></a> __aeabi_dadd <LI><a href="#[7e]">>></a> __aeabi_ui2d </UL> <P><STRONG><a name="[131]"></a>__ARM_scalbn</STRONG> (Thumb, 46 bytes, Stack size 16 bytes, dscalb.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = __ARM_scalbn </UL> <BR>[Called By]<UL><LI><a href="#[166]">>></a> pow <LI><a href="#[13b]">>></a> asin <LI><a href="#[135]">>></a> __mathlib_dbl_underflow <LI><a href="#[134]">>></a> __mathlib_dbl_overflow <LI><a href="#[130]">>></a> __mathlib_dbl_infnan <LI><a href="#[13f]">>></a> atan </UL> <P><STRONG><a name="[1ed]"></a>scalbn</STRONG> (Thumb, 0 bytes, Stack size 16 bytes, dscalb.o(.text), UNUSED) <P><STRONG><a name="[85]"></a>_dsqrt</STRONG> (Thumb, 162 bytes, Stack size 32 bytes, dsqrt.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 40<LI>Call Chain = _dsqrt ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[80]">>></a> __aeabi_llsr <LI><a href="#[76]">>></a> _double_round </UL> <BR>[Called By]<UL><LI><a href="#[13e]">>></a> sqrt </UL> <P><STRONG><a name="[86]"></a>__aeabi_d2ulz</STRONG> (Thumb, 48 bytes, Stack size 0 bytes, dfixul.o(.text), UNUSED) <BR><BR>[Calls]<UL><LI><a href="#[80]">>></a> __aeabi_llsr <LI><a href="#[73]">>></a> __aeabi_llsl </UL> <BR>[Called By]<UL><LI><a href="#[136]">>></a> _fp_digits </UL> <P><STRONG><a name="[5f]"></a>__scatterload</STRONG> (Thumb, 28 bytes, Stack size 0 bytes, init.o(.text)) <BR><BR>[Calls]<UL><LI><a href="#[87]">>></a> __main_after_scatterload </UL> <BR>[Called By]<UL><LI><a href="#[5e]">>></a> _main_scatterload </UL> <P><STRONG><a name="[1ee]"></a>__scatterload_rt2</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, init.o(.text), UNUSED) <P><STRONG><a name="[83]"></a>__vfscanf</STRONG> (Thumb, 808 bytes, Stack size 88 bytes, _scanf.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 144<LI>Call Chain = __vfscanf ⇒ _scanf_int </UL> <BR>[Calls]<UL><LI><a href="#[67]">>></a> _scanf_int </UL> <BR>[Called By]<UL><LI><a href="#[66]">>></a> __vfscanf_char </UL> <P><STRONG><a name="[84]"></a>_strtoul</STRONG> (Thumb, 158 bytes, Stack size 40 bytes, _strtoul.o(.text)) <BR><BR>[Stack]<UL><LI>Max Depth = 40<LI>Call Chain = _strtoul </UL> <BR>[Calls]<UL><LI><a href="#[68]">>></a> _chval <LI><a href="#[6a]">>></a> __aeabi_errno_addr </UL> <BR>[Called By]<UL><LI><a href="#[6b]">>></a> strtol </UL> <P><STRONG><a name="[1ef]"></a>__decompress</STRONG> (Thumb, 0 bytes, Stack size unknown bytes, __dczerorl2.o(.text), UNUSED) <P><STRONG><a name="[1f0]"></a>__decompress1</STRONG> (Thumb, 86 bytes, Stack size unknown bytes, __dczerorl2.o(.text), UNUSED) <P><STRONG><a name="[88]"></a>Accept_and_Compare_Str</STRONG> (Thumb, 144 bytes, Stack size 16 bytes, ec800.o(i.Accept_and_Compare_Str)) <BR><BR>[Stack]<UL><LI>Max Depth = 100<LI>Call Chain = Accept_and_Compare_Str ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[8a]">>></a> osDelay <LI><a href="#[89]">>></a> HAL_UART_Receive_DMA <LI><a href="#[8c]">>></a> search_sequence <LI><a href="#[8b]">>></a> strlen </UL> <BR>[Called By]<UL><LI><a href="#[b7]">>></a> EC800_subscribeToTopic <LI><a href="#[a7]">>></a> EC800_publishMessage <LI><a href="#[93]">>></a> EC800M_link <LI><a href="#[9c]">>></a> UpdateFirmware <LI><a href="#[9f]">>></a> EC800_LogIn_FTP <LI><a href="#[9a]">>></a> EC800_FTP_DownloadText </UL> <P><STRONG><a name="[6]"></a>BusFault_Handler</STRONG> (Thumb, 4 bytes, Stack size 0 bytes, stm32f1xx_it.o(i.BusFault_Handler)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[19]"></a>DMA1_Channel3_IRQHandler</STRONG> (Thumb, 10 bytes, Stack size 8 bytes, stm32f1xx_it.o(i.DMA1_Channel3_IRQHandler)) <BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = DMA1_Channel3_IRQHandler ⇒ HAL_DMA_IRQHandler </UL> <BR>[Calls]<UL><LI><a href="#[8d]">>></a> HAL_DMA_IRQHandler </UL> <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[46]"></a>DMA2_Channel3_IRQHandler</STRONG> (Thumb, 10 bytes, Stack size 8 bytes, stm32f1xx_it.o(i.DMA2_Channel3_IRQHandler)) <BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = DMA2_Channel3_IRQHandler ⇒ HAL_DMA_IRQHandler </UL> <BR>[Calls]<UL><LI><a href="#[8d]">>></a> HAL_DMA_IRQHandler </UL> <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[149]"></a>DWT_Delay_us</STRONG> (Thumb, 36 bytes, Stack size 8 bytes, atk_ms6050_iic.o(i.DWT_Delay_us)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = DWT_Delay_us </UL> <BR>[Called By]<UL><LI><a href="#[148]">>></a> atk_ms6050_iic_delay </UL> <P><STRONG><a name="[9]"></a>DebugMon_Handler</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, stm32f1xx_it.o(i.DebugMon_Handler)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[8e]"></a>EC800M_RecRespond</STRONG> (Thumb, 98 bytes, Stack size 16 bytes, ec800.o(i.EC800M_RecRespond)) <BR><BR>[Stack]<UL><LI>Max Depth = 100<LI>Call Chain = EC800M_RecRespond ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[8a]">>></a> osDelay <LI><a href="#[89]">>></a> HAL_UART_Receive_DMA <LI><a href="#[8f]">>></a> strstr <LI><a href="#[62]">>></a> __aeabi_memclr </UL> <BR>[Called By]<UL><LI><a href="#[a7]">>></a> EC800_publishMessage <LI><a href="#[a3]">>></a> EC800_gnss_init <LI><a href="#[93]">>></a> EC800M_link <LI><a href="#[9f]">>></a> EC800_LogIn_FTP </UL> <P><STRONG><a name="[90]"></a>EC800M_SendCommand</STRONG> (Thumb, 30 bytes, Stack size 16 bytes, ec800.o(i.EC800M_SendCommand)) <BR><BR>[Stack]<UL><LI>Max Depth = 80<LI>Call Chain = EC800M_SendCommand ⇒ HAL_UART_Transmit ⇒ UART_WaitOnFlagUntilTimeout </UL> <BR>[Calls]<UL><LI><a href="#[92]">>></a> HAL_UART_Transmit <LI><a href="#[91]">>></a> EC800_calculateStringLength </UL> <BR>[Called By]<UL><LI><a href="#[b7]">>></a> EC800_subscribeToTopic <LI><a href="#[a8]">>></a> EC800_readGnssDate <LI><a href="#[a7]">>></a> EC800_publishMessage <LI><a href="#[a3]">>></a> EC800_gnss_init <LI><a href="#[96]">>></a> EC800_getIMSI <LI><a href="#[93]">>></a> EC800M_link <LI><a href="#[9c]">>></a> UpdateFirmware <LI><a href="#[9f]">>></a> EC800_LogIn_FTP <LI><a href="#[9a]">>></a> EC800_FTP_DownloadText </UL> <P><STRONG><a name="[93]"></a>EC800M_link</STRONG> (Thumb, 1712 bytes, Stack size 120 bytes, ec800.o(i.EC800M_link)) <BR><BR>[Stack]<UL><LI>Max Depth = 252<LI>Call Chain = EC800M_link ⇒ EC800_getIMSI ⇒ EC800_recEnable ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[98]">>></a> EC800_extractSignal <LI><a href="#[97]">>></a> EC800_recEnable <LI><a href="#[96]">>></a> EC800_getIMSI <LI><a href="#[90]">>></a> EC800M_SendCommand <LI><a href="#[8e]">>></a> EC800M_RecRespond <LI><a href="#[88]">>></a> Accept_and_Compare_Str <LI><a href="#[99]">>></a> __2sprintf <LI><a href="#[95]">>></a> __2printf <LI><a href="#[8f]">>></a> strstr <LI><a href="#[94]">>></a> __aeabi_memclr4 <LI><a href="#[62]">>></a> __aeabi_memclr </UL> <BR>[Called By]<UL><LI><a href="#[b6]">>></a> EC800_stateTransition_use </UL> <P><STRONG><a name="[9a]"></a>EC800_FTP_DownloadText</STRONG> (Thumb, 246 bytes, Stack size 120 bytes, ec800_ftp_ota.o(i.EC800_FTP_DownloadText)) <BR><BR>[Stack]<UL><LI>Max Depth = 856<LI>Call Chain = EC800_FTP_DownloadText ⇒ UpdateFirmware ⇒ writeFlashPage ⇒ FLASH_Write ⇒ HAL_FLASH_Program ⇒ FLASH_WaitForLastOperation </UL> <BR>[Calls]<UL><LI><a href="#[90]">>></a> EC800M_SendCommand <LI><a href="#[88]">>></a> Accept_and_Compare_Str <LI><a href="#[9d]">>></a> Write_paramArea <LI><a href="#[9b]">>></a> __2snprintf <LI><a href="#[95]">>></a> __2printf <LI><a href="#[94]">>></a> __aeabi_memclr4 <LI><a href="#[9c]">>></a> UpdateFirmware <LI><a href="#[65]">>></a> __0sscanf </UL> <BR>[Called By]<UL><LI><a href="#[9e]">>></a> EC800_FTP_OTA_Upgrade </UL> <P><STRONG><a name="[9e]"></a>EC800_FTP_OTA_Upgrade</STRONG> (Thumb, 96 bytes, Stack size 8 bytes, ec800_ftp_ota.o(i.EC800_FTP_OTA_Upgrade)) <BR><BR>[Stack]<UL><LI>Max Depth = 864<LI>Call Chain = EC800_FTP_OTA_Upgrade ⇒ EC800_FTP_DownloadText ⇒ UpdateFirmware ⇒ writeFlashPage ⇒ FLASH_Write ⇒ HAL_FLASH_Program ⇒ FLASH_WaitForLastOperation </UL> <BR>[Calls]<UL><LI><a href="#[8a]">>></a> osDelay <LI><a href="#[a0]">>></a> HAL_NVIC_SystemReset <LI><a href="#[9f]">>></a> EC800_LogIn_FTP <LI><a href="#[9a]">>></a> EC800_FTP_DownloadText </UL> <BR>[Called By]<UL><LI><a href="#[121]">>></a> task_communication_content </UL> <P><STRONG><a name="[9f]"></a>EC800_LogIn_FTP</STRONG> (Thumb, 412 bytes, Stack size 120 bytes, ec800_ftp_ota.o(i.EC800_LogIn_FTP)) <BR><BR>[Stack]<UL><LI>Max Depth = 220<LI>Call Chain = EC800_LogIn_FTP ⇒ EC800M_RecRespond ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[90]">>></a> EC800M_SendCommand <LI><a href="#[8e]">>></a> EC800M_RecRespond <LI><a href="#[88]">>></a> Accept_and_Compare_Str <LI><a href="#[9b]">>></a> __2snprintf <LI><a href="#[95]">>></a> __2printf <LI><a href="#[94]">>></a> __aeabi_memclr4 </UL> <BR>[Called By]<UL><LI><a href="#[9e]">>></a> EC800_FTP_OTA_Upgrade </UL> <P><STRONG><a name="[91]"></a>EC800_calculateStringLength</STRONG> (Thumb, 16 bytes, Stack size 0 bytes, ec800.o(i.EC800_calculateStringLength)) <BR><BR>[Called By]<UL><LI><a href="#[90]">>></a> EC800M_SendCommand </UL> <P><STRONG><a name="[96]"></a>EC800_getIMSI</STRONG> (Thumb, 152 bytes, Stack size 40 bytes, ec800.o(i.EC800_getIMSI)) <BR><BR>[Stack]<UL><LI>Max Depth = 132<LI>Call Chain = EC800_getIMSI ⇒ EC800_recEnable ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[97]">>></a> EC800_recEnable <LI><a href="#[90]">>></a> EC800M_SendCommand <LI><a href="#[95]">>></a> __2printf <LI><a href="#[8b]">>></a> strlen <LI><a href="#[8f]">>></a> strstr <LI><a href="#[a2]">>></a> __aeabi_memcpy4 <LI><a href="#[61]">>></a> __rt_ctype_table </UL> <BR>[Called By]<UL><LI><a href="#[93]">>></a> EC800M_link </UL> <P><STRONG><a name="[a3]"></a>EC800_gnss_init</STRONG> (Thumb, 438 bytes, Stack size 16 bytes, ec800.o(i.EC800_gnss_init)) <BR><BR>[Stack]<UL><LI>Max Depth = 116<LI>Call Chain = EC800_gnss_init ⇒ EC800M_RecRespond ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[90]">>></a> EC800M_SendCommand <LI><a href="#[8e]">>></a> EC800M_RecRespond <LI><a href="#[95]">>></a> __2printf </UL> <BR>[Called By]<UL><LI><a href="#[b6]">>></a> EC800_stateTransition_use </UL> <P><STRONG><a name="[ab]"></a>EC800_mktime</STRONG> (Thumb, 94 bytes, Stack size 20 bytes, ec800.o(i.EC800_mktime)) <BR><BR>[Stack]<UL><LI>Max Depth = 20<LI>Call Chain = EC800_mktime </UL> <BR>[Called By]<UL><LI><a href="#[a6]">>></a> parseServerTime <LI><a href="#[a8]">>></a> EC800_readGnssDate </UL> <P><STRONG><a name="[a4]"></a>EC800_parseRespondTime</STRONG> (Thumb, 98 bytes, Stack size 16 bytes, ec800.o(i.EC800_parseRespondTime)) <BR><BR>[Stack]<UL><LI>Max Depth = 152<LI>Call Chain = EC800_parseRespondTime ⇒ parseServerTime ⇒ atoi ⇒ strtol ⇒ _strtoul </UL> <BR>[Calls]<UL><LI><a href="#[a5]">>></a> cJSON_GetObjectItem <LI><a href="#[a6]">>></a> parseServerTime <LI><a href="#[95]">>></a> __2printf </UL> <BR>[Called By]<UL><LI><a href="#[ae]">>></a> EC800_respondParse </UL> <P><STRONG><a name="[a7]"></a>EC800_publishMessage</STRONG> (Thumb, 166 bytes, Stack size 128 bytes, ec800.o(i.EC800_publishMessage)) <BR><BR>[Stack]<UL><LI>Max Depth = 228<LI>Call Chain = EC800_publishMessage ⇒ EC800M_RecRespond ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[90]">>></a> EC800M_SendCommand <LI><a href="#[8e]">>></a> EC800M_RecRespond <LI><a href="#[88]">>></a> Accept_and_Compare_Str <LI><a href="#[99]">>></a> __2sprintf <LI><a href="#[95]">>></a> __2printf <LI><a href="#[94]">>></a> __aeabi_memclr4 </UL> <BR>[Called By]<UL><LI><a href="#[b9]">>></a> requesting_Fence_Data <LI><a href="#[b8]">>></a> Login_Topic <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[ba]">>></a> EC800_time_calibration </UL> <P><STRONG><a name="[a8]"></a>EC800_readGnssDate</STRONG> (Thumb, 236 bytes, Stack size 24 bytes, ec800.o(i.EC800_readGnssDate)) <BR><BR>[Stack]<UL><LI>Max Depth = 168<LI>Call Chain = EC800_readGnssDate ⇒ osMutexRelease ⇒ xQueueGiveMutexRecursive ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[ad]">>></a> osMutexRelease <LI><a href="#[ac]">>></a> osMutexAcquire <LI><a href="#[a9]">>></a> NMEA_GNRMC_Analysis <LI><a href="#[aa]">>></a> utc_to_local_time <LI><a href="#[97]">>></a> EC800_recEnable <LI><a href="#[ab]">>></a> EC800_mktime <LI><a href="#[90]">>></a> EC800M_SendCommand <LI><a href="#[95]">>></a> __2printf <LI><a href="#[8f]">>></a> strstr <LI><a href="#[62]">>></a> __aeabi_memclr </UL> <BR>[Called By]<UL><LI><a href="#[b6]">>></a> EC800_stateTransition_use </UL> <P><STRONG><a name="[97]"></a>EC800_recEnable</STRONG> (Thumb, 48 bytes, Stack size 8 bytes, ec800.o(i.EC800_recEnable)) <BR><BR>[Stack]<UL><LI>Max Depth = 92<LI>Call Chain = EC800_recEnable ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[8a]">>></a> osDelay <LI><a href="#[89]">>></a> HAL_UART_Receive_DMA </UL> <BR>[Called By]<UL><LI><a href="#[a8]">>></a> EC800_readGnssDate <LI><a href="#[96]">>></a> EC800_getIMSI <LI><a href="#[93]">>></a> EC800M_link </UL> <P><STRONG><a name="[ae]"></a>EC800_respondParse</STRONG> (Thumb, 188 bytes, Stack size 24 bytes, ec800.o(i.EC800_respondParse)) <BR><BR>[Stack]<UL><LI>Max Depth = 400<LI>Call Chain = EC800_respondParse ⇒ cJSON_Parse ⇒ cJSON_ParseWithOpts ⇒ parse_value ⇒ parse_number ⇒ pow ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[b0]">>></a> cJSON_Parse <LI><a href="#[a5]">>></a> cJSON_GetObjectItem <LI><a href="#[b1]">>></a> cJSON_Delete <LI><a href="#[b2]">>></a> parse_Login_Response <LI><a href="#[b5]">>></a> parse_Latitude_Longitude_Data <LI><a href="#[b4]">>></a> EC800_respondUpdateDate <LI><a href="#[b3]">>></a> EC800_respondRealDate <LI><a href="#[a4]">>></a> EC800_parseRespondTime <LI><a href="#[95]">>></a> __2printf <LI><a href="#[af]">>></a> strchr </UL> <BR>[Called By]<UL><LI><a href="#[b6]">>></a> EC800_stateTransition_use </UL> <P><STRONG><a name="[b3]"></a>EC800_respondRealDate</STRONG> (Thumb, 56 bytes, Stack size 16 bytes, ec800.o(i.EC800_respondRealDate)) <BR><BR>[Stack]<UL><LI>Max Depth = 48<LI>Call Chain = EC800_respondRealDate ⇒ cJSON_GetObjectItem ⇒ cJSON_strcasecmp </UL> <BR>[Calls]<UL><LI><a href="#[a5]">>></a> cJSON_GetObjectItem <LI><a href="#[95]">>></a> __2printf </UL> <BR>[Called By]<UL><LI><a href="#[ae]">>></a> EC800_respondParse </UL> <P><STRONG><a name="[b4]"></a>EC800_respondUpdateDate</STRONG> (Thumb, 90 bytes, Stack size 24 bytes, ec800.o(i.EC800_respondUpdateDate)) <BR><BR>[Stack]<UL><LI>Max Depth = 56<LI>Call Chain = EC800_respondUpdateDate ⇒ cJSON_GetObjectItem ⇒ cJSON_strcasecmp </UL> <BR>[Calls]<UL><LI><a href="#[a5]">>></a> cJSON_GetObjectItem <LI><a href="#[95]">>></a> __2printf </UL> <BR>[Called By]<UL><LI><a href="#[ae]">>></a> EC800_respondParse </UL> <P><STRONG><a name="[b6]"></a>EC800_stateTransition_use</STRONG> (Thumb, 590 bytes, Stack size 128 bytes, ec800.o(i.EC800_stateTransition_use)) <BR><BR>[Stack]<UL><LI>Max Depth = 528<LI>Call Chain = EC800_stateTransition_use ⇒ EC800_respondParse ⇒ cJSON_Parse ⇒ cJSON_ParseWithOpts ⇒ parse_value ⇒ parse_number ⇒ pow ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[92]">>></a> HAL_UART_Transmit <LI><a href="#[89]">>></a> HAL_UART_Receive_DMA <LI><a href="#[bc]">>></a> HAL_UART_DMAStop <LI><a href="#[b9]">>></a> requesting_Fence_Data <LI><a href="#[b8]">>></a> Login_Topic <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[ba]">>></a> EC800_time_calibration <LI><a href="#[b7]">>></a> EC800_subscribeToTopic <LI><a href="#[ae]">>></a> EC800_respondParse <LI><a href="#[a8]">>></a> EC800_readGnssDate <LI><a href="#[a3]">>></a> EC800_gnss_init <LI><a href="#[93]">>></a> EC800M_link <LI><a href="#[99]">>></a> __2sprintf <LI><a href="#[8b]">>></a> strlen <LI><a href="#[94]">>></a> __aeabi_memclr4 <LI><a href="#[62]">>></a> __aeabi_memclr </UL> <BR>[Called By]<UL><LI><a href="#[122]">>></a> task_ec800_content </UL> <P><STRONG><a name="[b7]"></a>EC800_subscribeToTopic</STRONG> (Thumb, 74 bytes, Stack size 112 bytes, ec800.o(i.EC800_subscribeToTopic)) <BR><BR>[Stack]<UL><LI>Max Depth = 212<LI>Call Chain = EC800_subscribeToTopic ⇒ Accept_and_Compare_Str ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[90]">>></a> EC800M_SendCommand <LI><a href="#[88]">>></a> Accept_and_Compare_Str <LI><a href="#[99]">>></a> __2sprintf <LI><a href="#[95]">>></a> __2printf <LI><a href="#[94]">>></a> __aeabi_memclr4 </UL> <BR>[Called By]<UL><LI><a href="#[b6]">>></a> EC800_stateTransition_use </UL> <P><STRONG><a name="[ba]"></a>EC800_time_calibration</STRONG> (Thumb, 260 bytes, Stack size 88 bytes, ec800.o(i.EC800_time_calibration)) <BR><BR>[Stack]<UL><LI>Max Depth = 316<LI>Call Chain = EC800_time_calibration ⇒ EC800_publishMessage ⇒ EC800M_RecRespond ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[c1]">>></a> cJSON_Print <LI><a href="#[b1]">>></a> cJSON_Delete <LI><a href="#[be]">>></a> cJSON_CreateString <LI><a href="#[bd]">>></a> cJSON_CreateObject <LI><a href="#[c0]">>></a> cJSON_CreateNumber <LI><a href="#[bf]">>></a> cJSON_AddItemToObject <LI><a href="#[7e]">>></a> __aeabi_ui2d <LI><a href="#[a7]">>></a> EC800_publishMessage <LI><a href="#[99]">>></a> __2sprintf <LI><a href="#[8b]">>></a> strlen <LI><a href="#[94]">>></a> __aeabi_memclr4 <LI><a href="#[1]">>></a> free </UL> <BR>[Called By]<UL><LI><a href="#[b6]">>></a> EC800_stateTransition_use </UL> <P><STRONG><a name="[bb]"></a>EC800_uploadRealDate</STRONG> (Thumb, 644 bytes, Stack size 96 bytes, ec800.o(i.EC800_uploadRealDate)) <BR><BR>[Stack]<UL><LI>Max Depth = 324<LI>Call Chain = EC800_uploadRealDate ⇒ EC800_publishMessage ⇒ EC800M_RecRespond ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[7d]">>></a> __aeabi_i2d <LI><a href="#[c1]">>></a> cJSON_Print <LI><a href="#[b1]">>></a> cJSON_Delete <LI><a href="#[be]">>></a> cJSON_CreateString <LI><a href="#[bd]">>></a> cJSON_CreateObject <LI><a href="#[c0]">>></a> cJSON_CreateNumber <LI><a href="#[c2]">>></a> cJSON_CreateArray <LI><a href="#[bf]">>></a> cJSON_AddItemToObject <LI><a href="#[c3]">>></a> cJSON_AddItemToArray <LI><a href="#[7e]">>></a> __aeabi_ui2d <LI><a href="#[a7]">>></a> EC800_publishMessage <LI><a href="#[99]">>></a> __2sprintf <LI><a href="#[8b]">>></a> strlen <LI><a href="#[94]">>></a> __aeabi_memclr4 <LI><a href="#[1]">>></a> free </UL> <BR>[Called By]<UL><LI><a href="#[b6]">>></a> EC800_stateTransition_use </UL> <P><STRONG><a name="[107]"></a>Error_Handler</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, main.o(i.Error_Handler)) <BR><BR>[Called By]<UL><LI><a href="#[103]">>></a> HAL_UART_MspInit <LI><a href="#[119]">>></a> MX_USART3_UART_Init <LI><a href="#[118]">>></a> MX_USART1_UART_Init <LI><a href="#[117]">>></a> MX_UART4_Init <LI><a href="#[116]">>></a> MX_TIM4_Init <LI><a href="#[114]">>></a> MX_TIM2_Init <LI><a href="#[120]">>></a> SystemClock_Config </UL> <P><STRONG><a name="[c4]"></a>FLASH_Erase</STRONG> (Thumb, 46 bytes, Stack size 40 bytes, flash.o(i.FLASH_Erase)) <BR><BR>[Stack]<UL><LI>Max Depth = 80<LI>Call Chain = FLASH_Erase ⇒ HAL_FLASHEx_Erase ⇒ FLASH_WaitForLastOperation </UL> <BR>[Calls]<UL><LI><a href="#[c6]">>></a> HAL_FLASHEx_Erase <LI><a href="#[c5]">>></a> HAL_FLASH_Unlock <LI><a href="#[c7]">>></a> HAL_FLASH_Lock </UL> <BR>[Called By]<UL><LI><a href="#[9d]">>></a> Write_paramArea <LI><a href="#[129]">>></a> writeFlashPage </UL> <P><STRONG><a name="[d3]"></a>FLASH_PageErase</STRONG> (Thumb, 32 bytes, Stack size 0 bytes, stm32f1xx_hal_flash_ex.o(i.FLASH_PageErase)) <BR><BR>[Called By]<UL><LI><a href="#[c6]">>></a> HAL_FLASHEx_Erase </UL> <P><STRONG><a name="[c8]"></a>FLASH_WaitForLastOperation</STRONG> (Thumb, 106 bytes, Stack size 16 bytes, stm32f1xx_hal_flash.o(i.FLASH_WaitForLastOperation)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = FLASH_WaitForLastOperation </UL> <BR>[Calls]<UL><LI><a href="#[ca]">>></a> FLASH_SetErrorCode <LI><a href="#[c9]">>></a> HAL_GetTick </UL> <BR>[Called By]<UL><LI><a href="#[c6]">>></a> HAL_FLASHEx_Erase <LI><a href="#[cd]">>></a> HAL_FLASH_Program </UL> <P><STRONG><a name="[cb]"></a>FLASH_Write</STRONG> (Thumb, 92 bytes, Stack size 24 bytes, flash.o(i.FLASH_Write)) <BR><BR>[Stack]<UL><LI>Max Depth = 88<LI>Call Chain = FLASH_Write ⇒ HAL_FLASH_Program ⇒ FLASH_WaitForLastOperation </UL> <BR>[Calls]<UL><LI><a href="#[c5]">>></a> HAL_FLASH_Unlock <LI><a href="#[cd]">>></a> HAL_FLASH_Program <LI><a href="#[c7]">>></a> HAL_FLASH_Lock <LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[cc]">>></a> vTaskSuspendAll </UL> <BR>[Called By]<UL><LI><a href="#[9d]">>></a> Write_paramArea <LI><a href="#[129]">>></a> writeFlashPage </UL> <P><STRONG><a name="[16a]"></a>GetUniqueID</STRONG> (Thumb, 26 bytes, Stack size 0 bytes, flash.o(i.GetUniqueID)) <BR><BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[f8]"></a>HAL_DMA_Abort</STRONG> (Thumb, 86 bytes, Stack size 0 bytes, stm32f1xx_hal_dma.o(i.HAL_DMA_Abort)) <BR><BR>[Called By]<UL><LI><a href="#[fb]">>></a> HAL_UART_IRQHandler <LI><a href="#[bc]">>></a> HAL_UART_DMAStop </UL> <P><STRONG><a name="[fd]"></a>HAL_DMA_Abort_IT</STRONG> (Thumb, 414 bytes, Stack size 16 bytes, stm32f1xx_hal_dma.o(i.HAL_DMA_Abort_IT)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = HAL_DMA_Abort_IT </UL> <BR>[Called By]<UL><LI><a href="#[fb]">>></a> HAL_UART_IRQHandler </UL> <P><STRONG><a name="[8d]"></a>HAL_DMA_IRQHandler</STRONG> (Thumb, 910 bytes, Stack size 16 bytes, stm32f1xx_hal_dma.o(i.HAL_DMA_IRQHandler)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = HAL_DMA_IRQHandler </UL> <BR>[Called By]<UL><LI><a href="#[46]">>></a> DMA2_Channel3_IRQHandler <LI><a href="#[19]">>></a> DMA1_Channel3_IRQHandler </UL> <P><STRONG><a name="[106]"></a>HAL_DMA_Init</STRONG> (Thumb, 132 bytes, Stack size 0 bytes, stm32f1xx_hal_dma.o(i.HAL_DMA_Init)) <BR><BR>[Called By]<UL><LI><a href="#[103]">>></a> HAL_UART_MspInit </UL> <P><STRONG><a name="[cf]"></a>HAL_DMA_Start_IT</STRONG> (Thumb, 156 bytes, Stack size 24 bytes, stm32f1xx_hal_dma.o(i.HAL_DMA_Start_IT)) <BR><BR>[Stack]<UL><LI>Max Depth = 36<LI>Call Chain = HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[d0]">>></a> DMA_SetConfig </UL> <BR>[Called By]<UL><LI><a href="#[108]">>></a> UART_Start_Receive_DMA </UL> <P><STRONG><a name="[d1]"></a>HAL_Delay</STRONG> (Thumb, 36 bytes, Stack size 16 bytes, stm32f1xx_hal.o(i.HAL_Delay)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = HAL_Delay </UL> <BR>[Calls]<UL><LI><a href="#[c9]">>></a> HAL_GetTick </UL> <BR>[Called By]<UL><LI><a href="#[160]">>></a> mpu_reset_fifo </UL> <P><STRONG><a name="[c6]"></a>HAL_FLASHEx_Erase</STRONG> (Thumb, 168 bytes, Stack size 24 bytes, stm32f1xx_hal_flash_ex.o(i.HAL_FLASHEx_Erase)) <BR><BR>[Stack]<UL><LI>Max Depth = 40<LI>Call Chain = HAL_FLASHEx_Erase ⇒ FLASH_WaitForLastOperation </UL> <BR>[Calls]<UL><LI><a href="#[d2]">>></a> FLASH_MassErase <LI><a href="#[d3]">>></a> FLASH_PageErase <LI><a href="#[c8]">>></a> FLASH_WaitForLastOperation </UL> <BR>[Called By]<UL><LI><a href="#[c4]">>></a> FLASH_Erase </UL> <P><STRONG><a name="[c7]"></a>HAL_FLASH_Lock</STRONG> (Thumb, 16 bytes, Stack size 0 bytes, stm32f1xx_hal_flash.o(i.HAL_FLASH_Lock)) <BR><BR>[Called By]<UL><LI><a href="#[cb]">>></a> FLASH_Write <LI><a href="#[c4]">>></a> FLASH_Erase </UL> <P><STRONG><a name="[cd]"></a>HAL_FLASH_Program</STRONG> (Thumb, 168 bytes, Stack size 48 bytes, stm32f1xx_hal_flash.o(i.HAL_FLASH_Program)) <BR><BR>[Stack]<UL><LI>Max Depth = 64<LI>Call Chain = HAL_FLASH_Program ⇒ FLASH_WaitForLastOperation </UL> <BR>[Calls]<UL><LI><a href="#[d4]">>></a> FLASH_Program_HalfWord <LI><a href="#[c8]">>></a> FLASH_WaitForLastOperation <LI><a href="#[80]">>></a> __aeabi_llsr </UL> <BR>[Called By]<UL><LI><a href="#[cb]">>></a> FLASH_Write </UL> <P><STRONG><a name="[c5]"></a>HAL_FLASH_Unlock</STRONG> (Thumb, 36 bytes, Stack size 0 bytes, stm32f1xx_hal_flash.o(i.HAL_FLASH_Unlock)) <BR><BR>[Called By]<UL><LI><a href="#[cb]">>></a> FLASH_Write <LI><a href="#[c4]">>></a> FLASH_Erase </UL> <P><STRONG><a name="[105]"></a>HAL_GPIO_Init</STRONG> (Thumb, 792 bytes, Stack size 36 bytes, stm32f1xx_hal_gpio.o(i.HAL_GPIO_Init)) <BR><BR>[Stack]<UL><LI>Max Depth = 36<LI>Call Chain = HAL_GPIO_Init </UL> <BR>[Called By]<UL><LI><a href="#[103]">>></a> HAL_UART_MspInit <LI><a href="#[112]">>></a> MX_GPIO_Init </UL> <P><STRONG><a name="[14c]"></a>HAL_GPIO_ReadPin</STRONG> (Thumb, 16 bytes, Stack size 0 bytes, stm32f1xx_hal_gpio.o(i.HAL_GPIO_ReadPin)) <BR><BR>[Called By]<UL><LI><a href="#[150]">>></a> atk_ms6050_iic_wait_ack <LI><a href="#[14b]">>></a> atk_ms6050_iic_read_byte </UL> <P><STRONG><a name="[10b]"></a>HAL_GPIO_TogglePin</STRONG> (Thumb, 20 bytes, Stack size 8 bytes, stm32f1xx_hal_gpio.o(i.HAL_GPIO_TogglePin)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = HAL_GPIO_TogglePin </UL> <BR>[Called By]<UL><LI><a href="#[10a]">>></a> LED0_TOGGLE </UL> <P><STRONG><a name="[113]"></a>HAL_GPIO_WritePin</STRONG> (Thumb, 12 bytes, Stack size 0 bytes, stm32f1xx_hal_gpio.o(i.HAL_GPIO_WritePin)) <BR><BR>[Called By]<UL><LI><a href="#[112]">>></a> MX_GPIO_Init <LI><a href="#[14a]">>></a> atk_ms6050_iic_nack <LI><a href="#[147]">>></a> atk_ms6050_iic_ack <LI><a href="#[150]">>></a> atk_ms6050_iic_wait_ack <LI><a href="#[14f]">>></a> atk_ms6050_iic_stop <LI><a href="#[14e]">>></a> atk_ms6050_iic_start <LI><a href="#[14d]">>></a> atk_ms6050_iic_send_byte <LI><a href="#[14b]">>></a> atk_ms6050_iic_read_byte </UL> <P><STRONG><a name="[c9]"></a>HAL_GetTick</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, stm32f1xx_hal.o(i.HAL_GetTick)) <BR><BR>[Called By]<UL><LI><a href="#[e5]">>></a> HAL_RCC_OscConfig <LI><a href="#[e1]">>></a> HAL_RCC_ClockConfig <LI><a href="#[92]">>></a> HAL_UART_Transmit <LI><a href="#[d1]">>></a> HAL_Delay <LI><a href="#[c8]">>></a> FLASH_WaitForLastOperation <LI><a href="#[109]">>></a> UART_WaitOnFlagUntilTimeout <LI><a href="#[144]">>></a> atk_ms6050_get_clock_ms </UL> <P><STRONG><a name="[f6]"></a>HAL_IncTick</STRONG> (Thumb, 16 bytes, Stack size 0 bytes, stm32f1xx_hal.o(i.HAL_IncTick)) <BR><BR>[Called By]<UL><LI><a href="#[f2]">>></a> HAL_TIM_PeriodElapsedCallback </UL> <P><STRONG><a name="[d5]"></a>HAL_Init</STRONG> (Thumb, 34 bytes, Stack size 8 bytes, stm32f1xx_hal.o(i.HAL_Init)) <BR><BR>[Stack]<UL><LI>Max Depth = 128<LI>Call Chain = HAL_Init ⇒ HAL_InitTick ⇒ HAL_TIM_Base_Init ⇒ HAL_TIM_Base_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[d7]">>></a> HAL_InitTick <LI><a href="#[d8]">>></a> HAL_MspInit <LI><a href="#[d6]">>></a> HAL_NVIC_SetPriorityGrouping </UL> <BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[d7]"></a>HAL_InitTick</STRONG> (Thumb, 138 bytes, Stack size 48 bytes, stm32f1xx_hal_timebase_tim.o(i.HAL_InitTick)) <BR><BR>[Stack]<UL><LI>Max Depth = 120<LI>Call Chain = HAL_InitTick ⇒ HAL_TIM_Base_Init ⇒ HAL_TIM_Base_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[db]">>></a> HAL_TIM_Base_Init <LI><a href="#[de]">>></a> HAL_NVIC_SetPriority <LI><a href="#[dd]">>></a> HAL_NVIC_EnableIRQ <LI><a href="#[dc]">>></a> HAL_TIM_Base_Start_IT <LI><a href="#[da]">>></a> HAL_RCC_GetPCLK2Freq <LI><a href="#[d9]">>></a> HAL_RCC_GetClockConfig </UL> <BR>[Called By]<UL><LI><a href="#[e1]">>></a> HAL_RCC_ClockConfig <LI><a href="#[d5]">>></a> HAL_Init </UL> <P><STRONG><a name="[d8]"></a>HAL_MspInit</STRONG> (Thumb, 86 bytes, Stack size 8 bytes, stm32f1xx_hal_msp.o(i.HAL_MspInit)) <BR><BR>[Stack]<UL><LI>Max Depth = 56<LI>Call Chain = HAL_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[de]">>></a> HAL_NVIC_SetPriority </UL> <BR>[Called By]<UL><LI><a href="#[d5]">>></a> HAL_Init </UL> <P><STRONG><a name="[1c2]"></a>HAL_NVIC_DisableIRQ</STRONG> (Thumb, 62 bytes, Stack size 8 bytes, stm32f1xx_hal_cortex.o(i.HAL_NVIC_DisableIRQ)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = HAL_NVIC_DisableIRQ </UL> <BR>[Called By]<UL><LI><a href="#[121]">>></a> task_communication_content </UL> <P><STRONG><a name="[dd]"></a>HAL_NVIC_EnableIRQ</STRONG> (Thumb, 32 bytes, Stack size 0 bytes, stm32f1xx_hal_cortex.o(i.HAL_NVIC_EnableIRQ)) <BR><BR>[Called By]<UL><LI><a href="#[d7]">>></a> HAL_InitTick <LI><a href="#[103]">>></a> HAL_UART_MspInit <LI><a href="#[e7]">>></a> HAL_TIM_Base_MspInit <LI><a href="#[10c]">>></a> MX_DMA_Init </UL> <P><STRONG><a name="[f7]"></a>HAL_NVIC_GetPriority</STRONG> (Thumb, 138 bytes, Stack size 28 bytes, stm32f1xx_hal_cortex.o(i.HAL_NVIC_GetPriority)) <BR><BR>[Stack]<UL><LI>Max Depth = 28<LI>Call Chain = HAL_NVIC_GetPriority </UL> <BR>[Called By]<UL><LI><a href="#[f2]">>></a> HAL_TIM_PeriodElapsedCallback </UL> <P><STRONG><a name="[de]"></a>HAL_NVIC_SetPriority</STRONG> (Thumb, 124 bytes, Stack size 40 bytes, stm32f1xx_hal_cortex.o(i.HAL_NVIC_SetPriority)) <BR><BR>[Stack]<UL><LI>Max Depth = 48<LI>Call Chain = HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[e0]">>></a> __NVIC_SetPriority <LI><a href="#[df]">>></a> __NVIC_GetPriorityGrouping </UL> <BR>[Called By]<UL><LI><a href="#[d7]">>></a> HAL_InitTick <LI><a href="#[d8]">>></a> HAL_MspInit <LI><a href="#[103]">>></a> HAL_UART_MspInit <LI><a href="#[e7]">>></a> HAL_TIM_Base_MspInit <LI><a href="#[10c]">>></a> MX_DMA_Init </UL> <P><STRONG><a name="[d6]"></a>HAL_NVIC_SetPriorityGrouping</STRONG> (Thumb, 32 bytes, Stack size 0 bytes, stm32f1xx_hal_cortex.o(i.HAL_NVIC_SetPriorityGrouping)) <BR><BR>[Called By]<UL><LI><a href="#[d5]">>></a> HAL_Init </UL> <P><STRONG><a name="[a0]"></a>HAL_NVIC_SystemReset</STRONG> (Thumb, 60 bytes, Stack size 0 bytes, stm32f1xx_hal_cortex.o(i.HAL_NVIC_SystemReset)) <BR><BR>[Called By]<UL><LI><a href="#[9e]">>></a> EC800_FTP_OTA_Upgrade </UL> <P><STRONG><a name="[e1]"></a>HAL_RCC_ClockConfig</STRONG> (Thumb, 376 bytes, Stack size 16 bytes, stm32f1xx_hal_rcc.o(i.HAL_RCC_ClockConfig)) <BR><BR>[Stack]<UL><LI>Max Depth = 136<LI>Call Chain = HAL_RCC_ClockConfig ⇒ HAL_InitTick ⇒ HAL_TIM_Base_Init ⇒ HAL_TIM_Base_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[d7]">>></a> HAL_InitTick <LI><a href="#[e2]">>></a> HAL_RCC_GetSysClockFreq <LI><a href="#[c9]">>></a> HAL_GetTick </UL> <BR>[Called By]<UL><LI><a href="#[120]">>></a> SystemClock_Config </UL> <P><STRONG><a name="[d9]"></a>HAL_RCC_GetClockConfig</STRONG> (Thumb, 58 bytes, Stack size 0 bytes, stm32f1xx_hal_rcc.o(i.HAL_RCC_GetClockConfig)) <BR><BR>[Called By]<UL><LI><a href="#[d7]">>></a> HAL_InitTick </UL> <P><STRONG><a name="[e4]"></a>HAL_RCC_GetHCLKFreq</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, stm32f1xx_hal_rcc.o(i.HAL_RCC_GetHCLKFreq)) <BR><BR>[Called By]<UL><LI><a href="#[e3]">>></a> HAL_RCC_GetPCLK1Freq <LI><a href="#[da]">>></a> HAL_RCC_GetPCLK2Freq </UL> <P><STRONG><a name="[e3]"></a>HAL_RCC_GetPCLK1Freq</STRONG> (Thumb, 22 bytes, Stack size 4 bytes, stm32f1xx_hal_rcc.o(i.HAL_RCC_GetPCLK1Freq)) <BR><BR>[Stack]<UL><LI>Max Depth = 4<LI>Call Chain = HAL_RCC_GetPCLK1Freq </UL> <BR>[Calls]<UL><LI><a href="#[e4]">>></a> HAL_RCC_GetHCLKFreq </UL> <BR>[Called By]<UL><LI><a href="#[104]">>></a> UART_SetConfig </UL> <P><STRONG><a name="[da]"></a>HAL_RCC_GetPCLK2Freq</STRONG> (Thumb, 22 bytes, Stack size 4 bytes, stm32f1xx_hal_rcc.o(i.HAL_RCC_GetPCLK2Freq)) <BR><BR>[Stack]<UL><LI>Max Depth = 4<LI>Call Chain = HAL_RCC_GetPCLK2Freq </UL> <BR>[Calls]<UL><LI><a href="#[e4]">>></a> HAL_RCC_GetHCLKFreq </UL> <BR>[Called By]<UL><LI><a href="#[d7]">>></a> HAL_InitTick <LI><a href="#[104]">>></a> UART_SetConfig </UL> <P><STRONG><a name="[e2]"></a>HAL_RCC_GetSysClockFreq</STRONG> (Thumb, 92 bytes, Stack size 16 bytes, stm32f1xx_hal_rcc.o(i.HAL_RCC_GetSysClockFreq)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = HAL_RCC_GetSysClockFreq </UL> <BR>[Called By]<UL><LI><a href="#[e1]">>></a> HAL_RCC_ClockConfig </UL> <P><STRONG><a name="[e5]"></a>HAL_RCC_OscConfig</STRONG> (Thumb, 1114 bytes, Stack size 24 bytes, stm32f1xx_hal_rcc.o(i.HAL_RCC_OscConfig)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = HAL_RCC_OscConfig ⇒ RCC_Delay </UL> <BR>[Calls]<UL><LI><a href="#[e6]">>></a> RCC_Delay <LI><a href="#[c9]">>></a> HAL_GetTick </UL> <BR>[Called By]<UL><LI><a href="#[120]">>></a> SystemClock_Config </UL> <P><STRONG><a name="[f3]"></a>HAL_TIMEx_BreakCallback</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, stm32f1xx_hal_tim_ex.o(i.HAL_TIMEx_BreakCallback)) <BR><BR>[Called By]<UL><LI><a href="#[ee]">>></a> HAL_TIM_IRQHandler </UL> <P><STRONG><a name="[f5]"></a>HAL_TIMEx_CommutCallback</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, stm32f1xx_hal_tim_ex.o(i.HAL_TIMEx_CommutCallback)) <BR><BR>[Called By]<UL><LI><a href="#[ee]">>></a> HAL_TIM_IRQHandler </UL> <P><STRONG><a name="[115]"></a>HAL_TIMEx_MasterConfigSynchronization</STRONG> (Thumb, 134 bytes, Stack size 12 bytes, stm32f1xx_hal_tim_ex.o(i.HAL_TIMEx_MasterConfigSynchronization)) <BR><BR>[Stack]<UL><LI>Max Depth = 12<LI>Call Chain = HAL_TIMEx_MasterConfigSynchronization </UL> <BR>[Called By]<UL><LI><a href="#[116]">>></a> MX_TIM4_Init <LI><a href="#[114]">>></a> MX_TIM2_Init </UL> <P><STRONG><a name="[db]"></a>HAL_TIM_Base_Init</STRONG> (Thumb, 102 bytes, Stack size 8 bytes, stm32f1xx_hal_tim.o(i.HAL_TIM_Base_Init)) <BR><BR>[Stack]<UL><LI>Max Depth = 72<LI>Call Chain = HAL_TIM_Base_Init ⇒ HAL_TIM_Base_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[e7]">>></a> HAL_TIM_Base_MspInit <LI><a href="#[e8]">>></a> TIM_Base_SetConfig </UL> <BR>[Called By]<UL><LI><a href="#[d7]">>></a> HAL_InitTick <LI><a href="#[116]">>></a> MX_TIM4_Init <LI><a href="#[114]">>></a> MX_TIM2_Init </UL> <P><STRONG><a name="[e7]"></a>HAL_TIM_Base_MspInit</STRONG> (Thumb, 112 bytes, Stack size 16 bytes, tim.o(i.HAL_TIM_Base_MspInit)) <BR><BR>[Stack]<UL><LI>Max Depth = 64<LI>Call Chain = HAL_TIM_Base_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[de]">>></a> HAL_NVIC_SetPriority <LI><a href="#[dd]">>></a> HAL_NVIC_EnableIRQ </UL> <BR>[Called By]<UL><LI><a href="#[db]">>></a> HAL_TIM_Base_Init </UL> <P><STRONG><a name="[dc]"></a>HAL_TIM_Base_Start_IT</STRONG> (Thumb, 122 bytes, Stack size 0 bytes, stm32f1xx_hal_tim.o(i.HAL_TIM_Base_Start_IT)) <BR><BR>[Called By]<UL><LI><a href="#[d7]">>></a> HAL_InitTick <LI><a href="#[15e]">>></a> configureTimerForRunTimeStats </UL> <P><STRONG><a name="[e9]"></a>HAL_TIM_ConfigClockSource</STRONG> (Thumb, 268 bytes, Stack size 24 bytes, stm32f1xx_hal_tim.o(i.HAL_TIM_ConfigClockSource)) <BR><BR>[Stack]<UL><LI>Max Depth = 36<LI>Call Chain = HAL_TIM_ConfigClockSource ⇒ TIM_TI2_ConfigInputStage </UL> <BR>[Calls]<UL><LI><a href="#[ed]">>></a> TIM_TI2_ConfigInputStage <LI><a href="#[eb]">>></a> TIM_TI1_ConfigInputStage <LI><a href="#[ec]">>></a> TIM_ITRx_SetConfig <LI><a href="#[ea]">>></a> TIM_ETR_SetConfig </UL> <BR>[Called By]<UL><LI><a href="#[116]">>></a> MX_TIM4_Init <LI><a href="#[114]">>></a> MX_TIM2_Init </UL> <P><STRONG><a name="[ef]"></a>HAL_TIM_IC_CaptureCallback</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, stm32f1xx_hal_tim.o(i.HAL_TIM_IC_CaptureCallback)) <BR><BR>[Called By]<UL><LI><a href="#[ee]">>></a> HAL_TIM_IRQHandler </UL> <P><STRONG><a name="[ee]"></a>HAL_TIM_IRQHandler</STRONG> (Thumb, 406 bytes, Stack size 8 bytes, stm32f1xx_hal_tim.o(i.HAL_TIM_IRQHandler)) <BR><BR>[Stack]<UL><LI>Max Depth = 52<LI>Call Chain = HAL_TIM_IRQHandler ⇒ HAL_TIM_PeriodElapsedCallback ⇒ HAL_NVIC_GetPriority </UL> <BR>[Calls]<UL><LI><a href="#[f2]">>></a> HAL_TIM_PeriodElapsedCallback <LI><a href="#[f4]">>></a> HAL_TIM_TriggerCallback <LI><a href="#[f1]">>></a> HAL_TIM_PWM_PulseFinishedCallback <LI><a href="#[f0]">>></a> HAL_TIM_OC_DelayElapsedCallback <LI><a href="#[ef]">>></a> HAL_TIM_IC_CaptureCallback <LI><a href="#[f5]">>></a> HAL_TIMEx_CommutCallback <LI><a href="#[f3]">>></a> HAL_TIMEx_BreakCallback </UL> <BR>[Called By]<UL><LI><a href="#[2a]">>></a> TIM4_IRQHandler <LI><a href="#[28]">>></a> TIM2_IRQHandler <LI><a href="#[25]">>></a> TIM1_UP_IRQHandler </UL> <P><STRONG><a name="[f0]"></a>HAL_TIM_OC_DelayElapsedCallback</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, stm32f1xx_hal_tim.o(i.HAL_TIM_OC_DelayElapsedCallback)) <BR><BR>[Called By]<UL><LI><a href="#[ee]">>></a> HAL_TIM_IRQHandler </UL> <P><STRONG><a name="[f1]"></a>HAL_TIM_PWM_PulseFinishedCallback</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, stm32f1xx_hal_tim.o(i.HAL_TIM_PWM_PulseFinishedCallback)) <BR><BR>[Called By]<UL><LI><a href="#[ee]">>></a> HAL_TIM_IRQHandler </UL> <P><STRONG><a name="[f2]"></a>HAL_TIM_PeriodElapsedCallback</STRONG> (Thumb, 76 bytes, Stack size 16 bytes, main.o(i.HAL_TIM_PeriodElapsedCallback)) <BR><BR>[Stack]<UL><LI>Max Depth = 44<LI>Call Chain = HAL_TIM_PeriodElapsedCallback ⇒ HAL_NVIC_GetPriority </UL> <BR>[Calls]<UL><LI><a href="#[f7]">>></a> HAL_NVIC_GetPriority <LI><a href="#[f6]">>></a> HAL_IncTick </UL> <BR>[Called By]<UL><LI><a href="#[ee]">>></a> HAL_TIM_IRQHandler </UL> <P><STRONG><a name="[f4]"></a>HAL_TIM_TriggerCallback</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, stm32f1xx_hal_tim.o(i.HAL_TIM_TriggerCallback)) <BR><BR>[Called By]<UL><LI><a href="#[ee]">>></a> HAL_TIM_IRQHandler </UL> <P><STRONG><a name="[ff]"></a>HAL_UARTEx_RxEventCallback</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, stm32f1xx_hal_uart.o(i.HAL_UARTEx_RxEventCallback)) <BR><BR>[Called By]<UL><LI><a href="#[fb]">>></a> HAL_UART_IRQHandler <LI><a href="#[fc]">>></a> UART_Receive_IT <LI><a href="#[55]">>></a> UART_DMARxHalfCplt <LI><a href="#[54]">>></a> UART_DMAReceiveCplt </UL> <P><STRONG><a name="[bc]"></a>HAL_UART_DMAStop</STRONG> (Thumb, 138 bytes, Stack size 16 bytes, stm32f1xx_hal_uart.o(i.HAL_UART_DMAStop)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = HAL_UART_DMAStop </UL> <BR>[Calls]<UL><LI><a href="#[f8]">>></a> HAL_DMA_Abort <LI><a href="#[f9]">>></a> UART_EndTxTransfer <LI><a href="#[fa]">>></a> UART_EndRxTransfer </UL> <BR>[Called By]<UL><LI><a href="#[b6]">>></a> EC800_stateTransition_use <LI><a href="#[33]">>></a> USART3_IRQHandler <LI><a href="#[40]">>></a> UART4_IRQHandler </UL> <P><STRONG><a name="[fe]"></a>HAL_UART_ErrorCallback</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, stm32f1xx_hal_uart.o(i.HAL_UART_ErrorCallback)) <BR><BR>[Called By]<UL><LI><a href="#[fb]">>></a> HAL_UART_IRQHandler <LI><a href="#[56]">>></a> UART_DMAError <LI><a href="#[4f]">>></a> UART_DMAAbortOnError </UL> <P><STRONG><a name="[fb]"></a>HAL_UART_IRQHandler</STRONG> (Thumb, 736 bytes, Stack size 40 bytes, stm32f1xx_hal_uart.o(i.HAL_UART_IRQHandler)) <BR><BR>[Stack]<UL><LI>Max Depth = 64<LI>Call Chain = HAL_UART_IRQHandler ⇒ UART_Receive_IT </UL> <BR>[Calls]<UL><LI><a href="#[fd]">>></a> HAL_DMA_Abort_IT <LI><a href="#[f8]">>></a> HAL_DMA_Abort <LI><a href="#[fe]">>></a> HAL_UART_ErrorCallback <LI><a href="#[ff]">>></a> HAL_UARTEx_RxEventCallback <LI><a href="#[100]">>></a> UART_Transmit_IT <LI><a href="#[fc]">>></a> UART_Receive_IT <LI><a href="#[101]">>></a> UART_EndTransmit_IT <LI><a href="#[fa]">>></a> UART_EndRxTransfer </UL> <BR>[Called By]<UL><LI><a href="#[33]">>></a> USART3_IRQHandler <LI><a href="#[31]">>></a> USART1_IRQHandler <LI><a href="#[40]">>></a> UART4_IRQHandler </UL> <P><STRONG><a name="[102]"></a>HAL_UART_Init</STRONG> (Thumb, 118 bytes, Stack size 8 bytes, stm32f1xx_hal_uart.o(i.HAL_UART_Init)) <BR><BR>[Stack]<UL><LI>Max Depth = 88<LI>Call Chain = HAL_UART_Init ⇒ HAL_UART_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[103]">>></a> HAL_UART_MspInit <LI><a href="#[104]">>></a> UART_SetConfig </UL> <BR>[Called By]<UL><LI><a href="#[119]">>></a> MX_USART3_UART_Init <LI><a href="#[118]">>></a> MX_USART1_UART_Init <LI><a href="#[117]">>></a> MX_UART4_Init </UL> <P><STRONG><a name="[103]"></a>HAL_UART_MspInit</STRONG> (Thumb, 478 bytes, Stack size 32 bytes, usart.o(i.HAL_UART_MspInit)) <BR><BR>[Stack]<UL><LI>Max Depth = 80<LI>Call Chain = HAL_UART_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[106]">>></a> HAL_DMA_Init <LI><a href="#[de]">>></a> HAL_NVIC_SetPriority <LI><a href="#[dd]">>></a> HAL_NVIC_EnableIRQ <LI><a href="#[105]">>></a> HAL_GPIO_Init <LI><a href="#[107]">>></a> Error_Handler </UL> <BR>[Called By]<UL><LI><a href="#[102]">>></a> HAL_UART_Init </UL> <P><STRONG><a name="[89]"></a>HAL_UART_Receive_DMA</STRONG> (Thumb, 44 bytes, Stack size 16 bytes, stm32f1xx_hal_uart.o(i.HAL_UART_Receive_DMA)) <BR><BR>[Stack]<UL><LI>Max Depth = 84<LI>Call Chain = HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[108]">>></a> UART_Start_Receive_DMA </UL> <BR>[Called By]<UL><LI><a href="#[b6]">>></a> EC800_stateTransition_use <LI><a href="#[33]">>></a> USART3_IRQHandler <LI><a href="#[40]">>></a> UART4_IRQHandler <LI><a href="#[97]">>></a> EC800_recEnable <LI><a href="#[8e]">>></a> EC800M_RecRespond <LI><a href="#[88]">>></a> Accept_and_Compare_Str </UL> <P><STRONG><a name="[124]"></a>HAL_UART_RxCpltCallback</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, stm32f1xx_hal_uart.o(i.HAL_UART_RxCpltCallback)) <BR><BR>[Called By]<UL><LI><a href="#[fc]">>></a> UART_Receive_IT <LI><a href="#[54]">>></a> UART_DMAReceiveCplt </UL> <P><STRONG><a name="[125]"></a>HAL_UART_RxHalfCpltCallback</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, stm32f1xx_hal_uart.o(i.HAL_UART_RxHalfCpltCallback)) <BR><BR>[Called By]<UL><LI><a href="#[55]">>></a> UART_DMARxHalfCplt </UL> <P><STRONG><a name="[92]"></a>HAL_UART_Transmit</STRONG> (Thumb, 178 bytes, Stack size 40 bytes, stm32f1xx_hal_uart.o(i.HAL_UART_Transmit)) <BR><BR>[Stack]<UL><LI>Max Depth = 64<LI>Call Chain = HAL_UART_Transmit ⇒ UART_WaitOnFlagUntilTimeout </UL> <BR>[Calls]<UL><LI><a href="#[c9]">>></a> HAL_GetTick <LI><a href="#[109]">>></a> UART_WaitOnFlagUntilTimeout </UL> <BR>[Called By]<UL><LI><a href="#[b6]">>></a> EC800_stateTransition_use <LI><a href="#[57]">>></a> fputc <LI><a href="#[90]">>></a> EC800M_SendCommand </UL> <P><STRONG><a name="[126]"></a>HAL_UART_TxCpltCallback</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, stm32f1xx_hal_uart.o(i.HAL_UART_TxCpltCallback)) <BR><BR>[Called By]<UL><LI><a href="#[101]">>></a> UART_EndTransmit_IT </UL> <P><STRONG><a name="[4]"></a>HardFault_Handler</STRONG> (Thumb, 4 bytes, Stack size 0 bytes, stm32f1xx_it.o(i.HardFault_Handler)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[10a]"></a>LED0_TOGGLE</STRONG> (Thumb, 42 bytes, Stack size 8 bytes, gpio.o(i.LED0_TOGGLE)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = LED0_TOGGLE ⇒ HAL_GPIO_TogglePin </UL> <BR>[Calls]<UL><LI><a href="#[10b]">>></a> HAL_GPIO_TogglePin </UL> <BR>[Called By]<UL><LI><a href="#[121]">>></a> task_communication_content </UL> <P><STRONG><a name="[b8]"></a>Login_Topic</STRONG> (Thumb, 260 bytes, Stack size 88 bytes, ec800.o(i.Login_Topic)) <BR><BR>[Stack]<UL><LI>Max Depth = 316<LI>Call Chain = Login_Topic ⇒ EC800_publishMessage ⇒ EC800M_RecRespond ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[c1]">>></a> cJSON_Print <LI><a href="#[b1]">>></a> cJSON_Delete <LI><a href="#[be]">>></a> cJSON_CreateString <LI><a href="#[bd]">>></a> cJSON_CreateObject <LI><a href="#[c0]">>></a> cJSON_CreateNumber <LI><a href="#[bf]">>></a> cJSON_AddItemToObject <LI><a href="#[7e]">>></a> __aeabi_ui2d <LI><a href="#[a7]">>></a> EC800_publishMessage <LI><a href="#[99]">>></a> __2sprintf <LI><a href="#[8b]">>></a> strlen <LI><a href="#[94]">>></a> __aeabi_memclr4 <LI><a href="#[1]">>></a> free </UL> <BR>[Called By]<UL><LI><a href="#[b6]">>></a> EC800_stateTransition_use </UL> <P><STRONG><a name="[10c]"></a>MX_DMA_Init</STRONG> (Thumb, 90 bytes, Stack size 8 bytes, dma.o(i.MX_DMA_Init)) <BR><BR>[Stack]<UL><LI>Max Depth = 56<LI>Call Chain = MX_DMA_Init ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[de]">>></a> HAL_NVIC_SetPriority <LI><a href="#[dd]">>></a> HAL_NVIC_EnableIRQ </UL> <BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[10d]"></a>MX_FREERTOS_Init</STRONG> (Thumb, 120 bytes, Stack size 8 bytes, freertos.o(i.MX_FREERTOS_Init)) <BR><BR>[Stack]<UL><LI>Max Depth = 224<LI>Call Chain = MX_FREERTOS_Init ⇒ osTimerNew ⇒ xTimerCreateStatic ⇒ prvInitialiseNewTimer ⇒ prvCheckForValidListAndQueue ⇒ xQueueGenericCreateStatic ⇒ prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[110]">>></a> osTimerNew <LI><a href="#[111]">>></a> osThreadNew <LI><a href="#[10f]">>></a> osSemaphoreNew <LI><a href="#[10e]">>></a> osMutexNew </UL> <BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[112]"></a>MX_GPIO_Init</STRONG> (Thumb, 298 bytes, Stack size 24 bytes, gpio.o(i.MX_GPIO_Init)) <BR><BR>[Stack]<UL><LI>Max Depth = 60<LI>Call Chain = MX_GPIO_Init ⇒ HAL_GPIO_Init </UL> <BR>[Calls]<UL><LI><a href="#[113]">>></a> HAL_GPIO_WritePin <LI><a href="#[105]">>></a> HAL_GPIO_Init </UL> <BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[114]"></a>MX_TIM2_Init</STRONG> (Thumb, 104 bytes, Stack size 32 bytes, tim.o(i.MX_TIM2_Init)) <BR><BR>[Stack]<UL><LI>Max Depth = 104<LI>Call Chain = MX_TIM2_Init ⇒ HAL_TIM_Base_Init ⇒ HAL_TIM_Base_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[e9]">>></a> HAL_TIM_ConfigClockSource <LI><a href="#[db]">>></a> HAL_TIM_Base_Init <LI><a href="#[115]">>></a> HAL_TIMEx_MasterConfigSynchronization <LI><a href="#[107]">>></a> Error_Handler </UL> <BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[116]"></a>MX_TIM4_Init</STRONG> (Thumb, 98 bytes, Stack size 32 bytes, tim.o(i.MX_TIM4_Init)) <BR><BR>[Stack]<UL><LI>Max Depth = 104<LI>Call Chain = MX_TIM4_Init ⇒ HAL_TIM_Base_Init ⇒ HAL_TIM_Base_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[e9]">>></a> HAL_TIM_ConfigClockSource <LI><a href="#[db]">>></a> HAL_TIM_Base_Init <LI><a href="#[115]">>></a> HAL_TIMEx_MasterConfigSynchronization <LI><a href="#[107]">>></a> Error_Handler </UL> <BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[117]"></a>MX_UART4_Init</STRONG> (Thumb, 62 bytes, Stack size 8 bytes, usart.o(i.MX_UART4_Init)) <BR><BR>[Stack]<UL><LI>Max Depth = 96<LI>Call Chain = MX_UART4_Init ⇒ HAL_UART_Init ⇒ HAL_UART_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[102]">>></a> HAL_UART_Init <LI><a href="#[107]">>></a> Error_Handler </UL> <BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[118]"></a>MX_USART1_UART_Init</STRONG> (Thumb, 46 bytes, Stack size 8 bytes, usart.o(i.MX_USART1_UART_Init)) <BR><BR>[Stack]<UL><LI>Max Depth = 96<LI>Call Chain = MX_USART1_UART_Init ⇒ HAL_UART_Init ⇒ HAL_UART_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[102]">>></a> HAL_UART_Init <LI><a href="#[107]">>></a> Error_Handler </UL> <BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[119]"></a>MX_USART3_UART_Init</STRONG> (Thumb, 62 bytes, Stack size 8 bytes, usart.o(i.MX_USART3_UART_Init)) <BR><BR>[Stack]<UL><LI>Max Depth = 96<LI>Call Chain = MX_USART3_UART_Init ⇒ HAL_UART_Init ⇒ HAL_UART_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[102]">>></a> HAL_UART_Init <LI><a href="#[107]">>></a> Error_Handler </UL> <BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[5]"></a>MemManage_Handler</STRONG> (Thumb, 4 bytes, Stack size 0 bytes, stm32f1xx_it.o(i.MemManage_Handler)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[11a]"></a>NMEA_Comma_Pos</STRONG> (Thumb, 50 bytes, Stack size 0 bytes, nmea.o(i.NMEA_Comma_Pos)) <BR><BR>[Called By]<UL><LI><a href="#[a9]">>></a> NMEA_GNRMC_Analysis </UL> <P><STRONG><a name="[a9]"></a>NMEA_GNRMC_Analysis</STRONG> (Thumb, 536 bytes, Stack size 56 bytes, nmea.o(i.NMEA_GNRMC_Analysis)) <BR><BR>[Stack]<UL><LI>Max Depth = 112<LI>Call Chain = NMEA_GNRMC_Analysis ⇒ NMEA_Str2num ⇒ NMEA_Pow </UL> <BR>[Calls]<UL><LI><a href="#[7c]">>></a> __aeabi_ui2f <LI><a href="#[11d]">>></a> __aeabi_fmul <LI><a href="#[71]">>></a> __aeabi_fdiv <LI><a href="#[6c]">>></a> __aeabi_fadd <LI><a href="#[11e]">>></a> __aeabi_f2uiz <LI><a href="#[11b]">>></a> NMEA_Str2num <LI><a href="#[11c]">>></a> NMEA_Pow <LI><a href="#[11a]">>></a> NMEA_Comma_Pos <LI><a href="#[8f]">>></a> strstr </UL> <BR>[Called By]<UL><LI><a href="#[a8]">>></a> EC800_readGnssDate </UL> <P><STRONG><a name="[11c]"></a>NMEA_Pow</STRONG> (Thumb, 22 bytes, Stack size 8 bytes, nmea.o(i.NMEA_Pow)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = NMEA_Pow </UL> <BR>[Called By]<UL><LI><a href="#[11b]">>></a> NMEA_Str2num <LI><a href="#[a9]">>></a> NMEA_GNRMC_Analysis </UL> <P><STRONG><a name="[11b]"></a>NMEA_Str2num</STRONG> (Thumb, 234 bytes, Stack size 48 bytes, nmea.o(i.NMEA_Str2num)) <BR><BR>[Stack]<UL><LI>Max Depth = 56<LI>Call Chain = NMEA_Str2num ⇒ NMEA_Pow </UL> <BR>[Calls]<UL><LI><a href="#[11c]">>></a> NMEA_Pow </UL> <BR>[Called By]<UL><LI><a href="#[a9]">>></a> NMEA_GNRMC_Analysis </UL> <P><STRONG><a name="[3]"></a>NMI_Handler</STRONG> (Thumb, 4 bytes, Stack size 0 bytes, stm32f1xx_it.o(i.NMI_Handler)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[1c6]"></a>PostSleepProcessing</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, freertos.o(i.PostSleepProcessing)) <BR><BR>[Called By]<UL><LI><a href="#[1a8]">>></a> vPortSuppressTicksAndSleep </UL> <P><STRONG><a name="[1c5]"></a>PreSleepProcessing</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, freertos.o(i.PreSleepProcessing)) <BR><BR>[Called By]<UL><LI><a href="#[1a8]">>></a> vPortSuppressTicksAndSleep </UL> <P><STRONG><a name="[169]"></a>Remap_Vector_Table</STRONG> (Thumb, 12 bytes, Stack size 0 bytes, flash.o(i.Remap_Vector_Table)) <BR><BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[51]"></a>StartDefaultTask</STRONG> (Thumb, 10 bytes, Stack size 0 bytes, freertos.o(i.StartDefaultTask)) <BR><BR>[Stack]<UL><LI>Max Depth = 72<LI>Call Chain = StartDefaultTask ⇒ osDelay ⇒ vTaskDelay ⇒ xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[8a]">>></a> osDelay </UL> <BR>[Address Reference Count : 1]<UL><LI> freertos.o(i.MX_FREERTOS_Init) </UL> <P><STRONG><a name="[b]"></a>SysTick_Handler</STRONG> (Thumb, 46 bytes, Stack size 8 bytes, port.o(i.SysTick_Handler)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = SysTick_Handler ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[11f]">>></a> xTaskIncrementTick </UL> <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[120]"></a>SystemClock_Config</STRONG> (Thumb, 102 bytes, Stack size 64 bytes, main.o(i.SystemClock_Config)) <BR><BR>[Stack]<UL><LI>Max Depth = 200<LI>Call Chain = SystemClock_Config ⇒ HAL_RCC_ClockConfig ⇒ HAL_InitTick ⇒ HAL_TIM_Base_Init ⇒ HAL_TIM_Base_MspInit ⇒ HAL_NVIC_SetPriority ⇒ __NVIC_SetPriority </UL> <BR>[Calls]<UL><LI><a href="#[e5]">>></a> HAL_RCC_OscConfig <LI><a href="#[e1]">>></a> HAL_RCC_ClockConfig <LI><a href="#[107]">>></a> Error_Handler <LI><a href="#[94]">>></a> __aeabi_memclr4 </UL> <BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[49]"></a>SystemInit</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, system_stm32f1xx.o(i.SystemInit)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(.text) </UL> <P><STRONG><a name="[25]"></a>TIM1_UP_IRQHandler</STRONG> (Thumb, 10 bytes, Stack size 8 bytes, stm32f1xx_it.o(i.TIM1_UP_IRQHandler)) <BR><BR>[Stack]<UL><LI>Max Depth = 60<LI>Call Chain = TIM1_UP_IRQHandler ⇒ HAL_TIM_IRQHandler ⇒ HAL_TIM_PeriodElapsedCallback ⇒ HAL_NVIC_GetPriority </UL> <BR>[Calls]<UL><LI><a href="#[ee]">>></a> HAL_TIM_IRQHandler </UL> <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[28]"></a>TIM2_IRQHandler</STRONG> (Thumb, 10 bytes, Stack size 8 bytes, stm32f1xx_it.o(i.TIM2_IRQHandler)) <BR><BR>[Stack]<UL><LI>Max Depth = 60<LI>Call Chain = TIM2_IRQHandler ⇒ HAL_TIM_IRQHandler ⇒ HAL_TIM_PeriodElapsedCallback ⇒ HAL_NVIC_GetPriority </UL> <BR>[Calls]<UL><LI><a href="#[ee]">>></a> HAL_TIM_IRQHandler </UL> <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[2a]"></a>TIM4_IRQHandler</STRONG> (Thumb, 10 bytes, Stack size 8 bytes, stm32f1xx_it.o(i.TIM4_IRQHandler)) <BR><BR>[Stack]<UL><LI>Max Depth = 60<LI>Call Chain = TIM4_IRQHandler ⇒ HAL_TIM_IRQHandler ⇒ HAL_TIM_PeriodElapsedCallback ⇒ HAL_NVIC_GetPriority </UL> <BR>[Calls]<UL><LI><a href="#[ee]">>></a> HAL_TIM_IRQHandler </UL> <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[e8]"></a>TIM_Base_SetConfig</STRONG> (Thumb, 134 bytes, Stack size 8 bytes, stm32f1xx_hal_tim.o(i.TIM_Base_SetConfig)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = TIM_Base_SetConfig </UL> <BR>[Called By]<UL><LI><a href="#[db]">>></a> HAL_TIM_Base_Init </UL> <P><STRONG><a name="[ea]"></a>TIM_ETR_SetConfig</STRONG> (Thumb, 22 bytes, Stack size 12 bytes, stm32f1xx_hal_tim.o(i.TIM_ETR_SetConfig)) <BR><BR>[Stack]<UL><LI>Max Depth = 12<LI>Call Chain = TIM_ETR_SetConfig </UL> <BR>[Called By]<UL><LI><a href="#[e9]">>></a> HAL_TIM_ConfigClockSource </UL> <P><STRONG><a name="[53]"></a>Task_communication</STRONG> (Thumb, 14 bytes, Stack size 0 bytes, freertos.o(i.Task_communication)) <BR><BR>[Stack]<UL><LI>Max Depth = 872<LI>Call Chain = Task_communication ⇒ task_communication_content ⇒ EC800_FTP_OTA_Upgrade ⇒ EC800_FTP_DownloadText ⇒ UpdateFirmware ⇒ writeFlashPage ⇒ FLASH_Write ⇒ HAL_FLASH_Program ⇒ FLASH_WaitForLastOperation </UL> <BR>[Calls]<UL><LI><a href="#[8a]">>></a> osDelay <LI><a href="#[121]">>></a> task_communication_content </UL> <BR>[Address Reference Count : 1]<UL><LI> freertos.o(i.MX_FREERTOS_Init) </UL> <P><STRONG><a name="[52]"></a>Task_ec800_upload</STRONG> (Thumb, 14 bytes, Stack size 0 bytes, freertos.o(i.Task_ec800_upload)) <BR><BR>[Stack]<UL><LI>Max Depth = 544<LI>Call Chain = Task_ec800_upload ⇒ task_ec800_content ⇒ EC800_stateTransition_use ⇒ EC800_respondParse ⇒ cJSON_Parse ⇒ cJSON_ParseWithOpts ⇒ parse_value ⇒ parse_number ⇒ pow ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[122]">>></a> task_ec800_content <LI><a href="#[8a]">>></a> osDelay </UL> <BR>[Address Reference Count : 1]<UL><LI> freertos.o(i.MX_FREERTOS_Init) </UL> <P><STRONG><a name="[50]"></a>Time2_Callback</STRONG> (Thumb, 2 bytes, Stack size 0 bytes, freertos.o(i.Time2_Callback)) <BR>[Address Reference Count : 1]<UL><LI> freertos.o(i.MX_FREERTOS_Init) </UL> <P><STRONG><a name="[40]"></a>UART4_IRQHandler</STRONG> (Thumb, 76 bytes, Stack size 8 bytes, stm32f1xx_it.o(i.UART4_IRQHandler)) <BR><BR>[Stack]<UL><LI>Max Depth = 92<LI>Call Chain = UART4_IRQHandler ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[fb]">>></a> HAL_UART_IRQHandler <LI><a href="#[89]">>></a> HAL_UART_Receive_DMA <LI><a href="#[bc]">>></a> HAL_UART_DMAStop </UL> <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[108]"></a>UART_Start_Receive_DMA</STRONG> (Thumb, 186 bytes, Stack size 32 bytes, stm32f1xx_hal_uart.o(i.UART_Start_Receive_DMA)) <BR><BR>[Stack]<UL><LI>Max Depth = 68<LI>Call Chain = UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[cf]">>></a> HAL_DMA_Start_IT </UL> <BR>[Called By]<UL><LI><a href="#[89]">>></a> HAL_UART_Receive_DMA </UL> <P><STRONG><a name="[31]"></a>USART1_IRQHandler</STRONG> (Thumb, 10 bytes, Stack size 8 bytes, stm32f1xx_it.o(i.USART1_IRQHandler)) <BR><BR>[Stack]<UL><LI>Max Depth = 72<LI>Call Chain = USART1_IRQHandler ⇒ HAL_UART_IRQHandler ⇒ UART_Receive_IT </UL> <BR>[Calls]<UL><LI><a href="#[fb]">>></a> HAL_UART_IRQHandler </UL> <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[33]"></a>USART3_IRQHandler</STRONG> (Thumb, 98 bytes, Stack size 16 bytes, stm32f1xx_it.o(i.USART3_IRQHandler)) <BR><BR>[Stack]<UL><LI>Max Depth = 100<LI>Call Chain = USART3_IRQHandler ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[127]">>></a> parseModbusResponse <LI><a href="#[fb]">>></a> HAL_UART_IRQHandler <LI><a href="#[89]">>></a> HAL_UART_Receive_DMA <LI><a href="#[bc]">>></a> HAL_UART_DMAStop </UL> <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[9c]"></a>UpdateFirmware</STRONG> (Thumb, 316 bytes, Stack size 632 bytes, ec800_ftp_ota.o(i.UpdateFirmware)) <BR><BR>[Stack]<UL><LI>Max Depth = 736<LI>Call Chain = UpdateFirmware ⇒ writeFlashPage ⇒ FLASH_Write ⇒ HAL_FLASH_Program ⇒ FLASH_WaitForLastOperation </UL> <BR>[Calls]<UL><LI><a href="#[90]">>></a> EC800M_SendCommand <LI><a href="#[88]">>></a> Accept_and_Compare_Str <LI><a href="#[9b]">>></a> __2snprintf <LI><a href="#[94]">>></a> __aeabi_memclr4 <LI><a href="#[63]">>></a> __aeabi_memset <LI><a href="#[129]">>></a> writeFlashPage <LI><a href="#[128]">>></a> extract_data_as_uint32 </UL> <BR>[Called By]<UL><LI><a href="#[9a]">>></a> EC800_FTP_DownloadText </UL> <P><STRONG><a name="[7]"></a>UsageFault_Handler</STRONG> (Thumb, 4 bytes, Stack size 0 bytes, stm32f1xx_it.o(i.UsageFault_Handler)) <BR>[Address Reference Count : 1]<UL><LI> startup_stm32f103xe.o(RESET) </UL> <P><STRONG><a name="[9d]"></a>Write_paramArea</STRONG> (Thumb, 26 bytes, Stack size 16 bytes, flash.o(i.Write_paramArea)) <BR><BR>[Stack]<UL><LI>Max Depth = 104<LI>Call Chain = Write_paramArea ⇒ FLASH_Write ⇒ HAL_FLASH_Program ⇒ FLASH_WaitForLastOperation </UL> <BR>[Calls]<UL><LI><a href="#[cb]">>></a> FLASH_Write <LI><a href="#[c4]">>></a> FLASH_Erase </UL> <BR>[Called By]<UL><LI><a href="#[9a]">>></a> EC800_FTP_DownloadText </UL> <P><STRONG><a name="[12a]"></a>__0printf</STRONG> (Thumb, 22 bytes, Stack size 24 bytes, printfa.o(i.__0printf), UNUSED) <BR><BR>[Calls]<UL><LI><a href="#[12b]">>></a> _printf_core </UL> <P><STRONG><a name="[1f1]"></a>__1printf</STRONG> (Thumb, 0 bytes, Stack size 24 bytes, printfa.o(i.__0printf), UNUSED) <P><STRONG><a name="[95]"></a>__2printf</STRONG> (Thumb, 0 bytes, Stack size 24 bytes, printfa.o(i.__0printf)) <BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = __2printf </UL> <BR>[Called By]<UL><LI><a href="#[167]">>></a> isTurning <LI><a href="#[122]">>></a> task_ec800_content <LI><a href="#[127]">>></a> parseModbusResponse <LI><a href="#[b2]">>></a> parse_Login_Response <LI><a href="#[b5]">>></a> parse_Latitude_Longitude_Data <LI><a href="#[a6]">>></a> parseServerTime <LI><a href="#[b7]">>></a> EC800_subscribeToTopic <LI><a href="#[b4]">>></a> EC800_respondUpdateDate <LI><a href="#[b3]">>></a> EC800_respondRealDate <LI><a href="#[ae]">>></a> EC800_respondParse <LI><a href="#[a8]">>></a> EC800_readGnssDate <LI><a href="#[a7]">>></a> EC800_publishMessage <LI><a href="#[a4]">>></a> EC800_parseRespondTime <LI><a href="#[a3]">>></a> EC800_gnss_init <LI><a href="#[96]">>></a> EC800_getIMSI <LI><a href="#[93]">>></a> EC800M_link <LI><a href="#[184]">>></a> parseModbus10Response <LI><a href="#[183]">>></a> parseModbus03Response <LI><a href="#[9f]">>></a> EC800_LogIn_FTP <LI><a href="#[9a]">>></a> EC800_FTP_DownloadText </UL> <P><STRONG><a name="[1f2]"></a>__c89printf</STRONG> (Thumb, 0 bytes, Stack size 24 bytes, printfa.o(i.__0printf), UNUSED) <P><STRONG><a name="[1f3]"></a>printf</STRONG> (Thumb, 0 bytes, Stack size 24 bytes, printfa.o(i.__0printf), UNUSED) <P><STRONG><a name="[12c]"></a>__0snprintf</STRONG> (Thumb, 44 bytes, Stack size 32 bytes, printfa.o(i.__0snprintf), UNUSED) <BR><BR>[Calls]<UL><LI><a href="#[12b]">>></a> _printf_core </UL> <P><STRONG><a name="[1f4]"></a>__1snprintf</STRONG> (Thumb, 0 bytes, Stack size 32 bytes, printfa.o(i.__0snprintf), UNUSED) <P><STRONG><a name="[9b]"></a>__2snprintf</STRONG> (Thumb, 0 bytes, Stack size 32 bytes, printfa.o(i.__0snprintf)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = __2snprintf </UL> <BR>[Called By]<UL><LI><a href="#[9c]">>></a> UpdateFirmware <LI><a href="#[9f]">>></a> EC800_LogIn_FTP <LI><a href="#[9a]">>></a> EC800_FTP_DownloadText </UL> <P><STRONG><a name="[1f5]"></a>__c89snprintf</STRONG> (Thumb, 0 bytes, Stack size 32 bytes, printfa.o(i.__0snprintf), UNUSED) <P><STRONG><a name="[1f6]"></a>snprintf</STRONG> (Thumb, 0 bytes, Stack size 32 bytes, printfa.o(i.__0snprintf), UNUSED) <P><STRONG><a name="[12d]"></a>__0sprintf</STRONG> (Thumb, 34 bytes, Stack size 24 bytes, printfa.o(i.__0sprintf), UNUSED) <BR><BR>[Calls]<UL><LI><a href="#[59]">>></a> _sputc <LI><a href="#[12b]">>></a> _printf_core </UL> <P><STRONG><a name="[1f7]"></a>__1sprintf</STRONG> (Thumb, 0 bytes, Stack size 24 bytes, printfa.o(i.__0sprintf), UNUSED) <P><STRONG><a name="[99]"></a>__2sprintf</STRONG> (Thumb, 0 bytes, Stack size 24 bytes, printfa.o(i.__0sprintf)) <BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = __2sprintf </UL> <BR>[Called By]<UL><LI><a href="#[195]">>></a> print_string_ptr <LI><a href="#[191]">>></a> print_number <LI><a href="#[b6]">>></a> EC800_stateTransition_use <LI><a href="#[b9]">>></a> requesting_Fence_Data <LI><a href="#[b8]">>></a> Login_Topic <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[ba]">>></a> EC800_time_calibration <LI><a href="#[b7]">>></a> EC800_subscribeToTopic <LI><a href="#[a7]">>></a> EC800_publishMessage <LI><a href="#[93]">>></a> EC800M_link </UL> <P><STRONG><a name="[1f8]"></a>__c89sprintf</STRONG> (Thumb, 0 bytes, Stack size 24 bytes, printfa.o(i.__0sprintf), UNUSED) <P><STRONG><a name="[1f9]"></a>sprintf</STRONG> (Thumb, 0 bytes, Stack size 24 bytes, printfa.o(i.__0sprintf), UNUSED) <P><STRONG><a name="[13d]"></a>__ARM_fpclassify</STRONG> (Thumb, 40 bytes, Stack size 0 bytes, fpclassify.o(i.__ARM_fpclassify)) <BR><BR>[Called By]<UL><LI><a href="#[166]">>></a> pow <LI><a href="#[13b]">>></a> asin <LI><a href="#[13f]">>></a> atan </UL> <P><STRONG><a name="[6a]"></a>__aeabi_errno_addr</STRONG> (Thumb, 4 bytes, Stack size 0 bytes, errno.o(i.__aeabi_errno_addr)) <BR><BR>[Called By]<UL><LI><a href="#[84]">>></a> _strtoul <LI><a href="#[6b]">>></a> strtol <LI><a href="#[69]">>></a> atoi </UL> <P><STRONG><a name="[1fa]"></a>__rt_errno_addr</STRONG> (Thumb, 0 bytes, Stack size 0 bytes, errno.o(i.__aeabi_errno_addr), UNUSED) <P><STRONG><a name="[12e]"></a>__kernel_poly</STRONG> (Thumb, 170 bytes, Stack size 24 bytes, poly.o(i.__kernel_poly)) <BR><BR>[Stack]<UL><LI>Max Depth = 112<LI>Call Chain = __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[79]">>></a> __aeabi_dmul <LI><a href="#[72]">>></a> __aeabi_dadd </UL> <BR>[Called By]<UL><LI><a href="#[166]">>></a> pow <LI><a href="#[13b]">>></a> asin <LI><a href="#[13f]">>></a> atan </UL> <P><STRONG><a name="[12f]"></a>__mathlib_dbl_divzero</STRONG> (Thumb, 12 bytes, Stack size 0 bytes, dunder.o(i.__mathlib_dbl_divzero)) <BR><BR>[Stack]<UL><LI>Max Depth = 40<LI>Call Chain = __mathlib_dbl_divzero ⇒ __aeabi_ddiv ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[7a]">>></a> __aeabi_ddiv </UL> <BR>[Called By]<UL><LI><a href="#[166]">>></a> pow </UL> <P><STRONG><a name="[130]"></a>__mathlib_dbl_infnan</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, dunder.o(i.__mathlib_dbl_infnan)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = __mathlib_dbl_infnan ⇒ __ARM_scalbn </UL> <BR>[Calls]<UL><LI><a href="#[131]">>></a> __ARM_scalbn </UL> <BR>[Called By]<UL><LI><a href="#[13b]">>></a> asin <LI><a href="#[13f]">>></a> atan </UL> <P><STRONG><a name="[132]"></a>__mathlib_dbl_infnan2</STRONG> (Thumb, 4 bytes, Stack size 0 bytes, dunder.o(i.__mathlib_dbl_infnan2)) <BR><BR>[Stack]<UL><LI>Max Depth = 88<LI>Call Chain = __mathlib_dbl_infnan2 ⇒ __aeabi_dadd ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[72]">>></a> __aeabi_dadd </UL> <BR>[Called By]<UL><LI><a href="#[166]">>></a> pow <LI><a href="#[140]">>></a> atan2 </UL> <P><STRONG><a name="[133]"></a>__mathlib_dbl_invalid</STRONG> (Thumb, 12 bytes, Stack size 0 bytes, dunder.o(i.__mathlib_dbl_invalid)) <BR><BR>[Stack]<UL><LI>Max Depth = 40<LI>Call Chain = __mathlib_dbl_invalid ⇒ __aeabi_ddiv ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[7a]">>></a> __aeabi_ddiv </UL> <BR>[Called By]<UL><LI><a href="#[166]">>></a> pow <LI><a href="#[13b]">>></a> asin </UL> <P><STRONG><a name="[134]"></a>__mathlib_dbl_overflow</STRONG> (Thumb, 14 bytes, Stack size 0 bytes, dunder.o(i.__mathlib_dbl_overflow)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = __mathlib_dbl_overflow ⇒ __ARM_scalbn </UL> <BR>[Calls]<UL><LI><a href="#[131]">>></a> __ARM_scalbn </UL> <BR>[Called By]<UL><LI><a href="#[166]">>></a> pow </UL> <P><STRONG><a name="[135]"></a>__mathlib_dbl_underflow</STRONG> (Thumb, 10 bytes, Stack size 0 bytes, dunder.o(i.__mathlib_dbl_underflow)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = __mathlib_dbl_underflow ⇒ __ARM_scalbn </UL> <BR>[Calls]<UL><LI><a href="#[131]">>></a> __ARM_scalbn </UL> <BR>[Called By]<UL><LI><a href="#[166]">>></a> pow <LI><a href="#[13b]">>></a> asin <LI><a href="#[13f]">>></a> atan </UL> <P><STRONG><a name="[1fb]"></a>__scatterload_copy</STRONG> (Thumb, 14 bytes, Stack size unknown bytes, handlers.o(i.__scatterload_copy), UNUSED) <P><STRONG><a name="[1fc]"></a>__scatterload_null</STRONG> (Thumb, 2 bytes, Stack size unknown bytes, handlers.o(i.__scatterload_null), UNUSED) <P><STRONG><a name="[1fd]"></a>__scatterload_zeroinit</STRONG> (Thumb, 14 bytes, Stack size unknown bytes, handlers.o(i.__scatterload_zeroinit), UNUSED) <P><STRONG><a name="[13c]"></a>__set_errno</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, errno.o(i.__set_errno)) <BR><BR>[Called By]<UL><LI><a href="#[13e]">>></a> sqrt <LI><a href="#[166]">>></a> pow <LI><a href="#[13b]">>></a> asin </UL> <P><STRONG><a name="[13b]"></a>asin</STRONG> (Thumb, 572 bytes, Stack size 56 bytes, asin.o(i.asin)) <BR><BR>[Stack]<UL><LI>Max Depth = 168<LI>Call Chain = asin ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[77]">>></a> __aeabi_dsub <LI><a href="#[79]">>></a> __aeabi_dmul <LI><a href="#[72]">>></a> __aeabi_dadd <LI><a href="#[78]">>></a> __aeabi_drsub <LI><a href="#[7a]">>></a> __aeabi_ddiv <LI><a href="#[13e]">>></a> sqrt <LI><a href="#[131]">>></a> __ARM_scalbn <LI><a href="#[13c]">>></a> __set_errno <LI><a href="#[12e]">>></a> __kernel_poly <LI><a href="#[13d]">>></a> __ARM_fpclassify <LI><a href="#[135]">>></a> __mathlib_dbl_underflow <LI><a href="#[133]">>></a> __mathlib_dbl_invalid <LI><a href="#[130]">>></a> __mathlib_dbl_infnan </UL> <BR>[Called By]<UL><LI><a href="#[141]">>></a> atk_ms6050_dmp_get_data </UL> <P><STRONG><a name="[13f]"></a>atan</STRONG> (Thumb, 474 bytes, Stack size 40 bytes, atan.o(i.atan)) <BR><BR>[Stack]<UL><LI>Max Depth = 152<LI>Call Chain = atan ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[77]">>></a> __aeabi_dsub <LI><a href="#[79]">>></a> __aeabi_dmul <LI><a href="#[72]">>></a> __aeabi_dadd <LI><a href="#[78]">>></a> __aeabi_drsub <LI><a href="#[7a]">>></a> __aeabi_ddiv <LI><a href="#[131]">>></a> __ARM_scalbn <LI><a href="#[12e]">>></a> __kernel_poly <LI><a href="#[13d]">>></a> __ARM_fpclassify <LI><a href="#[135]">>></a> __mathlib_dbl_underflow <LI><a href="#[130]">>></a> __mathlib_dbl_infnan </UL> <BR>[Called By]<UL><LI><a href="#[140]">>></a> atan2 </UL> <P><STRONG><a name="[140]"></a>atan2</STRONG> (Thumb, 346 bytes, Stack size 32 bytes, atan2.o(i.atan2)) <BR><BR>[Stack]<UL><LI>Max Depth = 184<LI>Call Chain = atan2 ⇒ atan ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[77]">>></a> __aeabi_dsub <LI><a href="#[78]">>></a> __aeabi_drsub <LI><a href="#[7a]">>></a> __aeabi_ddiv <LI><a href="#[132]">>></a> __mathlib_dbl_infnan2 <LI><a href="#[13f]">>></a> atan </UL> <BR>[Called By]<UL><LI><a href="#[141]">>></a> atk_ms6050_dmp_get_data </UL> <P><STRONG><a name="[141]"></a>atk_ms6050_dmp_get_data</STRONG> (Thumb, 536 bytes, Stack size 136 bytes, inv_mpu.o(i.atk_ms6050_dmp_get_data)) <BR><BR>[Stack]<UL><LI>Max Depth = 320<LI>Call Chain = atk_ms6050_dmp_get_data ⇒ atan2 ⇒ atan ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[143]">>></a> __aeabi_f2d <LI><a href="#[79]">>></a> __aeabi_dmul <LI><a href="#[11d]">>></a> __aeabi_fmul <LI><a href="#[71]">>></a> __aeabi_fdiv <LI><a href="#[6c]">>></a> __aeabi_fadd <LI><a href="#[142]">>></a> dmp_read_fifo <LI><a href="#[6f]">>></a> __aeabi_fsub <LI><a href="#[81]">>></a> __aeabi_d2f <LI><a href="#[7b]">>></a> __aeabi_i2f <LI><a href="#[140]">>></a> atan2 <LI><a href="#[13b]">>></a> asin </UL> <BR>[Called By]<UL><LI><a href="#[167]">>></a> isTurning </UL> <P><STRONG><a name="[144]"></a>atk_ms6050_get_clock_ms</STRONG> (Thumb, 20 bytes, Stack size 8 bytes, inv_mpu.o(i.atk_ms6050_get_clock_ms)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = atk_ms6050_get_clock_ms </UL> <BR>[Calls]<UL><LI><a href="#[c9]">>></a> HAL_GetTick </UL> <BR>[Called By]<UL><LI><a href="#[142]">>></a> dmp_read_fifo </UL> <P><STRONG><a name="[145]"></a>atk_ms6050_get_gyroscope</STRONG> (Thumb, 80 bytes, Stack size 32 bytes, atk_ms6050.o(i.atk_ms6050_get_gyroscope)) <BR><BR>[Stack]<UL><LI>Max Depth = 92<LI>Call Chain = atk_ms6050_get_gyroscope ⇒ atk_ms6050_read ⇒ atk_ms6050_iic_wait_ack ⇒ atk_ms6050_iic_stop ⇒ atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[146]">>></a> atk_ms6050_read </UL> <BR>[Called By]<UL><LI><a href="#[165]">>></a> getAngularVelocity </UL> <P><STRONG><a name="[147]"></a>atk_ms6050_iic_ack</STRONG> (Thumb, 76 bytes, Stack size 8 bytes, atk_ms6050_iic.o(i.atk_ms6050_iic_ack)) <BR><BR>[Stack]<UL><LI>Max Depth = 20<LI>Call Chain = atk_ms6050_iic_ack ⇒ atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[113]">>></a> HAL_GPIO_WritePin <LI><a href="#[148]">>></a> atk_ms6050_iic_delay </UL> <BR>[Called By]<UL><LI><a href="#[14b]">>></a> atk_ms6050_iic_read_byte </UL> <P><STRONG><a name="[14a]"></a>atk_ms6050_iic_nack</STRONG> (Thumb, 58 bytes, Stack size 8 bytes, atk_ms6050_iic.o(i.atk_ms6050_iic_nack)) <BR><BR>[Stack]<UL><LI>Max Depth = 20<LI>Call Chain = atk_ms6050_iic_nack ⇒ atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[113]">>></a> HAL_GPIO_WritePin <LI><a href="#[148]">>></a> atk_ms6050_iic_delay </UL> <BR>[Called By]<UL><LI><a href="#[14b]">>></a> atk_ms6050_iic_read_byte </UL> <P><STRONG><a name="[14b]"></a>atk_ms6050_iic_read_byte</STRONG> (Thumb, 88 bytes, Stack size 16 bytes, atk_ms6050_iic.o(i.atk_ms6050_iic_read_byte)) <BR><BR>[Stack]<UL><LI>Max Depth = 36<LI>Call Chain = atk_ms6050_iic_read_byte ⇒ atk_ms6050_iic_nack ⇒ atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[113]">>></a> HAL_GPIO_WritePin <LI><a href="#[14c]">>></a> HAL_GPIO_ReadPin <LI><a href="#[14a]">>></a> atk_ms6050_iic_nack <LI><a href="#[147]">>></a> atk_ms6050_iic_ack <LI><a href="#[148]">>></a> atk_ms6050_iic_delay </UL> <BR>[Called By]<UL><LI><a href="#[146]">>></a> atk_ms6050_read </UL> <P><STRONG><a name="[14d]"></a>atk_ms6050_iic_send_byte</STRONG> (Thumb, 102 bytes, Stack size 16 bytes, atk_ms6050_iic.o(i.atk_ms6050_iic_send_byte)) <BR><BR>[Stack]<UL><LI>Max Depth = 28<LI>Call Chain = atk_ms6050_iic_send_byte ⇒ atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[113]">>></a> HAL_GPIO_WritePin <LI><a href="#[148]">>></a> atk_ms6050_iic_delay </UL> <BR>[Called By]<UL><LI><a href="#[151]">>></a> atk_ms6050_write <LI><a href="#[146]">>></a> atk_ms6050_read </UL> <P><STRONG><a name="[14e]"></a>atk_ms6050_iic_start</STRONG> (Thumb, 72 bytes, Stack size 8 bytes, atk_ms6050_iic.o(i.atk_ms6050_iic_start)) <BR><BR>[Stack]<UL><LI>Max Depth = 20<LI>Call Chain = atk_ms6050_iic_start ⇒ atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[113]">>></a> HAL_GPIO_WritePin <LI><a href="#[148]">>></a> atk_ms6050_iic_delay </UL> <BR>[Called By]<UL><LI><a href="#[151]">>></a> atk_ms6050_write <LI><a href="#[146]">>></a> atk_ms6050_read </UL> <P><STRONG><a name="[14f]"></a>atk_ms6050_iic_stop</STRONG> (Thumb, 58 bytes, Stack size 8 bytes, atk_ms6050_iic.o(i.atk_ms6050_iic_stop)) <BR><BR>[Stack]<UL><LI>Max Depth = 20<LI>Call Chain = atk_ms6050_iic_stop ⇒ atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[113]">>></a> HAL_GPIO_WritePin <LI><a href="#[148]">>></a> atk_ms6050_iic_delay </UL> <BR>[Called By]<UL><LI><a href="#[150]">>></a> atk_ms6050_iic_wait_ack <LI><a href="#[151]">>></a> atk_ms6050_write <LI><a href="#[146]">>></a> atk_ms6050_read </UL> <P><STRONG><a name="[150]"></a>atk_ms6050_iic_wait_ack</STRONG> (Thumb, 96 bytes, Stack size 16 bytes, atk_ms6050_iic.o(i.atk_ms6050_iic_wait_ack)) <BR><BR>[Stack]<UL><LI>Max Depth = 36<LI>Call Chain = atk_ms6050_iic_wait_ack ⇒ atk_ms6050_iic_stop ⇒ atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[113]">>></a> HAL_GPIO_WritePin <LI><a href="#[14c]">>></a> HAL_GPIO_ReadPin <LI><a href="#[148]">>></a> atk_ms6050_iic_delay <LI><a href="#[14f]">>></a> atk_ms6050_iic_stop </UL> <BR>[Called By]<UL><LI><a href="#[151]">>></a> atk_ms6050_write <LI><a href="#[146]">>></a> atk_ms6050_read </UL> <P><STRONG><a name="[146]"></a>atk_ms6050_read</STRONG> (Thumb, 138 bytes, Stack size 24 bytes, atk_ms6050.o(i.atk_ms6050_read)) <BR><BR>[Stack]<UL><LI>Max Depth = 60<LI>Call Chain = atk_ms6050_read ⇒ atk_ms6050_iic_wait_ack ⇒ atk_ms6050_iic_stop ⇒ atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[150]">>></a> atk_ms6050_iic_wait_ack <LI><a href="#[14f]">>></a> atk_ms6050_iic_stop <LI><a href="#[14e]">>></a> atk_ms6050_iic_start <LI><a href="#[14d]">>></a> atk_ms6050_iic_send_byte <LI><a href="#[14b]">>></a> atk_ms6050_iic_read_byte </UL> <BR>[Called By]<UL><LI><a href="#[15f]">>></a> mpu_read_fifo_stream <LI><a href="#[145]">>></a> atk_ms6050_get_gyroscope </UL> <P><STRONG><a name="[151]"></a>atk_ms6050_write</STRONG> (Thumb, 112 bytes, Stack size 24 bytes, atk_ms6050.o(i.atk_ms6050_write)) <BR><BR>[Stack]<UL><LI>Max Depth = 60<LI>Call Chain = atk_ms6050_write ⇒ atk_ms6050_iic_wait_ack ⇒ atk_ms6050_iic_stop ⇒ atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[150]">>></a> atk_ms6050_iic_wait_ack <LI><a href="#[14f]">>></a> atk_ms6050_iic_stop <LI><a href="#[14e]">>></a> atk_ms6050_iic_start <LI><a href="#[14d]">>></a> atk_ms6050_iic_send_byte </UL> <BR>[Called By]<UL><LI><a href="#[160]">>></a> mpu_reset_fifo </UL> <P><STRONG><a name="[c3]"></a>cJSON_AddItemToArray</STRONG> (Thumb, 42 bytes, Stack size 16 bytes, cjson.o(i.cJSON_AddItemToArray)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = cJSON_AddItemToArray </UL> <BR>[Calls]<UL><LI><a href="#[152]">>></a> suffix_object </UL> <BR>[Called By]<UL><LI><a href="#[bf]">>></a> cJSON_AddItemToObject <LI><a href="#[bb]">>></a> EC800_uploadRealDate </UL> <P><STRONG><a name="[bf]"></a>cJSON_AddItemToObject</STRONG> (Thumb, 44 bytes, Stack size 16 bytes, cjson.o(i.cJSON_AddItemToObject)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = cJSON_AddItemToObject ⇒ cJSON_AddItemToArray </UL> <BR>[Calls]<UL><LI><a href="#[c3]">>></a> cJSON_AddItemToArray <LI><a href="#[153]">>></a> cJSON_strdup </UL> <BR>[Called By]<UL><LI><a href="#[b9]">>></a> requesting_Fence_Data <LI><a href="#[b8]">>></a> Login_Topic <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[ba]">>></a> EC800_time_calibration </UL> <P><STRONG><a name="[c2]"></a>cJSON_CreateArray</STRONG> (Thumb, 18 bytes, Stack size 8 bytes, cjson.o(i.cJSON_CreateArray)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = cJSON_CreateArray ⇒ cJSON_New_Item </UL> <BR>[Calls]<UL><LI><a href="#[154]">>></a> cJSON_New_Item </UL> <BR>[Called By]<UL><LI><a href="#[bb]">>></a> EC800_uploadRealDate </UL> <P><STRONG><a name="[c0]"></a>cJSON_CreateNumber</STRONG> (Thumb, 36 bytes, Stack size 16 bytes, cjson.o(i.cJSON_CreateNumber)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = cJSON_CreateNumber ⇒ __aeabi_d2iz </UL> <BR>[Calls]<UL><LI><a href="#[7f]">>></a> __aeabi_d2iz <LI><a href="#[154]">>></a> cJSON_New_Item </UL> <BR>[Called By]<UL><LI><a href="#[b9]">>></a> requesting_Fence_Data <LI><a href="#[b8]">>></a> Login_Topic <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[ba]">>></a> EC800_time_calibration </UL> <P><STRONG><a name="[bd]"></a>cJSON_CreateObject</STRONG> (Thumb, 18 bytes, Stack size 8 bytes, cjson.o(i.cJSON_CreateObject)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = cJSON_CreateObject ⇒ cJSON_New_Item </UL> <BR>[Calls]<UL><LI><a href="#[154]">>></a> cJSON_New_Item </UL> <BR>[Called By]<UL><LI><a href="#[b9]">>></a> requesting_Fence_Data <LI><a href="#[b8]">>></a> Login_Topic <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[ba]">>></a> EC800_time_calibration </UL> <P><STRONG><a name="[be]"></a>cJSON_CreateString</STRONG> (Thumb, 28 bytes, Stack size 16 bytes, cjson.o(i.cJSON_CreateString)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = cJSON_CreateString ⇒ cJSON_strdup </UL> <BR>[Calls]<UL><LI><a href="#[153]">>></a> cJSON_strdup <LI><a href="#[154]">>></a> cJSON_New_Item </UL> <BR>[Called By]<UL><LI><a href="#[b9]">>></a> requesting_Fence_Data <LI><a href="#[b8]">>></a> Login_Topic <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[ba]">>></a> EC800_time_calibration </UL> <P><STRONG><a name="[b1]"></a>cJSON_Delete</STRONG> (Thumb, 82 bytes, Stack size 16 bytes, cjson.o(i.cJSON_Delete)) <BR><BR>[Stack]<UL><LI>Max Depth = 16 + In Cycle <LI>Call Chain = cJSON_Delete ⇒ cJSON_Delete (Cycle) </UL> <BR>[Calls]<UL><LI><a href="#[b1]">>></a> cJSON_Delete </UL> <BR>[Called By]<UL><LI><a href="#[156]">>></a> cJSON_ParseWithOpts <LI><a href="#[b1]">>></a> cJSON_Delete <LI><a href="#[b9]">>></a> requesting_Fence_Data <LI><a href="#[b8]">>></a> Login_Topic <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[ba]">>></a> EC800_time_calibration <LI><a href="#[ae]">>></a> EC800_respondParse </UL> <P><STRONG><a name="[187]"></a>cJSON_GetArrayItem</STRONG> (Thumb, 18 bytes, Stack size 0 bytes, cjson.o(i.cJSON_GetArrayItem)) <BR><BR>[Called By]<UL><LI><a href="#[b5]">>></a> parse_Latitude_Longitude_Data </UL> <P><STRONG><a name="[186]"></a>cJSON_GetArraySize</STRONG> (Thumb, 18 bytes, Stack size 0 bytes, cjson.o(i.cJSON_GetArraySize)) <BR><BR>[Called By]<UL><LI><a href="#[b5]">>></a> parse_Latitude_Longitude_Data </UL> <P><STRONG><a name="[a5]"></a>cJSON_GetObjectItem</STRONG> (Thumb, 30 bytes, Stack size 16 bytes, cjson.o(i.cJSON_GetObjectItem)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = cJSON_GetObjectItem ⇒ cJSON_strcasecmp </UL> <BR>[Calls]<UL><LI><a href="#[155]">>></a> cJSON_strcasecmp </UL> <BR>[Called By]<UL><LI><a href="#[b2]">>></a> parse_Login_Response <LI><a href="#[b5]">>></a> parse_Latitude_Longitude_Data <LI><a href="#[b4]">>></a> EC800_respondUpdateDate <LI><a href="#[b3]">>></a> EC800_respondRealDate <LI><a href="#[ae]">>></a> EC800_respondParse <LI><a href="#[a4]">>></a> EC800_parseRespondTime </UL> <P><STRONG><a name="[b0]"></a>cJSON_Parse</STRONG> (Thumb, 16 bytes, Stack size 8 bytes, cjson.o(i.cJSON_Parse)) <BR><BR>[Stack]<UL><LI>Max Depth = 376<LI>Call Chain = cJSON_Parse ⇒ cJSON_ParseWithOpts ⇒ parse_value ⇒ parse_number ⇒ pow ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[156]">>></a> cJSON_ParseWithOpts </UL> <BR>[Called By]<UL><LI><a href="#[ae]">>></a> EC800_respondParse </UL> <P><STRONG><a name="[156]"></a>cJSON_ParseWithOpts</STRONG> (Thumb, 96 bytes, Stack size 32 bytes, cjson.o(i.cJSON_ParseWithOpts)) <BR><BR>[Stack]<UL><LI>Max Depth = 368<LI>Call Chain = cJSON_ParseWithOpts ⇒ parse_value ⇒ parse_number ⇒ pow ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[b1]">>></a> cJSON_Delete <LI><a href="#[157]">>></a> skip <LI><a href="#[158]">>></a> parse_value <LI><a href="#[154]">>></a> cJSON_New_Item </UL> <BR>[Called By]<UL><LI><a href="#[b0]">>></a> cJSON_Parse </UL> <P><STRONG><a name="[c1]"></a>cJSON_Print</STRONG> (Thumb, 18 bytes, Stack size 8 bytes, cjson.o(i.cJSON_Print)) <BR><BR>[Stack]<UL><LI>Max Depth = 184<LI>Call Chain = cJSON_Print ⇒ print_value ⇒ print_object ⇒ print_value (Cycle) </UL> <BR>[Calls]<UL><LI><a href="#[159]">>></a> print_value </UL> <BR>[Called By]<UL><LI><a href="#[b9]">>></a> requesting_Fence_Data <LI><a href="#[b8]">>></a> Login_Topic <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[ba]">>></a> EC800_time_calibration </UL> <P><STRONG><a name="[15c]"></a>checkModbusCRC</STRONG> (Thumb, 52 bytes, Stack size 20 bytes, comm_car_485.o(i.checkModbusCRC)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = checkModbusCRC ⇒ modbusCRC </UL> <BR>[Calls]<UL><LI><a href="#[15d]">>></a> modbusCRC </UL> <BR>[Called By]<UL><LI><a href="#[127]">>></a> parseModbusResponse </UL> <P><STRONG><a name="[15e]"></a>configureTimerForRunTimeStats</STRONG> (Thumb, 10 bytes, Stack size 8 bytes, main.o(i.configureTimerForRunTimeStats)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = configureTimerForRunTimeStats </UL> <BR>[Calls]<UL><LI><a href="#[dc]">>></a> HAL_TIM_Base_Start_IT </UL> <BR>[Called By]<UL><LI><a href="#[171]">>></a> vTaskStartScheduler </UL> <P><STRONG><a name="[142]"></a>dmp_read_fifo</STRONG> (Thumb, 456 bytes, Stack size 88 bytes, inv_mpu_dmp_motion_driver.o(i.dmp_read_fifo)) <BR><BR>[Stack]<UL><LI>Max Depth = 180<LI>Call Chain = dmp_read_fifo ⇒ mpu_read_fifo_stream ⇒ mpu_reset_fifo ⇒ atk_ms6050_write ⇒ atk_ms6050_iic_wait_ack ⇒ atk_ms6050_iic_stop ⇒ atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[161]">>></a> decode_gesture <LI><a href="#[160]">>></a> mpu_reset_fifo <LI><a href="#[15f]">>></a> mpu_read_fifo_stream <LI><a href="#[144]">>></a> atk_ms6050_get_clock_ms </UL> <BR>[Called By]<UL><LI><a href="#[141]">>></a> atk_ms6050_dmp_get_data </UL> <P><STRONG><a name="[1c4]"></a>eTaskConfirmSleepModeStatus</STRONG> (Thumb, 42 bytes, Stack size 0 bytes, tasks.o(i.eTaskConfirmSleepModeStatus)) <BR><BR>[Called By]<UL><LI><a href="#[1a8]">>></a> vPortSuppressTicksAndSleep </UL> <P><STRONG><a name="[128]"></a>extract_data_as_uint32</STRONG> (Thumb, 128 bytes, Stack size 48 bytes, ec800_ftp_ota.o(i.extract_data_as_uint32)) <BR><BR>[Stack]<UL><LI>Max Depth = 72<LI>Call Chain = extract_data_as_uint32 ⇒ search_sequence </UL> <BR>[Calls]<UL><LI><a href="#[8c]">>></a> search_sequence <LI><a href="#[8b]">>></a> strlen <LI><a href="#[8f]">>></a> strstr <LI><a href="#[62]">>></a> __aeabi_memclr <LI><a href="#[15b]">>></a> __aeabi_memcpy </UL> <BR>[Called By]<UL><LI><a href="#[9c]">>></a> UpdateFirmware </UL> <P><STRONG><a name="[164]"></a>floor</STRONG> (Thumb, 204 bytes, Stack size 24 bytes, floor.o(i.floor)) <BR><BR>[Stack]<UL><LI>Max Depth = 112<LI>Call Chain = floor ⇒ __aeabi_dadd ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[72]">>></a> __aeabi_dadd <LI><a href="#[137]">>></a> __aeabi_cdrcmple <LI><a href="#[78]">>></a> __aeabi_drsub </UL> <BR>[Called By]<UL><LI><a href="#[191]">>></a> print_number </UL> <P><STRONG><a name="[57]"></a>fputc</STRONG> (Thumb, 22 bytes, Stack size 16 bytes, main.o(i.fputc)) <BR><BR>[Stack]<UL><LI>Max Depth = 80<LI>Call Chain = fputc ⇒ HAL_UART_Transmit ⇒ UART_WaitOnFlagUntilTimeout </UL> <BR>[Calls]<UL><LI><a href="#[92]">>></a> HAL_UART_Transmit </UL> <BR>[Address Reference Count : 1]<UL><LI> printfa.o(i.__0printf) </UL> <P><STRONG><a name="[1]"></a>free</STRONG> (Thumb, 76 bytes, Stack size 8 bytes, malloc.o(i.free)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = free </UL> <BR>[Called By]<UL><LI><a href="#[b9]">>></a> requesting_Fence_Data <LI><a href="#[b8]">>></a> Login_Topic <LI><a href="#[bb]">>></a> EC800_uploadRealDate <LI><a href="#[ba]">>></a> EC800_time_calibration </UL> <BR>[Address Reference Count : 1]<UL><LI> cjson.o(.data) </UL> <P><STRONG><a name="[165]"></a>getAngularVelocity</STRONG> (Thumb, 138 bytes, Stack size 72 bytes, turndetection.o(i.getAngularVelocity)) <BR><BR>[Stack]<UL><LI>Max Depth = 312<LI>Call Chain = getAngularVelocity ⇒ pow ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[7d]">>></a> __aeabi_i2d <LI><a href="#[72]">>></a> __aeabi_dadd <LI><a href="#[81]">>></a> __aeabi_d2f <LI><a href="#[145]">>></a> atk_ms6050_get_gyroscope <LI><a href="#[13e]">>></a> sqrt <LI><a href="#[166]">>></a> pow </UL> <BR>[Called By]<UL><LI><a href="#[167]">>></a> isTurning </UL> <P><STRONG><a name="[1d2]"></a>getRunTimeCounterValue</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, main.o(i.getRunTimeCounterValue)) <BR><BR>[Called By]<UL><LI><a href="#[60]">>></a> vTaskSwitchContext </UL> <P><STRONG><a name="[167]"></a>isTurning</STRONG> (Thumb, 380 bytes, Stack size 48 bytes, turndetection.o(i.isTurning)) <BR><BR>[Stack]<UL><LI>Max Depth = 368<LI>Call Chain = isTurning ⇒ atk_ms6050_dmp_get_data ⇒ atan2 ⇒ atan ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[143]">>></a> __aeabi_f2d <LI><a href="#[137]">>></a> __aeabi_cdrcmple <LI><a href="#[168]">>></a> lowPassFilter <LI><a href="#[165]">>></a> getAngularVelocity <LI><a href="#[6f]">>></a> __aeabi_fsub <LI><a href="#[81]">>></a> __aeabi_d2f <LI><a href="#[141]">>></a> atk_ms6050_dmp_get_data <LI><a href="#[95]">>></a> __2printf </UL> <BR>[Called By]<UL><LI><a href="#[122]">>></a> task_ec800_content </UL> <P><STRONG><a name="[168]"></a>lowPassFilter</STRONG> (Thumb, 66 bytes, Stack size 48 bytes, turndetection.o(i.lowPassFilter)) <BR><BR>[Stack]<UL><LI>Max Depth = 136<LI>Call Chain = lowPassFilter ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[143]">>></a> __aeabi_f2d <LI><a href="#[79]">>></a> __aeabi_dmul <LI><a href="#[72]">>></a> __aeabi_dadd <LI><a href="#[81]">>></a> __aeabi_d2f </UL> <BR>[Called By]<UL><LI><a href="#[167]">>></a> isTurning </UL> <P><STRONG><a name="[48]"></a>main</STRONG> (Thumb, 62 bytes, Stack size 0 bytes, main.o(i.main)) <BR><BR>[Stack]<UL><LI>Max Depth = 224<LI>Call Chain = main ⇒ MX_FREERTOS_Init ⇒ osTimerNew ⇒ xTimerCreateStatic ⇒ prvInitialiseNewTimer ⇒ prvCheckForValidListAndQueue ⇒ xQueueGenericCreateStatic ⇒ prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[16c]">>></a> osKernelStart <LI><a href="#[16b]">>></a> osKernelInitialize <LI><a href="#[169]">>></a> Remap_Vector_Table <LI><a href="#[119]">>></a> MX_USART3_UART_Init <LI><a href="#[118]">>></a> MX_USART1_UART_Init <LI><a href="#[117]">>></a> MX_UART4_Init <LI><a href="#[116]">>></a> MX_TIM4_Init <LI><a href="#[114]">>></a> MX_TIM2_Init <LI><a href="#[112]">>></a> MX_GPIO_Init <LI><a href="#[10d]">>></a> MX_FREERTOS_Init <LI><a href="#[10c]">>></a> MX_DMA_Init <LI><a href="#[d5]">>></a> HAL_Init <LI><a href="#[16a]">>></a> GetUniqueID <LI><a href="#[120]">>></a> SystemClock_Config </UL> <BR>[Address Reference Count : 1]<UL><LI> entry9a.o(.ARM.Collect$$$$0000000B) </UL> <P><STRONG><a name="[0]"></a>malloc</STRONG> (Thumb, 92 bytes, Stack size 20 bytes, malloc.o(i.malloc)) <BR><BR>[Stack]<UL><LI>Max Depth = 20<LI>Call Chain = malloc </UL> <BR>[Address Reference Count : 1]<UL><LI> cjson.o(.data) </UL> <P><STRONG><a name="[15d]"></a>modbusCRC</STRONG> (Thumb, 54 bytes, Stack size 12 bytes, comm_car_485.o(i.modbusCRC)) <BR><BR>[Stack]<UL><LI>Max Depth = 12<LI>Call Chain = modbusCRC </UL> <BR>[Called By]<UL><LI><a href="#[15c]">>></a> checkModbusCRC </UL> <P><STRONG><a name="[15f]"></a>mpu_read_fifo_stream</STRONG> (Thumb, 186 bytes, Stack size 24 bytes, inv_mpu.o(i.mpu_read_fifo_stream)) <BR><BR>[Stack]<UL><LI>Max Depth = 92<LI>Call Chain = mpu_read_fifo_stream ⇒ mpu_reset_fifo ⇒ atk_ms6050_write ⇒ atk_ms6050_iic_wait_ack ⇒ atk_ms6050_iic_stop ⇒ atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[160]">>></a> mpu_reset_fifo <LI><a href="#[146]">>></a> atk_ms6050_read </UL> <BR>[Called By]<UL><LI><a href="#[142]">>></a> dmp_read_fifo </UL> <P><STRONG><a name="[160]"></a>mpu_reset_fifo</STRONG> (Thumb, 450 bytes, Stack size 8 bytes, inv_mpu.o(i.mpu_reset_fifo)) <BR><BR>[Stack]<UL><LI>Max Depth = 68<LI>Call Chain = mpu_reset_fifo ⇒ atk_ms6050_write ⇒ atk_ms6050_iic_wait_ack ⇒ atk_ms6050_iic_stop ⇒ atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[d1]">>></a> HAL_Delay <LI><a href="#[151]">>></a> atk_ms6050_write </UL> <BR>[Called By]<UL><LI><a href="#[142]">>></a> dmp_read_fifo <LI><a href="#[15f]">>></a> mpu_read_fifo_stream </UL> <P><STRONG><a name="[8a]"></a>osDelay</STRONG> (Thumb, 50 bytes, Stack size 16 bytes, cmsis_os2.o(i.osDelay)) <BR><BR>[Stack]<UL><LI>Max Depth = 72<LI>Call Chain = osDelay ⇒ vTaskDelay ⇒ xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[16e]">>></a> __get_PRIMASK <LI><a href="#[16d]">>></a> __get_IPSR <LI><a href="#[16f]">>></a> __get_BASEPRI <LI><a href="#[170]">>></a> vTaskDelay </UL> <BR>[Called By]<UL><LI><a href="#[122]">>></a> task_ec800_content <LI><a href="#[9e]">>></a> EC800_FTP_OTA_Upgrade <LI><a href="#[121]">>></a> task_communication_content <LI><a href="#[52]">>></a> Task_ec800_upload <LI><a href="#[53]">>></a> Task_communication <LI><a href="#[51]">>></a> StartDefaultTask <LI><a href="#[97]">>></a> EC800_recEnable <LI><a href="#[8e]">>></a> EC800M_RecRespond <LI><a href="#[88]">>></a> Accept_and_Compare_Str </UL> <P><STRONG><a name="[16b]"></a>osKernelInitialize</STRONG> (Thumb, 58 bytes, Stack size 8 bytes, cmsis_os2.o(i.osKernelInitialize)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = osKernelInitialize </UL> <BR>[Calls]<UL><LI><a href="#[16e]">>></a> __get_PRIMASK <LI><a href="#[16d]">>></a> __get_IPSR <LI><a href="#[16f]">>></a> __get_BASEPRI </UL> <BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[16c]"></a>osKernelStart</STRONG> (Thumb, 64 bytes, Stack size 8 bytes, cmsis_os2.o(i.osKernelStart)) <BR><BR>[Stack]<UL><LI>Max Depth = 168<LI>Call Chain = osKernelStart ⇒ vTaskStartScheduler ⇒ xTimerCreateTimerTask ⇒ prvCheckForValidListAndQueue ⇒ xQueueGenericCreateStatic ⇒ prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[16e]">>></a> __get_PRIMASK <LI><a href="#[16d]">>></a> __get_IPSR <LI><a href="#[16f]">>></a> __get_BASEPRI <LI><a href="#[171]">>></a> vTaskStartScheduler </UL> <BR>[Called By]<UL><LI><a href="#[48]">>></a> main </UL> <P><STRONG><a name="[ac]"></a>osMutexAcquire</STRONG> (Thumb, 120 bytes, Stack size 24 bytes, cmsis_os2.o(i.osMutexAcquire)) <BR><BR>[Stack]<UL><LI>Max Depth = 136<LI>Call Chain = osMutexAcquire ⇒ xQueueTakeMutexRecursive ⇒ xQueueSemaphoreTake ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[172]">>></a> xQueueTakeMutexRecursive <LI><a href="#[173]">>></a> xQueueSemaphoreTake <LI><a href="#[16e]">>></a> __get_PRIMASK <LI><a href="#[16d]">>></a> __get_IPSR <LI><a href="#[16f]">>></a> __get_BASEPRI </UL> <BR>[Called By]<UL><LI><a href="#[a8]">>></a> EC800_readGnssDate </UL> <P><STRONG><a name="[10e]"></a>osMutexNew</STRONG> (Thumb, 202 bytes, Stack size 32 bytes, cmsis_os2.o(i.osMutexNew)) <BR><BR>[Stack]<UL><LI>Max Depth = 176<LI>Call Chain = osMutexNew ⇒ xQueueCreateMutexStatic ⇒ prvInitialiseMutex ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[174]">>></a> xQueueCreateMutexStatic <LI><a href="#[175]">>></a> xQueueCreateMutex <LI><a href="#[176]">>></a> vQueueAddToRegistry <LI><a href="#[16e]">>></a> __get_PRIMASK <LI><a href="#[16d]">>></a> __get_IPSR <LI><a href="#[16f]">>></a> __get_BASEPRI </UL> <BR>[Called By]<UL><LI><a href="#[10d]">>></a> MX_FREERTOS_Init </UL> <P><STRONG><a name="[ad]"></a>osMutexRelease</STRONG> (Thumb, 100 bytes, Stack size 24 bytes, cmsis_os2.o(i.osMutexRelease)) <BR><BR>[Stack]<UL><LI>Max Depth = 144<LI>Call Chain = osMutexRelease ⇒ xQueueGiveMutexRecursive ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[177]">>></a> xQueueGiveMutexRecursive <LI><a href="#[178]">>></a> xQueueGenericSend <LI><a href="#[16e]">>></a> __get_PRIMASK <LI><a href="#[16d]">>></a> __get_IPSR <LI><a href="#[16f]">>></a> __get_BASEPRI </UL> <BR>[Called By]<UL><LI><a href="#[a8]">>></a> EC800_readGnssDate </UL> <P><STRONG><a name="[10f]"></a>osSemaphoreNew</STRONG> (Thumb, 230 bytes, Stack size 32 bytes, cmsis_os2.o(i.osSemaphoreNew)) <BR><BR>[Stack]<UL><LI>Max Depth = 144<LI>Call Chain = osSemaphoreNew ⇒ xQueueCreateCountingSemaphoreStatic ⇒ xQueueGenericCreateStatic ⇒ prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[178]">>></a> xQueueGenericSend <LI><a href="#[179]">>></a> xQueueGenericCreateStatic <LI><a href="#[17a]">>></a> xQueueGenericCreate <LI><a href="#[17c]">>></a> xQueueCreateCountingSemaphoreStatic <LI><a href="#[17d]">>></a> xQueueCreateCountingSemaphore <LI><a href="#[17b]">>></a> vQueueDelete <LI><a href="#[176]">>></a> vQueueAddToRegistry <LI><a href="#[16e]">>></a> __get_PRIMASK <LI><a href="#[16d]">>></a> __get_IPSR <LI><a href="#[16f]">>></a> __get_BASEPRI </UL> <BR>[Called By]<UL><LI><a href="#[10d]">>></a> MX_FREERTOS_Init </UL> <P><STRONG><a name="[111]"></a>osThreadNew</STRONG> (Thumb, 216 bytes, Stack size 56 bytes, cmsis_os2.o(i.osThreadNew)) <BR><BR>[Stack]<UL><LI>Max Depth = 192<LI>Call Chain = osThreadNew ⇒ xTaskCreate ⇒ pvPortMalloc ⇒ xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[16e]">>></a> __get_PRIMASK <LI><a href="#[16d]">>></a> __get_IPSR <LI><a href="#[16f]">>></a> __get_BASEPRI <LI><a href="#[17e]">>></a> xTaskCreateStatic <LI><a href="#[17f]">>></a> xTaskCreate </UL> <BR>[Called By]<UL><LI><a href="#[10d]">>></a> MX_FREERTOS_Init </UL> <P><STRONG><a name="[110]"></a>osTimerNew</STRONG> (Thumb, 194 bytes, Stack size 48 bytes, cmsis_os2.o(i.osTimerNew)) <BR><BR>[Stack]<UL><LI>Max Depth = 216<LI>Call Chain = osTimerNew ⇒ xTimerCreateStatic ⇒ prvInitialiseNewTimer ⇒ prvCheckForValidListAndQueue ⇒ xQueueGenericCreateStatic ⇒ prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[180]">>></a> pvPortMalloc <LI><a href="#[16e]">>></a> __get_PRIMASK <LI><a href="#[16d]">>></a> __get_IPSR <LI><a href="#[16f]">>></a> __get_BASEPRI <LI><a href="#[181]">>></a> xTimerCreateStatic <LI><a href="#[182]">>></a> xTimerCreate </UL> <BR>[Called By]<UL><LI><a href="#[10d]">>></a> MX_FREERTOS_Init </UL> <P><STRONG><a name="[183]"></a>parseModbus03Response</STRONG> (Thumb, 44 bytes, Stack size 16 bytes, comm_car_485.o(i.parseModbus03Response)) <BR><BR>[Stack]<UL><LI>Max Depth = 40<LI>Call Chain = parseModbus03Response ⇒ __2printf </UL> <BR>[Calls]<UL><LI><a href="#[95]">>></a> __2printf </UL> <BR>[Called By]<UL><LI><a href="#[127]">>></a> parseModbusResponse </UL> <P><STRONG><a name="[184]"></a>parseModbus10Response</STRONG> (Thumb, 62 bytes, Stack size 24 bytes, comm_car_485.o(i.parseModbus10Response)) <BR><BR>[Stack]<UL><LI>Max Depth = 48<LI>Call Chain = parseModbus10Response ⇒ __2printf </UL> <BR>[Calls]<UL><LI><a href="#[95]">>></a> __2printf </UL> <BR>[Called By]<UL><LI><a href="#[127]">>></a> parseModbusResponse </UL> <P><STRONG><a name="[127]"></a>parseModbusResponse</STRONG> (Thumb, 68 bytes, Stack size 16 bytes, comm_car_485.o(i.parseModbusResponse)) <BR><BR>[Stack]<UL><LI>Max Depth = 64<LI>Call Chain = parseModbusResponse ⇒ parseModbus10Response ⇒ __2printf </UL> <BR>[Calls]<UL><LI><a href="#[95]">>></a> __2printf <LI><a href="#[184]">>></a> parseModbus10Response <LI><a href="#[183]">>></a> parseModbus03Response <LI><a href="#[15c]">>></a> checkModbusCRC </UL> <BR>[Called By]<UL><LI><a href="#[33]">>></a> USART3_IRQHandler </UL> <P><STRONG><a name="[a6]"></a>parseServerTime</STRONG> (Thumb, 260 bytes, Stack size 48 bytes, ec800.o(i.parseServerTime)) <BR><BR>[Stack]<UL><LI>Max Depth = 136<LI>Call Chain = parseServerTime ⇒ atoi ⇒ strtol ⇒ _strtoul </UL> <BR>[Calls]<UL><LI><a href="#[ab]">>></a> EC800_mktime <LI><a href="#[95]">>></a> __2printf <LI><a href="#[185]">>></a> strncpy <LI><a href="#[69]">>></a> atoi </UL> <BR>[Called By]<UL><LI><a href="#[a4]">>></a> EC800_parseRespondTime </UL> <P><STRONG><a name="[b5]"></a>parse_Latitude_Longitude_Data</STRONG> (Thumb, 236 bytes, Stack size 48 bytes, ec800.o(i.parse_Latitude_Longitude_Data)) <BR><BR>[Stack]<UL><LI>Max Depth = 80<LI>Call Chain = parse_Latitude_Longitude_Data ⇒ cJSON_GetObjectItem ⇒ cJSON_strcasecmp </UL> <BR>[Calls]<UL><LI><a href="#[a5]">>></a> cJSON_GetObjectItem <LI><a href="#[186]">>></a> cJSON_GetArraySize <LI><a href="#[187]">>></a> cJSON_GetArrayItem <LI><a href="#[95]">>></a> __2printf </UL> <BR>[Called By]<UL><LI><a href="#[ae]">>></a> EC800_respondParse </UL> <P><STRONG><a name="[b2]"></a>parse_Login_Response</STRONG> (Thumb, 62 bytes, Stack size 16 bytes, ec800.o(i.parse_Login_Response)) <BR><BR>[Stack]<UL><LI>Max Depth = 48<LI>Call Chain = parse_Login_Response ⇒ cJSON_GetObjectItem ⇒ cJSON_strcasecmp </UL> <BR>[Calls]<UL><LI><a href="#[a5]">>></a> cJSON_GetObjectItem <LI><a href="#[95]">>></a> __2printf </UL> <BR>[Called By]<UL><LI><a href="#[ae]">>></a> EC800_respondParse </UL> <P><STRONG><a name="[166]"></a>pow</STRONG> (Thumb, 2512 bytes, Stack size 128 bytes, pow.o(i.pow)) <BR><BR>[Stack]<UL><LI>Max Depth = 240<LI>Call Chain = pow ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[7d]">>></a> __aeabi_i2d <LI><a href="#[77]">>></a> __aeabi_dsub <LI><a href="#[79]">>></a> __aeabi_dmul <LI><a href="#[72]">>></a> __aeabi_dadd <LI><a href="#[137]">>></a> __aeabi_cdrcmple <LI><a href="#[78]">>></a> __aeabi_drsub <LI><a href="#[7a]">>></a> __aeabi_ddiv <LI><a href="#[13e]">>></a> sqrt <LI><a href="#[131]">>></a> __ARM_scalbn <LI><a href="#[13c]">>></a> __set_errno <LI><a href="#[12e]">>></a> __kernel_poly <LI><a href="#[13d]">>></a> __ARM_fpclassify <LI><a href="#[135]">>></a> __mathlib_dbl_underflow <LI><a href="#[134]">>></a> __mathlib_dbl_overflow <LI><a href="#[133]">>></a> __mathlib_dbl_invalid <LI><a href="#[132]">>></a> __mathlib_dbl_infnan2 <LI><a href="#[12f]">>></a> __mathlib_dbl_divzero </UL> <BR>[Called By]<UL><LI><a href="#[189]">>></a> parse_number <LI><a href="#[165]">>></a> getAngularVelocity </UL> <P><STRONG><a name="[180]"></a>pvPortMalloc</STRONG> (Thumb, 296 bytes, Stack size 24 bytes, heap_4.o(i.pvPortMalloc)) <BR><BR>[Stack]<UL><LI>Max Depth = 64<LI>Call Chain = pvPortMalloc ⇒ xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[cc]">>></a> vTaskSuspendAll <LI><a href="#[1c1]">>></a> prvInsertBlockIntoFreeList <LI><a href="#[1c0]">>></a> prvHeapInit </UL> <BR>[Called By]<UL><LI><a href="#[110]">>></a> osTimerNew <LI><a href="#[17a]">>></a> xQueueGenericCreate <LI><a href="#[182]">>></a> xTimerCreate <LI><a href="#[17f]">>></a> xTaskCreate </UL> <P><STRONG><a name="[1da]"></a>pvTaskIncrementMutexHeldCount</STRONG> (Thumb, 26 bytes, Stack size 0 bytes, tasks.o(i.pvTaskIncrementMutexHeldCount)) <BR><BR>[Called By]<UL><LI><a href="#[173]">>></a> xQueueSemaphoreTake </UL> <P><STRONG><a name="[123]"></a>pvTimerGetTimerID</STRONG> (Thumb, 44 bytes, Stack size 16 bytes, timers.o(i.pvTimerGetTimerID)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = pvTimerGetTimerID </UL> <BR>[Calls]<UL><LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical </UL> <BR>[Called By]<UL><LI><a href="#[5a]">>></a> TimerCallback </UL> <P><STRONG><a name="[1ae]"></a>pxPortInitialiseStack</STRONG> (Thumb, 30 bytes, Stack size 0 bytes, port.o(i.pxPortInitialiseStack)) <BR><BR>[Called By]<UL><LI><a href="#[1ac]">>></a> prvInitialiseNewTask </UL> <P><STRONG><a name="[b9]"></a>requesting_Fence_Data</STRONG> (Thumb, 278 bytes, Stack size 88 bytes, ec800.o(i.requesting_Fence_Data)) <BR><BR>[Stack]<UL><LI>Max Depth = 316<LI>Call Chain = requesting_Fence_Data ⇒ EC800_publishMessage ⇒ EC800M_RecRespond ⇒ HAL_UART_Receive_DMA ⇒ UART_Start_Receive_DMA ⇒ HAL_DMA_Start_IT ⇒ DMA_SetConfig </UL> <BR>[Calls]<UL><LI><a href="#[c1]">>></a> cJSON_Print <LI><a href="#[b1]">>></a> cJSON_Delete <LI><a href="#[be]">>></a> cJSON_CreateString <LI><a href="#[bd]">>></a> cJSON_CreateObject <LI><a href="#[c0]">>></a> cJSON_CreateNumber <LI><a href="#[bf]">>></a> cJSON_AddItemToObject <LI><a href="#[7e]">>></a> __aeabi_ui2d <LI><a href="#[a7]">>></a> EC800_publishMessage <LI><a href="#[99]">>></a> __2sprintf <LI><a href="#[8b]">>></a> strlen <LI><a href="#[94]">>></a> __aeabi_memclr4 <LI><a href="#[1]">>></a> free </UL> <BR>[Called By]<UL><LI><a href="#[b6]">>></a> EC800_stateTransition_use </UL> <P><STRONG><a name="[8c]"></a>search_sequence</STRONG> (Thumb, 76 bytes, Stack size 24 bytes, ec800.o(i.search_sequence)) <BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = search_sequence </UL> <BR>[Called By]<UL><LI><a href="#[88]">>></a> Accept_and_Compare_Str <LI><a href="#[128]">>></a> extract_data_as_uint32 </UL> <P><STRONG><a name="[13e]"></a>sqrt</STRONG> (Thumb, 76 bytes, Stack size 24 bytes, sqrt.o(i.sqrt)) <BR><BR>[Stack]<UL><LI>Max Depth = 64<LI>Call Chain = sqrt ⇒ _dsqrt ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[85]">>></a> _dsqrt <LI><a href="#[13c]">>></a> __set_errno </UL> <BR>[Called By]<UL><LI><a href="#[165]">>></a> getAngularVelocity <LI><a href="#[166]">>></a> pow <LI><a href="#[13b]">>></a> asin </UL> <P><STRONG><a name="[121]"></a>task_communication_content</STRONG> (Thumb, 52 bytes, Stack size 8 bytes, task_communication.o(i.task_communication_content)) <BR><BR>[Stack]<UL><LI>Max Depth = 872<LI>Call Chain = task_communication_content ⇒ EC800_FTP_OTA_Upgrade ⇒ EC800_FTP_DownloadText ⇒ UpdateFirmware ⇒ writeFlashPage ⇒ FLASH_Write ⇒ HAL_FLASH_Program ⇒ FLASH_WaitForLastOperation </UL> <BR>[Calls]<UL><LI><a href="#[1c3]">>></a> vTaskSuspend <LI><a href="#[8a]">>></a> osDelay <LI><a href="#[10a]">>></a> LED0_TOGGLE <LI><a href="#[1c2]">>></a> HAL_NVIC_DisableIRQ <LI><a href="#[9e]">>></a> EC800_FTP_OTA_Upgrade </UL> <BR>[Called By]<UL><LI><a href="#[53]">>></a> Task_communication </UL> <P><STRONG><a name="[122]"></a>task_ec800_content</STRONG> (Thumb, 56 bytes, Stack size 16 bytes, task_ec800_upload.o(i.task_ec800_content)) <BR><BR>[Stack]<UL><LI>Max Depth = 544<LI>Call Chain = task_ec800_content ⇒ EC800_stateTransition_use ⇒ EC800_respondParse ⇒ cJSON_Parse ⇒ cJSON_ParseWithOpts ⇒ parse_value ⇒ parse_number ⇒ pow ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[167]">>></a> isTurning <LI><a href="#[b6]">>></a> EC800_stateTransition_use <LI><a href="#[8a]">>></a> osDelay <LI><a href="#[95]">>></a> __2printf </UL> <BR>[Called By]<UL><LI><a href="#[52]">>></a> Task_ec800_upload </UL> <P><STRONG><a name="[aa]"></a>utc_to_local_time</STRONG> (Thumb, 314 bytes, Stack size 32 bytes, ec800.o(i.utc_to_local_time)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = utc_to_local_time </UL> <BR>[Called By]<UL><LI><a href="#[a8]">>></a> EC800_readGnssDate </UL> <P><STRONG><a name="[198]"></a>uxListRemove</STRONG> (Thumb, 40 bytes, Stack size 0 bytes, list.o(i.uxListRemove)) <BR><BR>[Called By]<UL><LI><a href="#[1c3]">>></a> vTaskSuspend <LI><a href="#[1be]">>></a> xTaskRemoveFromEventList <LI><a href="#[1db]">>></a> xTaskPriorityInherit <LI><a href="#[1a5]">>></a> xTaskPriorityDisinherit <LI><a href="#[1cd]">>></a> vTaskPriorityDisinheritAfterTimeout <LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[1bb]">>></a> prvSwitchTimerLists <LI><a href="#[1b5]">>></a> prvProcessReceivedCommands <LI><a href="#[1b3]">>></a> prvProcessExpiredTimer <LI><a href="#[11f]">>></a> xTaskIncrementTick <LI><a href="#[1a1]">>></a> prvCheckTasksWaitingTermination <LI><a href="#[197]">>></a> prvAddCurrentTaskToDelayedList </UL> <P><STRONG><a name="[1ce]"></a>vApplicationGetIdleTaskMemory</STRONG> (Thumb, 14 bytes, Stack size 0 bytes, cmsis_os2.o(i.vApplicationGetIdleTaskMemory)) <BR><BR>[Called By]<UL><LI><a href="#[171]">>></a> vTaskStartScheduler </UL> <P><STRONG><a name="[1dd]"></a>vApplicationGetTimerTaskMemory</STRONG> (Thumb, 16 bytes, Stack size 0 bytes, cmsis_os2.o(i.vApplicationGetTimerTaskMemory)) <BR><BR>[Called By]<UL><LI><a href="#[1cf]">>></a> xTimerCreateTimerTask </UL> <P><STRONG><a name="[1a0]"></a>vListInitialise</STRONG> (Thumb, 26 bytes, Stack size 0 bytes, list.o(i.vListInitialise)) <BR><BR>[Called By]<UL><LI><a href="#[1ab]">>></a> xQueueGenericReset <LI><a href="#[19f]">>></a> prvCheckForValidListAndQueue <LI><a href="#[19d]">>></a> prvInitialiseTaskLists </UL> <P><STRONG><a name="[1ad]"></a>vListInitialiseItem</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, list.o(i.vListInitialiseItem)) <BR><BR>[Called By]<UL><LI><a href="#[1af]">>></a> prvInitialiseNewTimer <LI><a href="#[1ac]">>></a> prvInitialiseNewTask </UL> <P><STRONG><a name="[19a]"></a>vListInsert</STRONG> (Thumb, 52 bytes, Stack size 8 bytes, list.o(i.vListInsert)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = vListInsert </UL> <BR>[Called By]<UL><LI><a href="#[1cc]">>></a> vTaskPlaceOnEventList <LI><a href="#[1bb]">>></a> prvSwitchTimerLists <LI><a href="#[1b0]">>></a> prvInsertTimerInActiveList <LI><a href="#[197]">>></a> prvAddCurrentTaskToDelayedList </UL> <P><STRONG><a name="[199]"></a>vListInsertEnd</STRONG> (Thumb, 24 bytes, Stack size 0 bytes, list.o(i.vListInsertEnd)) <BR><BR>[Called By]<UL><LI><a href="#[1c3]">>></a> vTaskSuspend <LI><a href="#[1be]">>></a> xTaskRemoveFromEventList <LI><a href="#[1db]">>></a> xTaskPriorityInherit <LI><a href="#[1a5]">>></a> xTaskPriorityDisinherit <LI><a href="#[1cd]">>></a> vTaskPriorityDisinheritAfterTimeout <LI><a href="#[1cb]">>></a> vTaskPlaceOnEventListRestricted <LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[11f]">>></a> xTaskIncrementTick <LI><a href="#[19b]">>></a> prvAddNewTaskToReadyList <LI><a href="#[197]">>></a> prvAddCurrentTaskToDelayedList </UL> <P><STRONG><a name="[19c]"></a>vPortEnterCritical</STRONG> (Thumb, 76 bytes, Stack size 0 bytes, port.o(i.vPortEnterCritical)) <BR><BR>[Called By]<UL><LI><a href="#[1c3]">>></a> vTaskSuspend <LI><a href="#[1d7]">>></a> xTaskCheckForTimeOut <LI><a href="#[173]">>></a> xQueueSemaphoreTake <LI><a href="#[1b7]">>></a> xQueueReceive <LI><a href="#[178]">>></a> xQueueGenericSend <LI><a href="#[1ab]">>></a> xQueueGenericReset <LI><a href="#[1b9]">>></a> vQueueWaitForMessageRestricted <LI><a href="#[1bd]">>></a> prvUnlockQueue <LI><a href="#[1b2]">>></a> prvIsQueueFull <LI><a href="#[1b1]">>></a> prvIsQueueEmpty <LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[123]">>></a> pvTimerGetTimerID <LI><a href="#[19f]">>></a> prvCheckForValidListAndQueue <LI><a href="#[1a1]">>></a> prvCheckTasksWaitingTermination <LI><a href="#[19b]">>></a> prvAddNewTaskToReadyList </UL> <P><STRONG><a name="[19e]"></a>vPortExitCritical</STRONG> (Thumb, 56 bytes, Stack size 0 bytes, port.o(i.vPortExitCritical)) <BR><BR>[Called By]<UL><LI><a href="#[1c3]">>></a> vTaskSuspend <LI><a href="#[1d7]">>></a> xTaskCheckForTimeOut <LI><a href="#[173]">>></a> xQueueSemaphoreTake <LI><a href="#[1b7]">>></a> xQueueReceive <LI><a href="#[178]">>></a> xQueueGenericSend <LI><a href="#[1ab]">>></a> xQueueGenericReset <LI><a href="#[1b9]">>></a> vQueueWaitForMessageRestricted <LI><a href="#[1bd]">>></a> prvUnlockQueue <LI><a href="#[1b2]">>></a> prvIsQueueFull <LI><a href="#[1b1]">>></a> prvIsQueueEmpty <LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[123]">>></a> pvTimerGetTimerID <LI><a href="#[19f]">>></a> prvCheckForValidListAndQueue <LI><a href="#[1a1]">>></a> prvCheckTasksWaitingTermination <LI><a href="#[19b]">>></a> prvAddNewTaskToReadyList </UL> <P><STRONG><a name="[1a6]"></a>vPortFree</STRONG> (Thumb, 140 bytes, Stack size 16 bytes, heap_4.o(i.vPortFree)) <BR><BR>[Stack]<UL><LI>Max Depth = 56<LI>Call Chain = vPortFree ⇒ xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[cc]">>></a> vTaskSuspendAll <LI><a href="#[1c1]">>></a> prvInsertBlockIntoFreeList </UL> <BR>[Called By]<UL><LI><a href="#[17b]">>></a> vQueueDelete <LI><a href="#[1b5]">>></a> prvProcessReceivedCommands <LI><a href="#[17f]">>></a> xTaskCreate <LI><a href="#[1a2]">>></a> prvDeleteTCB </UL> <P><STRONG><a name="[1d3]"></a>vPortSetupTimerInterrupt</STRONG> (Thumb, 86 bytes, Stack size 0 bytes, port.o(i.vPortSetupTimerInterrupt)) <BR><BR>[Called By]<UL><LI><a href="#[1d0]">>></a> xPortStartScheduler </UL> <P><STRONG><a name="[1a8]"></a>vPortSuppressTicksAndSleep</STRONG> (Thumb, 338 bytes, Stack size 24 bytes, port.o(i.vPortSuppressTicksAndSleep)) <BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = vPortSuppressTicksAndSleep </UL> <BR>[Calls]<UL><LI><a href="#[1c5]">>></a> PreSleepProcessing <LI><a href="#[1c6]">>></a> PostSleepProcessing <LI><a href="#[1c7]">>></a> vTaskStepTick <LI><a href="#[1c4]">>></a> eTaskConfirmSleepModeStatus </UL> <BR>[Called By]<UL><LI><a href="#[5c]">>></a> prvIdleTask </UL> <P><STRONG><a name="[1c8]"></a>vPortValidateInterruptPriority</STRONG> (Thumb, 106 bytes, Stack size 16 bytes, port.o(i.vPortValidateInterruptPriority)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = vPortValidateInterruptPriority </UL> <BR>[Calls]<UL><LI><a href="#[1c9]">>></a> vPortGetIPSR </UL> <BR>[Called By]<UL><LI><a href="#[1d8]">>></a> xQueueGenericSendFromISR </UL> <P><STRONG><a name="[176]"></a>vQueueAddToRegistry</STRONG> (Thumb, 38 bytes, Stack size 0 bytes, queue.o(i.vQueueAddToRegistry)) <BR><BR>[Called By]<UL><LI><a href="#[10f]">>></a> osSemaphoreNew <LI><a href="#[10e]">>></a> osMutexNew <LI><a href="#[19f]">>></a> prvCheckForValidListAndQueue </UL> <P><STRONG><a name="[17b]"></a>vQueueDelete</STRONG> (Thumb, 50 bytes, Stack size 16 bytes, queue.o(i.vQueueDelete)) <BR><BR>[Stack]<UL><LI>Max Depth = 72<LI>Call Chain = vQueueDelete ⇒ vPortFree ⇒ xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[1ca]">>></a> vQueueUnregisterQueue <LI><a href="#[1a6]">>></a> vPortFree </UL> <BR>[Called By]<UL><LI><a href="#[10f]">>></a> osSemaphoreNew </UL> <P><STRONG><a name="[1ca]"></a>vQueueUnregisterQueue</STRONG> (Thumb, 44 bytes, Stack size 0 bytes, queue.o(i.vQueueUnregisterQueue)) <BR><BR>[Called By]<UL><LI><a href="#[17b]">>></a> vQueueDelete </UL> <P><STRONG><a name="[1b9]"></a>vQueueWaitForMessageRestricted</STRONG> (Thumb, 74 bytes, Stack size 24 bytes, queue.o(i.vQueueWaitForMessageRestricted)) <BR><BR>[Stack]<UL><LI>Max Depth = 72<LI>Call Chain = vQueueWaitForMessageRestricted ⇒ vTaskPlaceOnEventListRestricted ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[1cb]">>></a> vTaskPlaceOnEventListRestricted <LI><a href="#[1bd]">>></a> prvUnlockQueue <LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical </UL> <BR>[Called By]<UL><LI><a href="#[1b8]">>></a> prvProcessTimerOrBlockTask </UL> <P><STRONG><a name="[170]"></a>vTaskDelay</STRONG> (Thumb, 82 bytes, Stack size 16 bytes, tasks.o(i.vTaskDelay)) <BR><BR>[Stack]<UL><LI>Max Depth = 56<LI>Call Chain = vTaskDelay ⇒ xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[cc]">>></a> vTaskSuspendAll <LI><a href="#[197]">>></a> prvAddCurrentTaskToDelayedList </UL> <BR>[Called By]<UL><LI><a href="#[8a]">>></a> osDelay </UL> <P><STRONG><a name="[1d6]"></a>vTaskInternalSetTimeOutState</STRONG> (Thumb, 14 bytes, Stack size 0 bytes, tasks.o(i.vTaskInternalSetTimeOutState)) <BR><BR>[Called By]<UL><LI><a href="#[1d7]">>></a> xTaskCheckForTimeOut <LI><a href="#[173]">>></a> xQueueSemaphoreTake <LI><a href="#[1b7]">>></a> xQueueReceive <LI><a href="#[178]">>></a> xQueueGenericSend </UL> <P><STRONG><a name="[1bf]"></a>vTaskMissedYield</STRONG> (Thumb, 8 bytes, Stack size 0 bytes, tasks.o(i.vTaskMissedYield)) <BR><BR>[Called By]<UL><LI><a href="#[1bd]">>></a> prvUnlockQueue </UL> <P><STRONG><a name="[1cc]"></a>vTaskPlaceOnEventList</STRONG> (Thumb, 52 bytes, Stack size 16 bytes, tasks.o(i.vTaskPlaceOnEventList)) <BR><BR>[Stack]<UL><LI>Max Depth = 48<LI>Call Chain = vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[19a]">>></a> vListInsert <LI><a href="#[197]">>></a> prvAddCurrentTaskToDelayedList </UL> <BR>[Called By]<UL><LI><a href="#[173]">>></a> xQueueSemaphoreTake <LI><a href="#[1b7]">>></a> xQueueReceive <LI><a href="#[178]">>></a> xQueueGenericSend </UL> <P><STRONG><a name="[1cb]"></a>vTaskPlaceOnEventListRestricted</STRONG> (Thumb, 60 bytes, Stack size 16 bytes, tasks.o(i.vTaskPlaceOnEventListRestricted)) <BR><BR>[Stack]<UL><LI>Max Depth = 48<LI>Call Chain = vTaskPlaceOnEventListRestricted ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[199]">>></a> vListInsertEnd <LI><a href="#[197]">>></a> prvAddCurrentTaskToDelayedList </UL> <BR>[Called By]<UL><LI><a href="#[1b9]">>></a> vQueueWaitForMessageRestricted </UL> <P><STRONG><a name="[1cd]"></a>vTaskPriorityDisinheritAfterTimeout</STRONG> (Thumb, 194 bytes, Stack size 32 bytes, tasks.o(i.vTaskPriorityDisinheritAfterTimeout)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = vTaskPriorityDisinheritAfterTimeout </UL> <BR>[Calls]<UL><LI><a href="#[199]">>></a> vListInsertEnd <LI><a href="#[198]">>></a> uxListRemove </UL> <BR>[Called By]<UL><LI><a href="#[173]">>></a> xQueueSemaphoreTake </UL> <P><STRONG><a name="[171]"></a>vTaskStartScheduler</STRONG> (Thumb, 160 bytes, Stack size 32 bytes, tasks.o(i.vTaskStartScheduler)) <BR><BR>[Stack]<UL><LI>Max Depth = 160<LI>Call Chain = vTaskStartScheduler ⇒ xTimerCreateTimerTask ⇒ prvCheckForValidListAndQueue ⇒ xQueueGenericCreateStatic ⇒ prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[15e]">>></a> configureTimerForRunTimeStats <LI><a href="#[1cf]">>></a> xTimerCreateTimerTask <LI><a href="#[1d0]">>></a> xPortStartScheduler <LI><a href="#[1ce]">>></a> vApplicationGetIdleTaskMemory <LI><a href="#[17e]">>></a> xTaskCreateStatic </UL> <BR>[Called By]<UL><LI><a href="#[16c]">>></a> osKernelStart </UL> <P><STRONG><a name="[1c7]"></a>vTaskStepTick</STRONG> (Thumb, 56 bytes, Stack size 0 bytes, tasks.o(i.vTaskStepTick)) <BR><BR>[Called By]<UL><LI><a href="#[1a8]">>></a> vPortSuppressTicksAndSleep </UL> <P><STRONG><a name="[1c3]"></a>vTaskSuspend</STRONG> (Thumb, 176 bytes, Stack size 16 bytes, tasks.o(i.vTaskSuspend)) <BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = vTaskSuspend ⇒ vTaskSwitchContext </UL> <BR>[Calls]<UL><LI><a href="#[199]">>></a> vListInsertEnd <LI><a href="#[198]">>></a> uxListRemove <LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical <LI><a href="#[60]">>></a> vTaskSwitchContext <LI><a href="#[1d1]">>></a> prvResetNextTaskUnblockTime </UL> <BR>[Called By]<UL><LI><a href="#[121]">>></a> task_communication_content </UL> <P><STRONG><a name="[cc]"></a>vTaskSuspendAll</STRONG> (Thumb, 12 bytes, Stack size 0 bytes, tasks.o(i.vTaskSuspendAll)) <BR><BR>[Called By]<UL><LI><a href="#[173]">>></a> xQueueSemaphoreTake <LI><a href="#[1b7]">>></a> xQueueReceive <LI><a href="#[178]">>></a> xQueueGenericSend <LI><a href="#[1a6]">>></a> vPortFree <LI><a href="#[180]">>></a> pvPortMalloc <LI><a href="#[1b8]">>></a> prvProcessTimerOrBlockTask <LI><a href="#[170]">>></a> vTaskDelay <LI><a href="#[5c]">>></a> prvIdleTask <LI><a href="#[cb]">>></a> FLASH_Write </UL> <P><STRONG><a name="[60]"></a>vTaskSwitchContext</STRONG> (Thumb, 176 bytes, Stack size 8 bytes, tasks.o(i.vTaskSwitchContext)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = vTaskSwitchContext </UL> <BR>[Calls]<UL><LI><a href="#[1d2]">>></a> getRunTimeCounterValue </UL> <BR>[Called By]<UL><LI><a href="#[1c3]">>></a> vTaskSuspend <LI><a href="#[a]">>></a> PendSV_Handler </UL> <P><STRONG><a name="[129]"></a>writeFlashPage</STRONG> (Thumb, 42 bytes, Stack size 16 bytes, ec800_ftp_ota.o(i.writeFlashPage)) <BR><BR>[Stack]<UL><LI>Max Depth = 104<LI>Call Chain = writeFlashPage ⇒ FLASH_Write ⇒ HAL_FLASH_Program ⇒ FLASH_WaitForLastOperation </UL> <BR>[Calls]<UL><LI><a href="#[cb]">>></a> FLASH_Write <LI><a href="#[c4]">>></a> FLASH_Erase </UL> <BR>[Called By]<UL><LI><a href="#[9c]">>></a> UpdateFirmware </UL> <P><STRONG><a name="[1d0]"></a>xPortStartScheduler</STRONG> (Thumb, 228 bytes, Stack size 16 bytes, port.o(i.xPortStartScheduler)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = xPortStartScheduler </UL> <BR>[Calls]<UL><LI><a href="#[1d3]">>></a> vPortSetupTimerInterrupt <LI><a href="#[1d4]">>></a> __asm___6_port_c_39a90d8d__prvStartFirstTask </UL> <BR>[Called By]<UL><LI><a href="#[171]">>></a> vTaskStartScheduler </UL> <P><STRONG><a name="[17d]"></a>xQueueCreateCountingSemaphore</STRONG> (Thumb, 92 bytes, Stack size 16 bytes, queue.o(i.xQueueCreateCountingSemaphore)) <BR><BR>[Stack]<UL><LI>Max Depth = 112<LI>Call Chain = xQueueCreateCountingSemaphore ⇒ xQueueGenericCreate ⇒ pvPortMalloc ⇒ xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[17a]">>></a> xQueueGenericCreate </UL> <BR>[Called By]<UL><LI><a href="#[10f]">>></a> osSemaphoreNew </UL> <P><STRONG><a name="[17c]"></a>xQueueCreateCountingSemaphoreStatic</STRONG> (Thumb, 100 bytes, Stack size 24 bytes, queue.o(i.xQueueCreateCountingSemaphoreStatic)) <BR><BR>[Stack]<UL><LI>Max Depth = 112<LI>Call Chain = xQueueCreateCountingSemaphoreStatic ⇒ xQueueGenericCreateStatic ⇒ prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[179]">>></a> xQueueGenericCreateStatic </UL> <BR>[Called By]<UL><LI><a href="#[10f]">>></a> osSemaphoreNew </UL> <P><STRONG><a name="[175]"></a>xQueueCreateMutex</STRONG> (Thumb, 34 bytes, Stack size 24 bytes, queue.o(i.xQueueCreateMutex)) <BR><BR>[Stack]<UL><LI>Max Depth = 136<LI>Call Chain = xQueueCreateMutex ⇒ prvInitialiseMutex ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[17a]">>></a> xQueueGenericCreate <LI><a href="#[1a9]">>></a> prvInitialiseMutex </UL> <BR>[Called By]<UL><LI><a href="#[10e]">>></a> osMutexNew </UL> <P><STRONG><a name="[174]"></a>xQueueCreateMutexStatic</STRONG> (Thumb, 42 bytes, Stack size 32 bytes, queue.o(i.xQueueCreateMutexStatic)) <BR><BR>[Stack]<UL><LI>Max Depth = 144<LI>Call Chain = xQueueCreateMutexStatic ⇒ prvInitialiseMutex ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[179]">>></a> xQueueGenericCreateStatic <LI><a href="#[1a9]">>></a> prvInitialiseMutex </UL> <BR>[Called By]<UL><LI><a href="#[10e]">>></a> osMutexNew </UL> <P><STRONG><a name="[17a]"></a>xQueueGenericCreate</STRONG> (Thumb, 94 bytes, Stack size 32 bytes, queue.o(i.xQueueGenericCreate)) <BR><BR>[Stack]<UL><LI>Max Depth = 96<LI>Call Chain = xQueueGenericCreate ⇒ pvPortMalloc ⇒ xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[1aa]">>></a> prvInitialiseNewQueue <LI><a href="#[180]">>></a> pvPortMalloc </UL> <BR>[Called By]<UL><LI><a href="#[10f]">>></a> osSemaphoreNew <LI><a href="#[175]">>></a> xQueueCreateMutex <LI><a href="#[17d]">>></a> xQueueCreateCountingSemaphore </UL> <P><STRONG><a name="[179]"></a>xQueueGenericCreateStatic</STRONG> (Thumb, 222 bytes, Stack size 32 bytes, queue.o(i.xQueueGenericCreateStatic)) <BR><BR>[Stack]<UL><LI>Max Depth = 88<LI>Call Chain = xQueueGenericCreateStatic ⇒ prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[1aa]">>></a> prvInitialiseNewQueue </UL> <BR>[Called By]<UL><LI><a href="#[10f]">>></a> osSemaphoreNew <LI><a href="#[174]">>></a> xQueueCreateMutexStatic <LI><a href="#[17c]">>></a> xQueueCreateCountingSemaphoreStatic <LI><a href="#[19f]">>></a> prvCheckForValidListAndQueue </UL> <P><STRONG><a name="[1ab]"></a>xQueueGenericReset</STRONG> (Thumb, 146 bytes, Stack size 16 bytes, queue.o(i.xQueueGenericReset)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[1be]">>></a> xTaskRemoveFromEventList <LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical <LI><a href="#[1a0]">>></a> vListInitialise </UL> <BR>[Called By]<UL><LI><a href="#[1aa]">>></a> prvInitialiseNewQueue </UL> <P><STRONG><a name="[178]"></a>xQueueGenericSend</STRONG> (Thumb, 420 bytes, Stack size 56 bytes, queue.o(i.xQueueGenericSend)) <BR><BR>[Stack]<UL><LI>Max Depth = 104<LI>Call Chain = xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[1be]">>></a> xTaskRemoveFromEventList <LI><a href="#[1d7]">>></a> xTaskCheckForTimeOut <LI><a href="#[1cc]">>></a> vTaskPlaceOnEventList <LI><a href="#[1d6]">>></a> vTaskInternalSetTimeOutState <LI><a href="#[1bd]">>></a> prvUnlockQueue <LI><a href="#[1b2]">>></a> prvIsQueueFull <LI><a href="#[1a4]">>></a> prvCopyDataToQueue <LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[1d5]">>></a> xTaskGetSchedulerState <LI><a href="#[cc]">>></a> vTaskSuspendAll <LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical </UL> <BR>[Called By]<UL><LI><a href="#[ad]">>></a> osMutexRelease <LI><a href="#[10f]">>></a> osSemaphoreNew <LI><a href="#[177]">>></a> xQueueGiveMutexRecursive <LI><a href="#[1a9]">>></a> prvInitialiseMutex <LI><a href="#[1b4]">>></a> xTimerGenericCommand </UL> <P><STRONG><a name="[1d8]"></a>xQueueGenericSendFromISR</STRONG> (Thumb, 248 bytes, Stack size 40 bytes, queue.o(i.xQueueGenericSendFromISR)) <BR><BR>[Stack]<UL><LI>Max Depth = 80<LI>Call Chain = xQueueGenericSendFromISR ⇒ prvCopyDataToQueue ⇒ xTaskPriorityDisinherit </UL> <BR>[Calls]<UL><LI><a href="#[1be]">>></a> xTaskRemoveFromEventList <LI><a href="#[1c8]">>></a> vPortValidateInterruptPriority <LI><a href="#[1a4]">>></a> prvCopyDataToQueue </UL> <BR>[Called By]<UL><LI><a href="#[1b4]">>></a> xTimerGenericCommand </UL> <P><STRONG><a name="[177]"></a>xQueueGiveMutexRecursive</STRONG> (Thumb, 72 bytes, Stack size 16 bytes, queue.o(i.xQueueGiveMutexRecursive)) <BR><BR>[Stack]<UL><LI>Max Depth = 120<LI>Call Chain = xQueueGiveMutexRecursive ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[1d9]">>></a> xTaskGetCurrentTaskHandle <LI><a href="#[178]">>></a> xQueueGenericSend </UL> <BR>[Called By]<UL><LI><a href="#[ad]">>></a> osMutexRelease </UL> <P><STRONG><a name="[1b7]"></a>xQueueReceive</STRONG> (Thumb, 356 bytes, Stack size 48 bytes, queue.o(i.xQueueReceive)) <BR><BR>[Stack]<UL><LI>Max Depth = 96<LI>Call Chain = xQueueReceive ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[1be]">>></a> xTaskRemoveFromEventList <LI><a href="#[1d7]">>></a> xTaskCheckForTimeOut <LI><a href="#[1cc]">>></a> vTaskPlaceOnEventList <LI><a href="#[1d6]">>></a> vTaskInternalSetTimeOutState <LI><a href="#[1bd]">>></a> prvUnlockQueue <LI><a href="#[1b1]">>></a> prvIsQueueEmpty <LI><a href="#[1a3]">>></a> prvCopyDataFromQueue <LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[1d5]">>></a> xTaskGetSchedulerState <LI><a href="#[cc]">>></a> vTaskSuspendAll <LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical </UL> <BR>[Called By]<UL><LI><a href="#[1b5]">>></a> prvProcessReceivedCommands </UL> <P><STRONG><a name="[173]"></a>xQueueSemaphoreTake</STRONG> (Thumb, 434 bytes, Stack size 40 bytes, queue.o(i.xQueueSemaphoreTake)) <BR><BR>[Stack]<UL><LI>Max Depth = 88<LI>Call Chain = xQueueSemaphoreTake ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[1be]">>></a> xTaskRemoveFromEventList <LI><a href="#[1db]">>></a> xTaskPriorityInherit <LI><a href="#[1d7]">>></a> xTaskCheckForTimeOut <LI><a href="#[1cd]">>></a> vTaskPriorityDisinheritAfterTimeout <LI><a href="#[1cc]">>></a> vTaskPlaceOnEventList <LI><a href="#[1d6]">>></a> vTaskInternalSetTimeOutState <LI><a href="#[1da]">>></a> pvTaskIncrementMutexHeldCount <LI><a href="#[1bd]">>></a> prvUnlockQueue <LI><a href="#[1b1]">>></a> prvIsQueueEmpty <LI><a href="#[1dc]">>></a> prvGetDisinheritPriorityAfterTimeout <LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[1d5]">>></a> xTaskGetSchedulerState <LI><a href="#[cc]">>></a> vTaskSuspendAll <LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical </UL> <BR>[Called By]<UL><LI><a href="#[ac]">>></a> osMutexAcquire <LI><a href="#[172]">>></a> xQueueTakeMutexRecursive </UL> <P><STRONG><a name="[172]"></a>xQueueTakeMutexRecursive</STRONG> (Thumb, 78 bytes, Stack size 24 bytes, queue.o(i.xQueueTakeMutexRecursive)) <BR><BR>[Stack]<UL><LI>Max Depth = 112<LI>Call Chain = xQueueTakeMutexRecursive ⇒ xQueueSemaphoreTake ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[1d9]">>></a> xTaskGetCurrentTaskHandle <LI><a href="#[173]">>></a> xQueueSemaphoreTake </UL> <BR>[Called By]<UL><LI><a href="#[ac]">>></a> osMutexAcquire </UL> <P><STRONG><a name="[1d7]"></a>xTaskCheckForTimeOut</STRONG> (Thumb, 132 bytes, Stack size 16 bytes, tasks.o(i.xTaskCheckForTimeOut)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = xTaskCheckForTimeOut </UL> <BR>[Calls]<UL><LI><a href="#[1d6]">>></a> vTaskInternalSetTimeOutState <LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical </UL> <BR>[Called By]<UL><LI><a href="#[173]">>></a> xQueueSemaphoreTake <LI><a href="#[1b7]">>></a> xQueueReceive <LI><a href="#[178]">>></a> xQueueGenericSend </UL> <P><STRONG><a name="[17f]"></a>xTaskCreate</STRONG> (Thumb, 100 bytes, Stack size 72 bytes, tasks.o(i.xTaskCreate)) <BR><BR>[Stack]<UL><LI>Max Depth = 136<LI>Call Chain = xTaskCreate ⇒ pvPortMalloc ⇒ xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[1a6]">>></a> vPortFree <LI><a href="#[180]">>></a> pvPortMalloc <LI><a href="#[1ac]">>></a> prvInitialiseNewTask <LI><a href="#[19b]">>></a> prvAddNewTaskToReadyList </UL> <BR>[Called By]<UL><LI><a href="#[111]">>></a> osThreadNew </UL> <P><STRONG><a name="[17e]"></a>xTaskCreateStatic</STRONG> (Thumb, 184 bytes, Stack size 56 bytes, tasks.o(i.xTaskCreateStatic)) <BR><BR>[Stack]<UL><LI>Max Depth = 96<LI>Call Chain = xTaskCreateStatic ⇒ prvInitialiseNewTask </UL> <BR>[Calls]<UL><LI><a href="#[1ac]">>></a> prvInitialiseNewTask <LI><a href="#[19b]">>></a> prvAddNewTaskToReadyList </UL> <BR>[Called By]<UL><LI><a href="#[111]">>></a> osThreadNew <LI><a href="#[1cf]">>></a> xTimerCreateTimerTask <LI><a href="#[171]">>></a> vTaskStartScheduler </UL> <P><STRONG><a name="[1d9]"></a>xTaskGetCurrentTaskHandle</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, tasks.o(i.xTaskGetCurrentTaskHandle)) <BR><BR>[Called By]<UL><LI><a href="#[172]">>></a> xQueueTakeMutexRecursive <LI><a href="#[177]">>></a> xQueueGiveMutexRecursive </UL> <P><STRONG><a name="[1d5]"></a>xTaskGetSchedulerState</STRONG> (Thumb, 24 bytes, Stack size 0 bytes, tasks.o(i.xTaskGetSchedulerState)) <BR><BR>[Called By]<UL><LI><a href="#[173]">>></a> xQueueSemaphoreTake <LI><a href="#[1b7]">>></a> xQueueReceive <LI><a href="#[178]">>></a> xQueueGenericSend <LI><a href="#[1b4]">>></a> xTimerGenericCommand </UL> <P><STRONG><a name="[1ba]"></a>xTaskGetTickCount</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, tasks.o(i.xTaskGetTickCount)) <BR><BR>[Called By]<UL><LI><a href="#[1b6]">>></a> prvSampleTimeNow </UL> <P><STRONG><a name="[11f]"></a>xTaskIncrementTick</STRONG> (Thumb, 280 bytes, Stack size 24 bytes, tasks.o(i.xTaskIncrementTick)) <BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[199]">>></a> vListInsertEnd <LI><a href="#[198]">>></a> uxListRemove <LI><a href="#[1d1]">>></a> prvResetNextTaskUnblockTime </UL> <BR>[Called By]<UL><LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[b]">>></a> SysTick_Handler </UL> <P><STRONG><a name="[1a5]"></a>xTaskPriorityDisinherit</STRONG> (Thumb, 152 bytes, Stack size 16 bytes, tasks.o(i.xTaskPriorityDisinherit)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = xTaskPriorityDisinherit </UL> <BR>[Calls]<UL><LI><a href="#[199]">>></a> vListInsertEnd <LI><a href="#[198]">>></a> uxListRemove </UL> <BR>[Called By]<UL><LI><a href="#[1a4]">>></a> prvCopyDataToQueue </UL> <P><STRONG><a name="[1db]"></a>xTaskPriorityInherit</STRONG> (Thumb, 150 bytes, Stack size 16 bytes, tasks.o(i.xTaskPriorityInherit)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = xTaskPriorityInherit </UL> <BR>[Calls]<UL><LI><a href="#[199]">>></a> vListInsertEnd <LI><a href="#[198]">>></a> uxListRemove </UL> <BR>[Called By]<UL><LI><a href="#[173]">>></a> xQueueSemaphoreTake </UL> <P><STRONG><a name="[1be]"></a>xTaskRemoveFromEventList</STRONG> (Thumb, 130 bytes, Stack size 16 bytes, tasks.o(i.xTaskRemoveFromEventList)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[199]">>></a> vListInsertEnd <LI><a href="#[198]">>></a> uxListRemove <LI><a href="#[1d1]">>></a> prvResetNextTaskUnblockTime </UL> <BR>[Called By]<UL><LI><a href="#[173]">>></a> xQueueSemaphoreTake <LI><a href="#[1b7]">>></a> xQueueReceive <LI><a href="#[1d8]">>></a> xQueueGenericSendFromISR <LI><a href="#[178]">>></a> xQueueGenericSend <LI><a href="#[1ab]">>></a> xQueueGenericReset <LI><a href="#[1bd]">>></a> prvUnlockQueue </UL> <P><STRONG><a name="[ce]"></a>xTaskResumeAll</STRONG> (Thumb, 222 bytes, Stack size 16 bytes, tasks.o(i.xTaskResumeAll)) <BR><BR>[Stack]<UL><LI>Max Depth = 40<LI>Call Chain = xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[199]">>></a> vListInsertEnd <LI><a href="#[198]">>></a> uxListRemove <LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical <LI><a href="#[11f]">>></a> xTaskIncrementTick <LI><a href="#[1d1]">>></a> prvResetNextTaskUnblockTime </UL> <BR>[Called By]<UL><LI><a href="#[173]">>></a> xQueueSemaphoreTake <LI><a href="#[1b7]">>></a> xQueueReceive <LI><a href="#[178]">>></a> xQueueGenericSend <LI><a href="#[1a6]">>></a> vPortFree <LI><a href="#[180]">>></a> pvPortMalloc <LI><a href="#[1b8]">>></a> prvProcessTimerOrBlockTask <LI><a href="#[170]">>></a> vTaskDelay <LI><a href="#[5c]">>></a> prvIdleTask <LI><a href="#[cb]">>></a> FLASH_Write </UL> <P><STRONG><a name="[182]"></a>xTimerCreate</STRONG> (Thumb, 54 bytes, Stack size 40 bytes, timers.o(i.xTimerCreate)) <BR><BR>[Stack]<UL><LI>Max Depth = 168<LI>Call Chain = xTimerCreate ⇒ prvInitialiseNewTimer ⇒ prvCheckForValidListAndQueue ⇒ xQueueGenericCreateStatic ⇒ prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[180]">>></a> pvPortMalloc <LI><a href="#[1af]">>></a> prvInitialiseNewTimer </UL> <BR>[Called By]<UL><LI><a href="#[110]">>></a> osTimerNew </UL> <P><STRONG><a name="[181]"></a>xTimerCreateStatic</STRONG> (Thumb, 112 bytes, Stack size 40 bytes, timers.o(i.xTimerCreateStatic)) <BR><BR>[Stack]<UL><LI>Max Depth = 168<LI>Call Chain = xTimerCreateStatic ⇒ prvInitialiseNewTimer ⇒ prvCheckForValidListAndQueue ⇒ xQueueGenericCreateStatic ⇒ prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[1af]">>></a> prvInitialiseNewTimer </UL> <BR>[Called By]<UL><LI><a href="#[110]">>></a> osTimerNew </UL> <P><STRONG><a name="[1cf]"></a>xTimerCreateTimerTask</STRONG> (Thumb, 100 bytes, Stack size 32 bytes, timers.o(i.xTimerCreateTimerTask)) <BR><BR>[Stack]<UL><LI>Max Depth = 128<LI>Call Chain = xTimerCreateTimerTask ⇒ prvCheckForValidListAndQueue ⇒ xQueueGenericCreateStatic ⇒ prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[1dd]">>></a> vApplicationGetTimerTaskMemory <LI><a href="#[19f]">>></a> prvCheckForValidListAndQueue <LI><a href="#[17e]">>></a> xTaskCreateStatic </UL> <BR>[Called By]<UL><LI><a href="#[171]">>></a> vTaskStartScheduler </UL> <P><STRONG><a name="[1b4]"></a>xTimerGenericCommand</STRONG> (Thumb, 128 bytes, Stack size 48 bytes, timers.o(i.xTimerGenericCommand)) <BR><BR>[Stack]<UL><LI>Max Depth = 152<LI>Call Chain = xTimerGenericCommand ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[1d8]">>></a> xQueueGenericSendFromISR <LI><a href="#[178]">>></a> xQueueGenericSend <LI><a href="#[1d5]">>></a> xTaskGetSchedulerState </UL> <BR>[Called By]<UL><LI><a href="#[1bb]">>></a> prvSwitchTimerLists <LI><a href="#[1b5]">>></a> prvProcessReceivedCommands <LI><a href="#[1b3]">>></a> prvProcessExpiredTimer </UL> <P> <H3> Local Symbols </H3> <P><STRONG><a name="[154]"></a>cJSON_New_Item</STRONG> (Thumb, 26 bytes, Stack size 8 bytes, cjson.o(i.cJSON_New_Item)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = cJSON_New_Item </UL> <BR>[Calls]<UL><LI><a href="#[94]">>></a> __aeabi_memclr4 </UL> <BR>[Called By]<UL><LI><a href="#[156]">>></a> cJSON_ParseWithOpts <LI><a href="#[be]">>></a> cJSON_CreateString <LI><a href="#[bd]">>></a> cJSON_CreateObject <LI><a href="#[c0]">>></a> cJSON_CreateNumber <LI><a href="#[c2]">>></a> cJSON_CreateArray <LI><a href="#[18a]">>></a> parse_object <LI><a href="#[188]">>></a> parse_array </UL> <P><STRONG><a name="[155]"></a>cJSON_strcasecmp</STRONG> (Thumb, 76 bytes, Stack size 16 bytes, cjson.o(i.cJSON_strcasecmp)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = cJSON_strcasecmp </UL> <BR>[Calls]<UL><LI><a href="#[15a]">>></a> tolower </UL> <BR>[Called By]<UL><LI><a href="#[a5]">>></a> cJSON_GetObjectItem </UL> <P><STRONG><a name="[153]"></a>cJSON_strdup</STRONG> (Thumb, 40 bytes, Stack size 16 bytes, cjson.o(i.cJSON_strdup)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = cJSON_strdup </UL> <BR>[Calls]<UL><LI><a href="#[8b]">>></a> strlen <LI><a href="#[15b]">>></a> __aeabi_memcpy </UL> <BR>[Called By]<UL><LI><a href="#[be]">>></a> cJSON_CreateString <LI><a href="#[bf]">>></a> cJSON_AddItemToObject <LI><a href="#[159]">>></a> print_value </UL> <P><STRONG><a name="[162]"></a>ensure</STRONG> (Thumb, 104 bytes, Stack size 24 bytes, cjson.o(i.ensure)) <BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = ensure </UL> <BR>[Calls]<UL><LI><a href="#[163]">>></a> pow2gt <LI><a href="#[15b]">>></a> __aeabi_memcpy </UL> <BR>[Called By]<UL><LI><a href="#[159]">>></a> print_value <LI><a href="#[195]">>></a> print_string_ptr <LI><a href="#[194]">>></a> print_object <LI><a href="#[191]">>></a> print_number <LI><a href="#[18e]">>></a> print_array </UL> <P><STRONG><a name="[188]"></a>parse_array</STRONG> (Thumb, 166 bytes, Stack size 32 bytes, cjson.o(i.parse_array)) <BR><BR>[Stack]<UL><LI>Max Depth = 40 + In Cycle <LI>Call Chain = parse_array ⇒ parse_value (Cycle) </UL> <BR>[Calls]<UL><LI><a href="#[157]">>></a> skip <LI><a href="#[158]">>></a> parse_value <LI><a href="#[154]">>></a> cJSON_New_Item </UL> <BR>[Called By]<UL><LI><a href="#[158]">>></a> parse_value </UL> <P><STRONG><a name="[18c]"></a>parse_hex4</STRONG> (Thumb, 276 bytes, Stack size 0 bytes, cjson.o(i.parse_hex4)) <BR><BR>[Called By]<UL><LI><a href="#[18b]">>></a> parse_string </UL> <P><STRONG><a name="[189]"></a>parse_number</STRONG> (Thumb, 432 bytes, Stack size 80 bytes, cjson.o(i.parse_number)) <BR><BR>[Stack]<UL><LI>Max Depth = 320<LI>Call Chain = parse_number ⇒ pow ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[7d]">>></a> __aeabi_i2d <LI><a href="#[77]">>></a> __aeabi_dsub <LI><a href="#[79]">>></a> __aeabi_dmul <LI><a href="#[72]">>></a> __aeabi_dadd <LI><a href="#[7f]">>></a> __aeabi_d2iz <LI><a href="#[166]">>></a> pow </UL> <BR>[Called By]<UL><LI><a href="#[158]">>></a> parse_value </UL> <P><STRONG><a name="[18a]"></a>parse_object</STRONG> (Thumb, 270 bytes, Stack size 32 bytes, cjson.o(i.parse_object)) <BR><BR>[Stack]<UL><LI>Max Depth = 72 + In Cycle <LI>Call Chain = parse_object ⇒ parse_value (Cycle) </UL> <BR>[Calls]<UL><LI><a href="#[157]">>></a> skip <LI><a href="#[158]">>></a> parse_value <LI><a href="#[18b]">>></a> parse_string <LI><a href="#[154]">>></a> cJSON_New_Item </UL> <BR>[Called By]<UL><LI><a href="#[158]">>></a> parse_value </UL> <P><STRONG><a name="[18b]"></a>parse_string</STRONG> (Thumb, 448 bytes, Stack size 40 bytes, cjson.o(i.parse_string)) <BR><BR>[Stack]<UL><LI>Max Depth = 40<LI>Call Chain = parse_string </UL> <BR>[Calls]<UL><LI><a href="#[18c]">>></a> parse_hex4 </UL> <BR>[Called By]<UL><LI><a href="#[158]">>></a> parse_value <LI><a href="#[18a]">>></a> parse_object </UL> <P><STRONG><a name="[158]"></a>parse_value</STRONG> (Thumb, 158 bytes, Stack size 16 bytes, cjson.o(i.parse_value)) <BR><BR>[Stack]<UL><LI>Max Depth = 336<LI>Call Chain = parse_value ⇒ parse_number ⇒ pow ⇒ __kernel_poly ⇒ __aeabi_dmul ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[18b]">>></a> parse_string <LI><a href="#[18a]">>></a> parse_object <LI><a href="#[189]">>></a> parse_number <LI><a href="#[188]">>></a> parse_array <LI><a href="#[18d]">>></a> strncmp </UL> <BR>[Called By]<UL><LI><a href="#[156]">>></a> cJSON_ParseWithOpts <LI><a href="#[18a]">>></a> parse_object <LI><a href="#[188]">>></a> parse_array </UL> <P><STRONG><a name="[163]"></a>pow2gt</STRONG> (Thumb, 28 bytes, Stack size 0 bytes, cjson.o(i.pow2gt)) <BR><BR>[Called By]<UL><LI><a href="#[162]">>></a> ensure </UL> <P><STRONG><a name="[18e]"></a>print_array</STRONG> (Thumb, 578 bytes, Stack size 72 bytes, cjson.o(i.print_array)) <BR><BR>[Stack]<UL><LI>Max Depth = 96 + In Cycle <LI>Call Chain = print_array ⇒ print_value (Cycle) </UL> <BR>[Calls]<UL><LI><a href="#[190]">>></a> update <LI><a href="#[159]">>></a> print_value <LI><a href="#[162]">>></a> ensure <LI><a href="#[18f]">>></a> strcpy <LI><a href="#[8b]">>></a> strlen <LI><a href="#[94]">>></a> __aeabi_memclr4 <LI><a href="#[15b]">>></a> __aeabi_memcpy </UL> <BR>[Called By]<UL><LI><a href="#[159]">>></a> print_value </UL> <P><STRONG><a name="[191]"></a>print_number</STRONG> (Thumb, 342 bytes, Stack size 40 bytes, cjson.o(i.print_number)) <BR><BR>[Stack]<UL><LI>Max Depth = 152<LI>Call Chain = print_number ⇒ floor ⇒ __aeabi_dadd ⇒ _double_epilogue ⇒ _double_round </UL> <BR>[Calls]<UL><LI><a href="#[7d]">>></a> __aeabi_i2d <LI><a href="#[77]">>></a> __aeabi_dsub <LI><a href="#[137]">>></a> __aeabi_cdrcmple <LI><a href="#[193]">>></a> __aeabi_cdcmple <LI><a href="#[192]">>></a> __aeabi_cdcmpeq <LI><a href="#[162]">>></a> ensure <LI><a href="#[99]">>></a> __2sprintf <LI><a href="#[164]">>></a> floor </UL> <BR>[Called By]<UL><LI><a href="#[159]">>></a> print_value </UL> <P><STRONG><a name="[194]"></a>print_object</STRONG> (Thumb, 1038 bytes, Stack size 88 bytes, cjson.o(i.print_object)) <BR><BR>[Stack]<UL><LI>Max Depth = 152 + In Cycle <LI>Call Chain = print_object ⇒ print_value (Cycle) </UL> <BR>[Calls]<UL><LI><a href="#[190]">>></a> update <LI><a href="#[159]">>></a> print_value <LI><a href="#[195]">>></a> print_string_ptr <LI><a href="#[162]">>></a> ensure <LI><a href="#[18f]">>></a> strcpy <LI><a href="#[8b]">>></a> strlen <LI><a href="#[94]">>></a> __aeabi_memclr4 <LI><a href="#[15b]">>></a> __aeabi_memcpy </UL> <BR>[Called By]<UL><LI><a href="#[159]">>></a> print_value </UL> <P><STRONG><a name="[196]"></a>print_string</STRONG> (Thumb, 16 bytes, Stack size 16 bytes, cjson.o(i.print_string)) <BR><BR>[Stack]<UL><LI>Max Depth = 80<LI>Call Chain = print_string ⇒ print_string_ptr ⇒ ensure </UL> <BR>[Calls]<UL><LI><a href="#[195]">>></a> print_string_ptr </UL> <BR>[Called By]<UL><LI><a href="#[159]">>></a> print_value </UL> <P><STRONG><a name="[195]"></a>print_string_ptr</STRONG> (Thumb, 442 bytes, Stack size 40 bytes, cjson.o(i.print_string_ptr)) <BR><BR>[Stack]<UL><LI>Max Depth = 64<LI>Call Chain = print_string_ptr ⇒ ensure </UL> <BR>[Calls]<UL><LI><a href="#[162]">>></a> ensure <LI><a href="#[99]">>></a> __2sprintf <LI><a href="#[18f]">>></a> strcpy <LI><a href="#[af]">>></a> strchr </UL> <BR>[Called By]<UL><LI><a href="#[196]">>></a> print_string <LI><a href="#[194]">>></a> print_object </UL> <P><STRONG><a name="[159]"></a>print_value</STRONG> (Thumb, 278 bytes, Stack size 24 bytes, cjson.o(i.print_value)) <BR><BR>[Stack]<UL><LI>Max Depth = 176<LI>Call Chain = print_value ⇒ print_object ⇒ print_value (Cycle) </UL> <BR>[Calls]<UL><LI><a href="#[196]">>></a> print_string <LI><a href="#[194]">>></a> print_object <LI><a href="#[191]">>></a> print_number <LI><a href="#[18e]">>></a> print_array <LI><a href="#[162]">>></a> ensure <LI><a href="#[153]">>></a> cJSON_strdup <LI><a href="#[18f]">>></a> strcpy </UL> <BR>[Called By]<UL><LI><a href="#[c1]">>></a> cJSON_Print <LI><a href="#[194]">>></a> print_object <LI><a href="#[18e]">>></a> print_array </UL> <P><STRONG><a name="[157]"></a>skip</STRONG> (Thumb, 18 bytes, Stack size 0 bytes, cjson.o(i.skip)) <BR><BR>[Called By]<UL><LI><a href="#[156]">>></a> cJSON_ParseWithOpts <LI><a href="#[18a]">>></a> parse_object <LI><a href="#[188]">>></a> parse_array </UL> <P><STRONG><a name="[152]"></a>suffix_object</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, cjson.o(i.suffix_object)) <BR><BR>[Called By]<UL><LI><a href="#[c3]">>></a> cJSON_AddItemToArray </UL> <P><STRONG><a name="[190]"></a>update</STRONG> (Thumb, 32 bytes, Stack size 16 bytes, cjson.o(i.update)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = update </UL> <BR>[Calls]<UL><LI><a href="#[8b]">>></a> strlen </UL> <BR>[Called By]<UL><LI><a href="#[194]">>></a> print_object <LI><a href="#[18e]">>></a> print_array </UL> <P><STRONG><a name="[98]"></a>EC800_extractSignal</STRONG> (Thumb, 70 bytes, Stack size 16 bytes, ec800.o(i.EC800_extractSignal)) <BR><BR>[Stack]<UL><LI>Max Depth = 104<LI>Call Chain = EC800_extractSignal ⇒ atoi ⇒ strtol ⇒ _strtoul </UL> <BR>[Calls]<UL><LI><a href="#[a1]">>></a> strtok <LI><a href="#[62]">>></a> __aeabi_memclr <LI><a href="#[69]">>></a> atoi </UL> <BR>[Called By]<UL><LI><a href="#[93]">>></a> EC800M_link </UL> <P><STRONG><a name="[e6]"></a>RCC_Delay</STRONG> (Thumb, 36 bytes, Stack size 8 bytes, stm32f1xx_hal_rcc.o(i.RCC_Delay)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = RCC_Delay </UL> <BR>[Called By]<UL><LI><a href="#[e5]">>></a> HAL_RCC_OscConfig </UL> <P><STRONG><a name="[d0]"></a>DMA_SetConfig</STRONG> (Thumb, 44 bytes, Stack size 12 bytes, stm32f1xx_hal_dma.o(i.DMA_SetConfig)) <BR><BR>[Stack]<UL><LI>Max Depth = 12<LI>Call Chain = DMA_SetConfig </UL> <BR>[Called By]<UL><LI><a href="#[cf]">>></a> HAL_DMA_Start_IT </UL> <P><STRONG><a name="[df]"></a>__NVIC_GetPriorityGrouping</STRONG> (Thumb, 10 bytes, Stack size 0 bytes, stm32f1xx_hal_cortex.o(i.__NVIC_GetPriorityGrouping)) <BR><BR>[Called By]<UL><LI><a href="#[de]">>></a> HAL_NVIC_SetPriority </UL> <P><STRONG><a name="[e0]"></a>__NVIC_SetPriority</STRONG> (Thumb, 32 bytes, Stack size 8 bytes, stm32f1xx_hal_cortex.o(i.__NVIC_SetPriority)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = __NVIC_SetPriority </UL> <BR>[Called By]<UL><LI><a href="#[de]">>></a> HAL_NVIC_SetPriority </UL> <P><STRONG><a name="[d4]"></a>FLASH_Program_HalfWord</STRONG> (Thumb, 22 bytes, Stack size 0 bytes, stm32f1xx_hal_flash.o(i.FLASH_Program_HalfWord)) <BR><BR>[Called By]<UL><LI><a href="#[cd]">>></a> HAL_FLASH_Program </UL> <P><STRONG><a name="[ca]"></a>FLASH_SetErrorCode</STRONG> (Thumb, 124 bytes, Stack size 0 bytes, stm32f1xx_hal_flash.o(i.FLASH_SetErrorCode)) <BR><BR>[Called By]<UL><LI><a href="#[c8]">>></a> FLASH_WaitForLastOperation </UL> <P><STRONG><a name="[d2]"></a>FLASH_MassErase</STRONG> (Thumb, 30 bytes, Stack size 0 bytes, stm32f1xx_hal_flash_ex.o(i.FLASH_MassErase)) <BR><BR>[Called By]<UL><LI><a href="#[c6]">>></a> HAL_FLASHEx_Erase </UL> <P><STRONG><a name="[ec]"></a>TIM_ITRx_SetConfig</STRONG> (Thumb, 18 bytes, Stack size 0 bytes, stm32f1xx_hal_tim.o(i.TIM_ITRx_SetConfig)) <BR><BR>[Called By]<UL><LI><a href="#[e9]">>></a> HAL_TIM_ConfigClockSource </UL> <P><STRONG><a name="[eb]"></a>TIM_TI1_ConfigInputStage</STRONG> (Thumb, 38 bytes, Stack size 12 bytes, stm32f1xx_hal_tim.o(i.TIM_TI1_ConfigInputStage)) <BR><BR>[Stack]<UL><LI>Max Depth = 12<LI>Call Chain = TIM_TI1_ConfigInputStage </UL> <BR>[Called By]<UL><LI><a href="#[e9]">>></a> HAL_TIM_ConfigClockSource </UL> <P><STRONG><a name="[ed]"></a>TIM_TI2_ConfigInputStage</STRONG> (Thumb, 40 bytes, Stack size 12 bytes, stm32f1xx_hal_tim.o(i.TIM_TI2_ConfigInputStage)) <BR><BR>[Stack]<UL><LI>Max Depth = 12<LI>Call Chain = TIM_TI2_ConfigInputStage </UL> <BR>[Called By]<UL><LI><a href="#[e9]">>></a> HAL_TIM_ConfigClockSource </UL> <P><STRONG><a name="[4f]"></a>UART_DMAAbortOnError</STRONG> (Thumb, 20 bytes, Stack size 16 bytes, stm32f1xx_hal_uart.o(i.UART_DMAAbortOnError)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = UART_DMAAbortOnError </UL> <BR>[Calls]<UL><LI><a href="#[fe]">>></a> HAL_UART_ErrorCallback </UL> <BR>[Address Reference Count : 1]<UL><LI> stm32f1xx_hal_uart.o(i.HAL_UART_IRQHandler) </UL> <P><STRONG><a name="[56]"></a>UART_DMAError</STRONG> (Thumb, 80 bytes, Stack size 16 bytes, stm32f1xx_hal_uart.o(i.UART_DMAError)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = UART_DMAError </UL> <BR>[Calls]<UL><LI><a href="#[fe]">>></a> HAL_UART_ErrorCallback <LI><a href="#[f9]">>></a> UART_EndTxTransfer <LI><a href="#[fa]">>></a> UART_EndRxTransfer </UL> <BR>[Address Reference Count : 1]<UL><LI> stm32f1xx_hal_uart.o(i.UART_Start_Receive_DMA) </UL> <P><STRONG><a name="[54]"></a>UART_DMAReceiveCplt</STRONG> (Thumb, 180 bytes, Stack size 16 bytes, stm32f1xx_hal_uart.o(i.UART_DMAReceiveCplt)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = UART_DMAReceiveCplt </UL> <BR>[Calls]<UL><LI><a href="#[124]">>></a> HAL_UART_RxCpltCallback <LI><a href="#[ff]">>></a> HAL_UARTEx_RxEventCallback </UL> <BR>[Address Reference Count : 1]<UL><LI> stm32f1xx_hal_uart.o(i.UART_Start_Receive_DMA) </UL> <P><STRONG><a name="[55]"></a>UART_DMARxHalfCplt</STRONG> (Thumb, 36 bytes, Stack size 16 bytes, stm32f1xx_hal_uart.o(i.UART_DMARxHalfCplt)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = UART_DMARxHalfCplt </UL> <BR>[Calls]<UL><LI><a href="#[125]">>></a> HAL_UART_RxHalfCpltCallback <LI><a href="#[ff]">>></a> HAL_UARTEx_RxEventCallback </UL> <BR>[Address Reference Count : 1]<UL><LI> stm32f1xx_hal_uart.o(i.UART_Start_Receive_DMA) </UL> <P><STRONG><a name="[fa]"></a>UART_EndRxTransfer</STRONG> (Thumb, 108 bytes, Stack size 0 bytes, stm32f1xx_hal_uart.o(i.UART_EndRxTransfer)) <BR><BR>[Called By]<UL><LI><a href="#[fb]">>></a> HAL_UART_IRQHandler <LI><a href="#[bc]">>></a> HAL_UART_DMAStop <LI><a href="#[56]">>></a> UART_DMAError </UL> <P><STRONG><a name="[101]"></a>UART_EndTransmit_IT</STRONG> (Thumb, 32 bytes, Stack size 8 bytes, stm32f1xx_hal_uart.o(i.UART_EndTransmit_IT)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = UART_EndTransmit_IT </UL> <BR>[Calls]<UL><LI><a href="#[126]">>></a> HAL_UART_TxCpltCallback </UL> <BR>[Called By]<UL><LI><a href="#[fb]">>></a> HAL_UART_IRQHandler </UL> <P><STRONG><a name="[f9]"></a>UART_EndTxTransfer</STRONG> (Thumb, 38 bytes, Stack size 0 bytes, stm32f1xx_hal_uart.o(i.UART_EndTxTransfer)) <BR><BR>[Called By]<UL><LI><a href="#[bc]">>></a> HAL_UART_DMAStop <LI><a href="#[56]">>></a> UART_DMAError </UL> <P><STRONG><a name="[fc]"></a>UART_Receive_IT</STRONG> (Thumb, 252 bytes, Stack size 24 bytes, stm32f1xx_hal_uart.o(i.UART_Receive_IT)) <BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = UART_Receive_IT </UL> <BR>[Calls]<UL><LI><a href="#[124]">>></a> HAL_UART_RxCpltCallback <LI><a href="#[ff]">>></a> HAL_UARTEx_RxEventCallback </UL> <BR>[Called By]<UL><LI><a href="#[fb]">>></a> HAL_UART_IRQHandler </UL> <P><STRONG><a name="[104]"></a>UART_SetConfig</STRONG> (Thumb, 248 bytes, Stack size 16 bytes, stm32f1xx_hal_uart.o(i.UART_SetConfig)) <BR><BR>[Stack]<UL><LI>Max Depth = 20<LI>Call Chain = UART_SetConfig ⇒ HAL_RCC_GetPCLK1Freq </UL> <BR>[Calls]<UL><LI><a href="#[e3]">>></a> HAL_RCC_GetPCLK1Freq <LI><a href="#[da]">>></a> HAL_RCC_GetPCLK2Freq </UL> <BR>[Called By]<UL><LI><a href="#[102]">>></a> HAL_UART_Init </UL> <P><STRONG><a name="[100]"></a>UART_Transmit_IT</STRONG> (Thumb, 96 bytes, Stack size 0 bytes, stm32f1xx_hal_uart.o(i.UART_Transmit_IT)) <BR><BR>[Called By]<UL><LI><a href="#[fb]">>></a> HAL_UART_IRQHandler </UL> <P><STRONG><a name="[109]"></a>UART_WaitOnFlagUntilTimeout</STRONG> (Thumb, 146 bytes, Stack size 24 bytes, stm32f1xx_hal_uart.o(i.UART_WaitOnFlagUntilTimeout)) <BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = UART_WaitOnFlagUntilTimeout </UL> <BR>[Calls]<UL><LI><a href="#[c9]">>></a> HAL_GetTick </UL> <BR>[Called By]<UL><LI><a href="#[92]">>></a> HAL_UART_Transmit </UL> <P><STRONG><a name="[1a3]"></a>prvCopyDataFromQueue</STRONG> (Thumb, 42 bytes, Stack size 16 bytes, queue.o(i.prvCopyDataFromQueue)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = prvCopyDataFromQueue </UL> <BR>[Calls]<UL><LI><a href="#[15b]">>></a> __aeabi_memcpy </UL> <BR>[Called By]<UL><LI><a href="#[1b7]">>></a> xQueueReceive </UL> <P><STRONG><a name="[1a4]"></a>prvCopyDataToQueue</STRONG> (Thumb, 124 bytes, Stack size 24 bytes, queue.o(i.prvCopyDataToQueue)) <BR><BR>[Stack]<UL><LI>Max Depth = 40<LI>Call Chain = prvCopyDataToQueue ⇒ xTaskPriorityDisinherit </UL> <BR>[Calls]<UL><LI><a href="#[1a5]">>></a> xTaskPriorityDisinherit <LI><a href="#[15b]">>></a> __aeabi_memcpy </UL> <BR>[Called By]<UL><LI><a href="#[1d8]">>></a> xQueueGenericSendFromISR <LI><a href="#[178]">>></a> xQueueGenericSend </UL> <P><STRONG><a name="[1dc]"></a>prvGetDisinheritPriorityAfterTimeout</STRONG> (Thumb, 20 bytes, Stack size 0 bytes, queue.o(i.prvGetDisinheritPriorityAfterTimeout)) <BR><BR>[Called By]<UL><LI><a href="#[173]">>></a> xQueueSemaphoreTake </UL> <P><STRONG><a name="[1a9]"></a>prvInitialiseMutex</STRONG> (Thumb, 28 bytes, Stack size 8 bytes, queue.o(i.prvInitialiseMutex)) <BR><BR>[Stack]<UL><LI>Max Depth = 112<LI>Call Chain = prvInitialiseMutex ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[178]">>></a> xQueueGenericSend </UL> <BR>[Called By]<UL><LI><a href="#[174]">>></a> xQueueCreateMutexStatic <LI><a href="#[175]">>></a> xQueueCreateMutex </UL> <P><STRONG><a name="[1aa]"></a>prvInitialiseNewQueue</STRONG> (Thumb, 42 bytes, Stack size 24 bytes, queue.o(i.prvInitialiseNewQueue)) <BR><BR>[Stack]<UL><LI>Max Depth = 56<LI>Call Chain = prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[1ab]">>></a> xQueueGenericReset </UL> <BR>[Called By]<UL><LI><a href="#[179]">>></a> xQueueGenericCreateStatic <LI><a href="#[17a]">>></a> xQueueGenericCreate </UL> <P><STRONG><a name="[1b1]"></a>prvIsQueueEmpty</STRONG> (Thumb, 26 bytes, Stack size 16 bytes, queue.o(i.prvIsQueueEmpty)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = prvIsQueueEmpty </UL> <BR>[Calls]<UL><LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical </UL> <BR>[Called By]<UL><LI><a href="#[173]">>></a> xQueueSemaphoreTake <LI><a href="#[1b7]">>></a> xQueueReceive </UL> <P><STRONG><a name="[1b2]"></a>prvIsQueueFull</STRONG> (Thumb, 30 bytes, Stack size 16 bytes, queue.o(i.prvIsQueueFull)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = prvIsQueueFull </UL> <BR>[Calls]<UL><LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical </UL> <BR>[Called By]<UL><LI><a href="#[178]">>></a> xQueueGenericSend </UL> <P><STRONG><a name="[1bd]"></a>prvUnlockQueue</STRONG> (Thumb, 126 bytes, Stack size 16 bytes, queue.o(i.prvUnlockQueue)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = prvUnlockQueue ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[1be]">>></a> xTaskRemoveFromEventList <LI><a href="#[1bf]">>></a> vTaskMissedYield <LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical </UL> <BR>[Called By]<UL><LI><a href="#[173]">>></a> xQueueSemaphoreTake <LI><a href="#[1b7]">>></a> xQueueReceive <LI><a href="#[178]">>></a> xQueueGenericSend <LI><a href="#[1b9]">>></a> vQueueWaitForMessageRestricted </UL> <P><STRONG><a name="[197]"></a>prvAddCurrentTaskToDelayedList</STRONG> (Thumb, 100 bytes, Stack size 24 bytes, tasks.o(i.prvAddCurrentTaskToDelayedList)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[199]">>></a> vListInsertEnd <LI><a href="#[19a]">>></a> vListInsert <LI><a href="#[198]">>></a> uxListRemove </UL> <BR>[Called By]<UL><LI><a href="#[1cb]">>></a> vTaskPlaceOnEventListRestricted <LI><a href="#[1cc]">>></a> vTaskPlaceOnEventList <LI><a href="#[170]">>></a> vTaskDelay </UL> <P><STRONG><a name="[19b]"></a>prvAddNewTaskToReadyList</STRONG> (Thumb, 154 bytes, Stack size 8 bytes, tasks.o(i.prvAddNewTaskToReadyList)) <BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = prvAddNewTaskToReadyList ⇒ prvInitialiseTaskLists </UL> <BR>[Calls]<UL><LI><a href="#[199]">>></a> vListInsertEnd <LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical <LI><a href="#[19d]">>></a> prvInitialiseTaskLists </UL> <BR>[Called By]<UL><LI><a href="#[17e]">>></a> xTaskCreateStatic <LI><a href="#[17f]">>></a> xTaskCreate </UL> <P><STRONG><a name="[1a1]"></a>prvCheckTasksWaitingTermination</STRONG> (Thumb, 60 bytes, Stack size 8 bytes, tasks.o(i.prvCheckTasksWaitingTermination)) <BR><BR>[Stack]<UL><LI>Max Depth = 72<LI>Call Chain = prvCheckTasksWaitingTermination ⇒ prvDeleteTCB ⇒ vPortFree ⇒ xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[198]">>></a> uxListRemove <LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical <LI><a href="#[1a2]">>></a> prvDeleteTCB </UL> <BR>[Called By]<UL><LI><a href="#[5c]">>></a> prvIdleTask </UL> <P><STRONG><a name="[1a2]"></a>prvDeleteTCB</STRONG> (Thumb, 80 bytes, Stack size 8 bytes, tasks.o(i.prvDeleteTCB)) <BR><BR>[Stack]<UL><LI>Max Depth = 64<LI>Call Chain = prvDeleteTCB ⇒ vPortFree ⇒ xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[1a6]">>></a> vPortFree </UL> <BR>[Called By]<UL><LI><a href="#[1a1]">>></a> prvCheckTasksWaitingTermination </UL> <P><STRONG><a name="[1a7]"></a>prvGetExpectedIdleTime</STRONG> (Thumb, 52 bytes, Stack size 0 bytes, tasks.o(i.prvGetExpectedIdleTime)) <BR><BR>[Called By]<UL><LI><a href="#[5c]">>></a> prvIdleTask </UL> <P><STRONG><a name="[5c]"></a>prvIdleTask</STRONG> (Thumb, 108 bytes, Stack size 0 bytes, tasks.o(i.prvIdleTask)) <BR><BR>[Stack]<UL><LI>Max Depth = 72<LI>Call Chain = prvIdleTask ⇒ prvCheckTasksWaitingTermination ⇒ prvDeleteTCB ⇒ vPortFree ⇒ xTaskResumeAll ⇒ xTaskIncrementTick </UL> <BR>[Calls]<UL><LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[cc]">>></a> vTaskSuspendAll <LI><a href="#[1a8]">>></a> vPortSuppressTicksAndSleep <LI><a href="#[1a7]">>></a> prvGetExpectedIdleTime <LI><a href="#[1a1]">>></a> prvCheckTasksWaitingTermination </UL> <BR>[Address Reference Count : 1]<UL><LI> tasks.o(i.vTaskStartScheduler) </UL> <P><STRONG><a name="[1ac]"></a>prvInitialiseNewTask</STRONG> (Thumb, 182 bytes, Stack size 40 bytes, tasks.o(i.prvInitialiseNewTask)) <BR><BR>[Stack]<UL><LI>Max Depth = 40<LI>Call Chain = prvInitialiseNewTask </UL> <BR>[Calls]<UL><LI><a href="#[1ad]">>></a> vListInitialiseItem <LI><a href="#[1ae]">>></a> pxPortInitialiseStack <LI><a href="#[63]">>></a> __aeabi_memset </UL> <BR>[Called By]<UL><LI><a href="#[17e]">>></a> xTaskCreateStatic <LI><a href="#[17f]">>></a> xTaskCreate </UL> <P><STRONG><a name="[19d]"></a>prvInitialiseTaskLists</STRONG> (Thumb, 70 bytes, Stack size 8 bytes, tasks.o(i.prvInitialiseTaskLists)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = prvInitialiseTaskLists </UL> <BR>[Calls]<UL><LI><a href="#[1a0]">>></a> vListInitialise </UL> <BR>[Called By]<UL><LI><a href="#[19b]">>></a> prvAddNewTaskToReadyList </UL> <P><STRONG><a name="[1d1]"></a>prvResetNextTaskUnblockTime</STRONG> (Thumb, 42 bytes, Stack size 0 bytes, tasks.o(i.prvResetNextTaskUnblockTime)) <BR><BR>[Called By]<UL><LI><a href="#[1c3]">>></a> vTaskSuspend <LI><a href="#[1be]">>></a> xTaskRemoveFromEventList <LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[11f]">>></a> xTaskIncrementTick </UL> <P><STRONG><a name="[19f]"></a>prvCheckForValidListAndQueue</STRONG> (Thumb, 78 bytes, Stack size 8 bytes, timers.o(i.prvCheckForValidListAndQueue)) <BR><BR>[Stack]<UL><LI>Max Depth = 96<LI>Call Chain = prvCheckForValidListAndQueue ⇒ xQueueGenericCreateStatic ⇒ prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[179]">>></a> xQueueGenericCreateStatic <LI><a href="#[176]">>></a> vQueueAddToRegistry <LI><a href="#[19e]">>></a> vPortExitCritical <LI><a href="#[19c]">>></a> vPortEnterCritical <LI><a href="#[1a0]">>></a> vListInitialise </UL> <BR>[Called By]<UL><LI><a href="#[1af]">>></a> prvInitialiseNewTimer <LI><a href="#[1cf]">>></a> xTimerCreateTimerTask </UL> <P><STRONG><a name="[1bc]"></a>prvGetNextExpireTime</STRONG> (Thumb, 36 bytes, Stack size 0 bytes, timers.o(i.prvGetNextExpireTime)) <BR><BR>[Called By]<UL><LI><a href="#[5d]">>></a> prvTimerTask </UL> <P><STRONG><a name="[1af]"></a>prvInitialiseNewTimer</STRONG> (Thumb, 78 bytes, Stack size 32 bytes, timers.o(i.prvInitialiseNewTimer)) <BR><BR>[Stack]<UL><LI>Max Depth = 128<LI>Call Chain = prvInitialiseNewTimer ⇒ prvCheckForValidListAndQueue ⇒ xQueueGenericCreateStatic ⇒ prvInitialiseNewQueue ⇒ xQueueGenericReset ⇒ xTaskRemoveFromEventList </UL> <BR>[Calls]<UL><LI><a href="#[1ad]">>></a> vListInitialiseItem <LI><a href="#[19f]">>></a> prvCheckForValidListAndQueue </UL> <BR>[Called By]<UL><LI><a href="#[181]">>></a> xTimerCreateStatic <LI><a href="#[182]">>></a> xTimerCreate </UL> <P><STRONG><a name="[1b0]"></a>prvInsertTimerInActiveList</STRONG> (Thumb, 80 bytes, Stack size 24 bytes, timers.o(i.prvInsertTimerInActiveList)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = prvInsertTimerInActiveList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[19a]">>></a> vListInsert </UL> <BR>[Called By]<UL><LI><a href="#[1b5]">>></a> prvProcessReceivedCommands <LI><a href="#[1b3]">>></a> prvProcessExpiredTimer </UL> <P><STRONG><a name="[1b3]"></a>prvProcessExpiredTimer</STRONG> (Thumb, 94 bytes, Stack size 24 bytes, timers.o(i.prvProcessExpiredTimer)) <BR><BR>[Stack]<UL><LI>Max Depth = 176<LI>Call Chain = prvProcessExpiredTimer ⇒ xTimerGenericCommand ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[198]">>></a> uxListRemove <LI><a href="#[1b4]">>></a> xTimerGenericCommand <LI><a href="#[1b0]">>></a> prvInsertTimerInActiveList </UL> <BR>[Called By]<UL><LI><a href="#[1b8]">>></a> prvProcessTimerOrBlockTask </UL> <P><STRONG><a name="[1b5]"></a>prvProcessReceivedCommands</STRONG> (Thumb, 290 bytes, Stack size 48 bytes, timers.o(i.prvProcessReceivedCommands)) <BR><BR>[Stack]<UL><LI>Max Depth = 248<LI>Call Chain = prvProcessReceivedCommands ⇒ prvSampleTimeNow ⇒ prvSwitchTimerLists ⇒ xTimerGenericCommand ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[1b7]">>></a> xQueueReceive <LI><a href="#[198]">>></a> uxListRemove <LI><a href="#[1a6]">>></a> vPortFree <LI><a href="#[1b4]">>></a> xTimerGenericCommand <LI><a href="#[1b6]">>></a> prvSampleTimeNow <LI><a href="#[1b0]">>></a> prvInsertTimerInActiveList </UL> <BR>[Called By]<UL><LI><a href="#[5d]">>></a> prvTimerTask </UL> <P><STRONG><a name="[1b8]"></a>prvProcessTimerOrBlockTask</STRONG> (Thumb, 102 bytes, Stack size 24 bytes, timers.o(i.prvProcessTimerOrBlockTask)) <BR><BR>[Stack]<UL><LI>Max Depth = 224<LI>Call Chain = prvProcessTimerOrBlockTask ⇒ prvSampleTimeNow ⇒ prvSwitchTimerLists ⇒ xTimerGenericCommand ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[1b9]">>></a> vQueueWaitForMessageRestricted <LI><a href="#[ce]">>></a> xTaskResumeAll <LI><a href="#[cc]">>></a> vTaskSuspendAll <LI><a href="#[1b6]">>></a> prvSampleTimeNow <LI><a href="#[1b3]">>></a> prvProcessExpiredTimer </UL> <BR>[Called By]<UL><LI><a href="#[5d]">>></a> prvTimerTask </UL> <P><STRONG><a name="[1b6]"></a>prvSampleTimeNow</STRONG> (Thumb, 40 bytes, Stack size 16 bytes, timers.o(i.prvSampleTimeNow)) <BR><BR>[Stack]<UL><LI>Max Depth = 200<LI>Call Chain = prvSampleTimeNow ⇒ prvSwitchTimerLists ⇒ xTimerGenericCommand ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[1bb]">>></a> prvSwitchTimerLists <LI><a href="#[1ba]">>></a> xTaskGetTickCount </UL> <BR>[Called By]<UL><LI><a href="#[1b8]">>></a> prvProcessTimerOrBlockTask <LI><a href="#[1b5]">>></a> prvProcessReceivedCommands </UL> <P><STRONG><a name="[1bb]"></a>prvSwitchTimerLists</STRONG> (Thumb, 150 bytes, Stack size 32 bytes, timers.o(i.prvSwitchTimerLists)) <BR><BR>[Stack]<UL><LI>Max Depth = 184<LI>Call Chain = prvSwitchTimerLists ⇒ xTimerGenericCommand ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[19a]">>></a> vListInsert <LI><a href="#[198]">>></a> uxListRemove <LI><a href="#[1b4]">>></a> xTimerGenericCommand </UL> <BR>[Called By]<UL><LI><a href="#[1b6]">>></a> prvSampleTimeNow </UL> <P><STRONG><a name="[5d]"></a>prvTimerTask</STRONG> (Thumb, 26 bytes, Stack size 8 bytes, timers.o(i.prvTimerTask)) <BR><BR>[Stack]<UL><LI>Max Depth = 256<LI>Call Chain = prvTimerTask ⇒ prvProcessReceivedCommands ⇒ prvSampleTimeNow ⇒ prvSwitchTimerLists ⇒ xTimerGenericCommand ⇒ xQueueGenericSend ⇒ vTaskPlaceOnEventList ⇒ prvAddCurrentTaskToDelayedList ⇒ vListInsert </UL> <BR>[Calls]<UL><LI><a href="#[1b8]">>></a> prvProcessTimerOrBlockTask <LI><a href="#[1b5]">>></a> prvProcessReceivedCommands <LI><a href="#[1bc]">>></a> prvGetNextExpireTime </UL> <BR>[Address Reference Count : 1]<UL><LI> timers.o(i.xTimerCreateTimerTask) </UL> <P><STRONG><a name="[5a]"></a>TimerCallback</STRONG> (Thumb, 22 bytes, Stack size 16 bytes, cmsis_os2.o(i.TimerCallback)) <BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = TimerCallback ⇒ pvTimerGetTimerID </UL> <BR>[Calls]<UL><LI><a href="#[123]">>></a> pvTimerGetTimerID </UL> <BR>[Address Reference Count : 1]<UL><LI> cmsis_os2.o(i.osTimerNew) </UL> <P><STRONG><a name="[16f]"></a>__get_BASEPRI</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, cmsis_os2.o(i.__get_BASEPRI)) <BR><BR>[Called By]<UL><LI><a href="#[ad]">>></a> osMutexRelease <LI><a href="#[ac]">>></a> osMutexAcquire <LI><a href="#[8a]">>></a> osDelay <LI><a href="#[110]">>></a> osTimerNew <LI><a href="#[111]">>></a> osThreadNew <LI><a href="#[10f]">>></a> osSemaphoreNew <LI><a href="#[10e]">>></a> osMutexNew <LI><a href="#[16c]">>></a> osKernelStart <LI><a href="#[16b]">>></a> osKernelInitialize </UL> <P><STRONG><a name="[16d]"></a>__get_IPSR</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, cmsis_os2.o(i.__get_IPSR)) <BR><BR>[Called By]<UL><LI><a href="#[ad]">>></a> osMutexRelease <LI><a href="#[ac]">>></a> osMutexAcquire <LI><a href="#[8a]">>></a> osDelay <LI><a href="#[110]">>></a> osTimerNew <LI><a href="#[111]">>></a> osThreadNew <LI><a href="#[10f]">>></a> osSemaphoreNew <LI><a href="#[10e]">>></a> osMutexNew <LI><a href="#[16c]">>></a> osKernelStart <LI><a href="#[16b]">>></a> osKernelInitialize </UL> <P><STRONG><a name="[16e]"></a>__get_PRIMASK</STRONG> (Thumb, 6 bytes, Stack size 0 bytes, cmsis_os2.o(i.__get_PRIMASK)) <BR><BR>[Called By]<UL><LI><a href="#[ad]">>></a> osMutexRelease <LI><a href="#[ac]">>></a> osMutexAcquire <LI><a href="#[8a]">>></a> osDelay <LI><a href="#[110]">>></a> osTimerNew <LI><a href="#[111]">>></a> osThreadNew <LI><a href="#[10f]">>></a> osSemaphoreNew <LI><a href="#[10e]">>></a> osMutexNew <LI><a href="#[16c]">>></a> osKernelStart <LI><a href="#[16b]">>></a> osKernelInitialize </UL> <P><STRONG><a name="[1c0]"></a>prvHeapInit</STRONG> (Thumb, 98 bytes, Stack size 12 bytes, heap_4.o(i.prvHeapInit)) <BR><BR>[Stack]<UL><LI>Max Depth = 12<LI>Call Chain = prvHeapInit </UL> <BR>[Called By]<UL><LI><a href="#[180]">>></a> pvPortMalloc </UL> <P><STRONG><a name="[1c1]"></a>prvInsertBlockIntoFreeList</STRONG> (Thumb, 96 bytes, Stack size 8 bytes, heap_4.o(i.prvInsertBlockIntoFreeList)) <BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = prvInsertBlockIntoFreeList </UL> <BR>[Called By]<UL><LI><a href="#[1a6]">>></a> vPortFree <LI><a href="#[180]">>></a> pvPortMalloc </UL> <P><STRONG><a name="[5b]"></a>prvTaskExitError</STRONG> (Thumb, 60 bytes, Stack size 0 bytes, port.o(i.prvTaskExitError)) <BR>[Address Reference Count : 1]<UL><LI> port.o(i.pxPortInitialiseStack) </UL> <P><STRONG><a name="[148]"></a>atk_ms6050_iic_delay</STRONG> (Thumb, 10 bytes, Stack size 4 bytes, atk_ms6050_iic.o(i.atk_ms6050_iic_delay)) <BR><BR>[Stack]<UL><LI>Max Depth = 12<LI>Call Chain = atk_ms6050_iic_delay ⇒ DWT_Delay_us </UL> <BR>[Calls]<UL><LI><a href="#[149]">>></a> DWT_Delay_us </UL> <BR>[Called By]<UL><LI><a href="#[14a]">>></a> atk_ms6050_iic_nack <LI><a href="#[147]">>></a> atk_ms6050_iic_ack <LI><a href="#[150]">>></a> atk_ms6050_iic_wait_ack <LI><a href="#[14f]">>></a> atk_ms6050_iic_stop <LI><a href="#[14e]">>></a> atk_ms6050_iic_start <LI><a href="#[14d]">>></a> atk_ms6050_iic_send_byte <LI><a href="#[14b]">>></a> atk_ms6050_iic_read_byte </UL> <P><STRONG><a name="[161]"></a>decode_gesture</STRONG> (Thumb, 94 bytes, Stack size 24 bytes, inv_mpu_dmp_motion_driver.o(i.decode_gesture)) <BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = decode_gesture </UL> <BR>[Called By]<UL><LI><a href="#[142]">>></a> dmp_read_fifo </UL> <P><STRONG><a name="[136]"></a>_fp_digits</STRONG> (Thumb, 366 bytes, Stack size 64 bytes, printfa.o(i._fp_digits), UNUSED) <BR><BR>[Calls]<UL><LI><a href="#[79]">>></a> __aeabi_dmul <LI><a href="#[72]">>></a> __aeabi_dadd <LI><a href="#[137]">>></a> __aeabi_cdrcmple <LI><a href="#[7a]">>></a> __aeabi_ddiv <LI><a href="#[82]">>></a> __aeabi_uldivmod <LI><a href="#[86]">>></a> __aeabi_d2ulz </UL> <BR>[Called By]<UL><LI><a href="#[12b]">>></a> _printf_core </UL> <P><STRONG><a name="[12b]"></a>_printf_core</STRONG> (Thumb, 1744 bytes, Stack size 136 bytes, printfa.o(i._printf_core), UNUSED) <BR><BR>[Calls]<UL><LI><a href="#[138]">>></a> _printf_pre_padding <LI><a href="#[139]">>></a> _printf_post_padding <LI><a href="#[136]">>></a> _fp_digits <LI><a href="#[82]">>></a> __aeabi_uldivmod <LI><a href="#[13a]">>></a> __aeabi_uidivmod </UL> <BR>[Called By]<UL><LI><a href="#[12d]">>></a> __0sprintf <LI><a href="#[12c]">>></a> __0snprintf <LI><a href="#[12a]">>></a> __0printf </UL> <P><STRONG><a name="[139]"></a>_printf_post_padding</STRONG> (Thumb, 36 bytes, Stack size 24 bytes, printfa.o(i._printf_post_padding), UNUSED) <BR><BR>[Called By]<UL><LI><a href="#[12b]">>></a> _printf_core </UL> <P><STRONG><a name="[138]"></a>_printf_pre_padding</STRONG> (Thumb, 46 bytes, Stack size 24 bytes, printfa.o(i._printf_pre_padding), UNUSED) <BR><BR>[Called By]<UL><LI><a href="#[12b]">>></a> _printf_core </UL> <P><STRONG><a name="[58]"></a>_snputc</STRONG> (Thumb, 22 bytes, Stack size 0 bytes, printfa.o(i._snputc)) <BR>[Address Reference Count : 1]<UL><LI> printfa.o(i.__0snprintf) </UL> <P><STRONG><a name="[59]"></a>_sputc</STRONG> (Thumb, 10 bytes, Stack size 0 bytes, printfa.o(i._sputc)) <BR><BR>[Called By]<UL><LI><a href="#[12d]">>></a> __0sprintf </UL> <BR>[Address Reference Count : 1]<UL><LI> printfa.o(i.__0sprintf) </UL> <P><STRONG><a name="[4d]"></a>_scanf_char_input</STRONG> (Thumb, 12 bytes, Stack size 0 bytes, scanf_char.o(.text)) <BR>[Address Reference Count : 1]<UL><LI> scanf_char.o(.text) </UL><P> <H3> Undefined Global Symbols </H3><HR></body></html>