📄 uart_debug.htm
字号:
<!doctype html public "-//w3c//dtd html 4.0 transitional//en">
<html><head>
<title>Static Call Graph - [.\Obj\uart_debug.axf]</title></head>
<body><HR>
<H1>Static Call Graph for image .\Obj\uart_debug.axf</H1><HR>
<BR><P>#<CALLGRAPH># ARM Linker, RVCT3.0 [Build 951]: Last Updated: Mon Jan 22 21:44:34 2007
<BR><P>
<H3>Maximum Stack Usage = 64 bytes + Unknown(Functions without stacksize,Cycles,Untraceable Function Pointers)</H3><H3>
Call chain for Maximum Stack Depth:</H3>
__main -> __rt_entry -> __rt_lib_init -> _fp_init<P>
<H3>
Functions with no stack information
</H3><UL>
<LI><a href="#[bb1580]">Reset_Handler</a>
<LI><a href="#[1027b28]">__scatterload</a>
<LI><a href="#[1027a58]">__scatterload_rt2</a>
<LI><a href="#[1027aa8]">__scatterload_null</a>
<LI><a href="#[1027574]">__scatterload_copy</a>
<LI><a href="#[1027124]">__scatterload_zeroinit</a>
<LI><a href="#[bb1400]">__user_initial_stackheap</a>
<LI><a href="#[baff9c]">SoftwareInterrupt</a>
<LI><a href="#[baff24]">IntEnable</a>
<LI><a href="#[bafeac]">IntDisable</a>
<LI><a href="#[ff24d0]">__fplib_config_pureend_doubles</a>
<LI><a href="#[bb1b4c]">Undef_Handler</a>
<LI><a href="#[bb1ad4]">SWI_Handler</a>
<LI><a href="#[bb1a58]">PAbt_Handler</a>
<LI><a href="#[bb19dc]">DAbt_Handler</a>
<LI><a href="#[bb1964]">IRQ_Handler</a>
<LI><a href="#[bb18ec]">FIQ_Handler</a>
<LI><a href="#[bb0184]">IRQDisable</a>
<LI><a href="#[bb010c]">IRQEnable</a>
<LI><a href="#[bb0094]">FIQDisable</a>
<LI><a href="#[bb001c]">FIQEnable</a>
<LI><a href="#[bf8220]">__arm_div4</a>
<LI><a href="#[bf81a8]">__arm_div8</a>
<LI><a href="#[bf812c]">__arm_div_large</a>
</UL>
<P>
<H3>
Mutually Recursive functions
</H3><UL>
<LI><a href="#[bb1b4c]">Undef_Handler</a> -> <a href="#[bb1b4c]">Undef_Handler</a><BR>
<LI><a href="#[bb1ad4]">SWI_Handler</a> -> <a href="#[bb1ad4]">SWI_Handler</a><BR>
<LI><a href="#[bb1a58]">PAbt_Handler</a> -> <a href="#[bb1a58]">PAbt_Handler</a><BR>
<LI><a href="#[bb19dc]">DAbt_Handler</a> -> <a href="#[bb19dc]">DAbt_Handler</a><BR>
<LI><a href="#[bb1964]">IRQ_Handler</a> -> <a href="#[bb1964]">IRQ_Handler</a><BR>
<LI><a href="#[bb18ec]">FIQ_Handler</a> -> <a href="#[bb18ec]">FIQ_Handler</a><BR>
</UL>
<BR>
<P><STRONG><a name="[bb1580]"></a>Reset_Handler</STRONG> (ARM, 0 bytes, Stack size unknown bytes, startup.o(RESET))
<BR><BR>[Stack]<UL><LI>Max Depth = 8 + Unknown Stack Size
<LI>Call Chain = Reset_Handler -> TargetResetInit</UL>
<BR>[Calls]<UL><LI><a href="#[b25680]">>></a> TargetResetInit
</UL>
<BR>[Address Reference Count : 1]<UL><LI> startup.o(RESET)
</UL>
<P><STRONG><a name="[fffec4]"></a>__main</STRONG> (ARM, 8 bytes, Stack size 0 bytes, __main.o(!!!main))
<BR><BR>[Stack]<UL><LI>Max Depth = 64 + Unknown Stack Size
<LI>Call Chain = __main -> __rt_entry -> __rt_lib_init -> _fp_init</UL>
<BR>[Calls]<UL><LI><a href="#[fff51c]">>></a> __rt_entry
<LI><a href="#[1027b28]">>></a> __scatterload
</UL>
<P><STRONG><a name="[1027b28]"></a>__scatterload</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter))
<BR><BR>[Called By]<UL><LI><a href="#[fffec4]"><<</a> __main
</UL>
<P><STRONG><a name="[1027a58]"></a>__scatterload_rt2</STRONG> (ARM, 48 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[fff51c]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[1027aa8]"></a>__scatterload_null</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<P><STRONG><a name="[1027574]"></a>__scatterload_copy</STRONG> (ARM, 40 bytes, Stack size unknown bytes, __scatter_copy.o(!!handler_copy), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[1027574]">>></a> __scatterload_copy
</UL>
<BR>[Called By]<UL><LI><a href="#[1027574]"><<</a> __scatterload_copy
</UL>
<P><STRONG><a name="[1027124]"></a>__scatterload_zeroinit</STRONG> (ARM, 44 bytes, Stack size unknown bytes, __scatter_zi.o(!!handler_zi), UNUSED)
<P><STRONG><a name="[ff89e4]"></a>__ARM_argv_veneer</STRONG> (ARM, 16 bytes, Stack size 0 bytes, lib_init.o(.emb_text))
<BR><BR>[Called By]<UL><LI><a href="#[ff8918]"><<</a> __rt_lib_init (via Veneer)
</UL>
<P><STRONG><a name="[b27818]"></a>init_VIC</STRONG> (ARM, 88 bytes, Stack size 0 bytes, irq.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b25680]"><<</a> TargetResetInit
</UL>
<P><STRONG><a name="[b277a0]"></a>install_irq</STRONG> (ARM, 92 bytes, Stack size 8 bytes, irq.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = install_irq</UL>
<BR>[Called By]<UL><LI><a href="#[b225e4]"><<</a> UARTInit
</UL>
<P><STRONG><a name="[b257f4]"></a>TargetInit</STRONG> (ARM, 4 bytes, Stack size 0 bytes, target.o(.text), UNUSED)
<P><STRONG><a name="[b25778]"></a>GPIOResetInit</STRONG> (ARM, 120 bytes, Stack size 0 bytes, target.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b25680]"><<</a> TargetResetInit
</UL>
<P><STRONG><a name="[b256fc]"></a>ConfigurePLL</STRONG> (ARM, 308 bytes, Stack size 0 bytes, target.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b25680]"><<</a> TargetResetInit
</UL>
<P><STRONG><a name="[b25680]"></a>TargetResetInit</STRONG> (ARM, 92 bytes, Stack size 8 bytes, target.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = TargetResetInit</UL>
<BR>[Calls]<UL><LI><a href="#[b256fc]">>></a> ConfigurePLL
<LI><a href="#[b25778]">>></a> GPIOResetInit
<LI><a href="#[b27818]">>></a> init_VIC
</UL>
<BR>[Called By]<UL><LI><a href="#[bb1580]"><<</a> Reset_Handler
</UL>
<P><STRONG><a name="[b2265c]"></a>UART0Handler</STRONG> (ARM, 396 bytes, Stack size 24 bytes, uart.o(.text), UNUSED)
<P><STRONG><a name="[b225e4]"></a>UARTInit</STRONG> (ARM, 140 bytes, Stack size 16 bytes, uart.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 24 + Unknown Stack Size
<LI>Call Chain = UARTInit -> install_irq</UL>
<BR>[Calls]<UL><LI><a href="#[b277a0]">>></a> install_irq
<LI><a href="#[bf7e4c]">>></a> __aeabi_uidivmod
</UL>
<BR>[Called By]<UL><LI><a href="#[bb3364]"><<</a> main
</UL>
<P><STRONG><a name="[b2256c]"></a>UARTSend</STRONG> (ARM, 68 bytes, Stack size 0 bytes, uart.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[bb3364]"><<</a> main
</UL>
<P><STRONG><a name="[bb3364]"></a>main</STRONG> (ARM, 88 bytes, Stack size 8 bytes, uarttest.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 32 + Unknown Stack Size
<LI>Call Chain = main -> UARTInit -> install_irq</UL>
<BR>[Calls]<UL><LI><a href="#[b2256c]">>></a> UARTSend
<LI><a href="#[b225e4]">>></a> UARTInit
</UL>
<BR>[Address Reference Count : 1]<UL><LI> kernel.o(.text)
</UL>
<P><STRONG><a name="[bb1400]"></a>__user_initial_stackheap</STRONG> (ARM, 0 bytes, Stack size unknown bytes, startup.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[ffeb7c]"><<</a> __user_setup_stackheap
</UL>
<P><STRONG><a name="[bf7f94]"></a>__aeabi_idiv</STRONG> (ARM, 0 bytes, Stack size 0 bytes, aeabi_sdiv.o(.text), UNUSED)
<P><STRONG><a name="[bf7f18]"></a>__aeabi_idivmod</STRONG> (ARM, 364 bytes, Stack size 0 bytes, aeabi_sdiv.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[ffe6f8]">>></a> __aeabi_idiv0
</UL>
<P><STRONG><a name="[bf51c8]"></a>__use_two_region_memory</STRONG> (ARM, 4 bytes, Stack size 0 bytes, stkheap2.o(.text), UNUSED)
<P><STRONG><a name="[100057c]"></a>__rt_stackheap_init</STRONG> (ARM, 60 bytes, Stack size 24 bytes, stkheap2.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 32 + Unknown Stack Size
<LI>Call Chain = __rt_stackheap_init -> __user_setup_stackheap</UL>
<BR>[Calls]<UL><LI><a href="#[ffd820]">>></a> __rt_stackheap_storage
<LI><a href="#[ffeb7c]">>></a> __user_setup_stackheap
</UL>
<BR>[Called By]<UL><LI><a href="#[fff51c]"><<</a> __rt_entry
</UL>
<P><STRONG><a name="[10004f4]"></a>__rt_heap_extend</STRONG> (ARM, 24 bytes, Stack size 8 bytes, stkheap2.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[bf529c]">>></a> __user_heap_extend (Weak Reference)
</UL>
<P><STRONG><a name="[fff51c]"></a>__rt_entry</STRONG> (ARM, 76 bytes, Stack size 16 bytes, kernel.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 64 + Unknown Stack Size
<LI>Call Chain = __rt_entry -> __rt_lib_init -> _fp_init</UL>
<BR>[Calls]<UL><LI><a href="#[ff6c8c]">>></a> _platform_post_lib_init
<LI><a href="#[ff70e0]">>></a> _platform_post_stackheap_init
<LI><a href="#[ff8918]">>></a> __rt_lib_init (via Veneer)
<LI><a href="#[ffbaa4]">>></a> exit (via BX)
<LI><a href="#[100057c]">>></a> __rt_stackheap_init
</UL>
<BR>[Called By]<UL><LI><a href="#[fffec4]"><<</a> __main
<LI><a href="#[1027a58]"><<</a> __scatterload_rt2
</UL>
<P><STRONG><a name="[fff3d4]"></a>__rt_exit</STRONG> (ARM, 20 bytes, Stack size 8 bytes, kernel.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = __rt_exit -> __rt_lib_shutdown</UL>
<BR>[Calls]<UL><LI><a href="#[ff88c8]">>></a> __rt_lib_shutdown (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[ffbaa4]"><<</a> exit (via Veneer)
</UL>
<P><STRONG><a name="[fff35c]"></a>__rt_abort</STRONG> (ARM, 8 bytes, Stack size 0 bytes, kernel.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[ffcaec]">>></a> _sys_exit
</UL>
<P><STRONG><a name="[ffeb7c]"></a>__user_setup_stackheap</STRONG> (ARM, 96 bytes, Stack size 8 bytes, sys_stackheap_outer.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 8 + Unknown Stack Size
<LI>Call Chain = __user_setup_stackheap</UL>
<BR>[Calls]<UL><LI><a href="#[bb1400]">>></a> __user_initial_stackheap
<LI><a href="#[ffc610]">>></a> __user_perproc_libspace
</UL>
<BR>[Called By]<UL><LI><a href="#[100057c]"><<</a> __rt_stackheap_init
</UL>
<P><STRONG><a name="[ffe6f8]"></a>__aeabi_idiv0</STRONG> (ARM, 4 bytes, Stack size 0 bytes, aeabi_idiv0.o(.text), UNUSED)
<BR><BR>[Called By]<UL><LI><a href="#[bf7f18]"><<</a> __aeabi_idivmod
</UL>
<P><STRONG><a name="[ffd820]"></a>__rt_stackheap_storage</STRONG> (ARM, 12 bytes, Stack size 0 bytes, rt_stackheap_storage_intlibspace.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[100057c]"><<</a> __rt_stackheap_init
</UL>
<P><STRONG><a name="[ffcaec]"></a>_sys_exit</STRONG> (ARM, 20 bytes, Stack size 0 bytes, sys_exit.o(.text), UNUSED)
<BR><BR>[Called By]<UL><LI><a href="#[fff35c]"><<</a> __rt_abort
</UL>
<P><STRONG><a name="[ffc4e8]"></a>__user_libspace</STRONG> (ARM, 8 bytes, Stack size 0 bytes, libspace.o(.text), UNUSED)
<P><STRONG><a name="[ffc610]"></a>__user_perproc_libspace</STRONG> (ARM, 0 bytes, Stack size 0 bytes, libspace.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[ffeb7c]"><<</a> __user_setup_stackheap
</UL>
<P><STRONG><a name="[ffc588]"></a>__user_perthread_libspace</STRONG> (ARM, 0 bytes, Stack size 0 bytes, libspace.o(.text), UNUSED)
<P><STRONG><a name="[ffbaa4]"></a>exit</STRONG> (Thumb, 24 bytes, Stack size 8 bytes, exit.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = exit -> __rt_exit -> __rt_lib_shutdown</UL>
<BR>[Calls]<UL><LI><a href="#[ffb954]">>></a> _call_atexit_fns (Weak Reference)
<LI><a href="#[ffb9d4]">>></a> __ARM_stackcheck (Weak Reference)
<LI><a href="#[fff3d4]">>></a> __rt_exit (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[fff51c]"><<</a> __rt_entry
</UL>
<P><STRONG><a name="[ff8918]"></a>__rt_lib_init</STRONG> (Thumb, 188 bytes, Stack size 40 bytes, lib_init.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 48<LI>Call Chain = __rt_lib_init -> _fp_init</UL>
<BR>[Calls]<UL><LI><a href="#[ff25dc]">>></a> _fp_init (via Veneer)
<LI><a href="#[ff55c4]">>></a> __rt_locale (via Veneer)
<LI><a href="#[ff7e98]">>></a> _signal_init (Weak Reference)
<LI><a href="#[ff7f14]">>></a> _rand_init (Weak Reference)
<LI><a href="#[ff7f8c]">>></a> _initio (Weak Reference)
<LI><a href="#[ff8000]">>></a> _init_user_alloc (Weak Reference)
<LI><a href="#[ff8080]">>></a> _init_alloc (Weak Reference)
<LI><a href="#[ff80f8]">>></a> _getenv_init (Weak Reference)
<LI><a href="#[ff8174]">>></a> _get_lc_time (Weak Reference)
<LI><a href="#[ff81f0]">>></a> _get_lc_numeric (Weak Reference)
<LI><a href="#[ff826c]">>></a> _get_lc_monetary (Weak Reference)
<LI><a href="#[ff82ec]">>></a> _get_lc_ctype (Weak Reference)
<LI><a href="#[ff8368]">>></a> _get_lc_collate (Weak Reference)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -