📄 uart_release.htm
字号:
<!doctype html public "-//w3c//dtd html 4.0 transitional//en">
<html><head>
<title>Static Call Graph - [.\Obj\uart_release.axf]</title></head>
<body><HR>
<H1>Static Call Graph for image .\Obj\uart_release.axf</H1><HR>
<BR><P>#<CALLGRAPH># ARM Linker, RVCT3.1 [Build 919]: Last Updated: Wed Apr 01 09:05:35 2009
<BR><P>
<H3>Maximum Stack Usage = 64 bytes + Unknown(Functions without stacksize, 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="#[c7fbc8]">__user_initial_stackheap</a>
<LI><a href="#[c7f5c0]">SoftwareInterrupt</a>
<LI><a href="#[c7f578]">IntEnable</a>
<LI><a href="#[c7f530]">IntDisable</a>
<LI><a href="#[c7f728]">IRQDisable</a>
<LI><a href="#[c7f6e0]">IRQEnable</a>
<LI><a href="#[c7f698]">FIQDisable</a>
<LI><a href="#[c7f650]">FIQEnable</a>
</UL>
</UL>
<P>
<H3>
Function Pointers
</H3><UL>
<LI><a href="#[c79458]">__ARM_get_argv</a>
<LI><a href="#[c804a0]">main</a>
<LI><a href="#[c7a1c0]">__I_use_semihosting</a>
<LI><a href="#[c7f728]">IRQDisable</a>
<LI><a href="#[c7f6e0]">IRQEnable</a>
<LI><a href="#[c7f698]">FIQDisable</a>
<LI><a href="#[c7f650]">FIQEnable</a>
</UL>
<P>
<H3>
Global Symbols
</H3>
<P><STRONG><a name="[c7ce08]"></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="#[c76cc0]">>></a> __scatterload
<LI><a href="#[c7cb48]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[c76cc0]"></a>__scatterload</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter))
<BR><BR>[Called By]<UL><LI><a href="#[c7ce08]">>></a> __main
</UL>
<P><STRONG><a name="[c76c78]"></a>__scatterload_rt2</STRONG> (ARM, 52 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c7cb48]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[c76c30]"></a>__scatterload_null</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<P><STRONG><a name="[c769f0]"></a>__scatterload_zeroinit</STRONG> (ARM, 44 bytes, Stack size unknown bytes, __scatter_zi.o(!!handler_zi), UNUSED)
<P><STRONG><a name="[c7b110]"></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="#[c7b080]">>></a> __rt_lib_init (via Veneer)
</UL>
<P><STRONG><a name="[c83040]"></a>init_VIC</STRONG> (ARM, 76 bytes, Stack size 8 bytes, irq.o(.text), UNUSED)
<P><STRONG><a name="[c82ff8]"></a>install_irq</STRONG> (ARM, 76 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="#[c811b0]">>></a> UARTInit
</UL>
<P><STRONG><a name="[c81240]"></a>UART0Handler</STRONG> (ARM, 52 bytes, Stack size 8 bytes, uart.o(.text), UNUSED)
<P><STRONG><a name="[c811f8]"></a>UART1Handler</STRONG> (ARM, 52 bytes, Stack size 8 bytes, uart.o(.text), UNUSED)
<P><STRONG><a name="[c811b0]"></a>UARTInit</STRONG> (ARM, 268 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="#[c7dd40]">>></a> __aeabi_uidivmod
<LI><a href="#[c82ff8]">>></a> install_irq
</UL>
<BR>[Called By]<UL><LI><a href="#[c804a0]">>></a> main
</UL>
<P><STRONG><a name="[c81168]"></a>UARTSend</STRONG> (ARM, 128 bytes, Stack size 4 bytes, uart.o(.text), UNUSED)
<P><STRONG><a name="[c81120]"></a>UARTSendByte</STRONG> (ARM, 32 bytes, Stack size 0 bytes, uart.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c804a0]">>></a> main
</UL>
<P><STRONG><a name="[c810d8]"></a>UARTn_RcvByte</STRONG> (ARM, 28 bytes, Stack size 0 bytes, uart.o(.text), UNUSED)
<P><STRONG><a name="[c804a0]"></a>main</STRONG> (ARM, 440 bytes, Stack size 40 bytes, uarttest.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 64 + Unknown Stack Size
<LI>Call Chain = main ⇒ UARTInit ⇒ install_irq
</UL>
<BR>[Calls]<UL><LI><a href="#[c7e240]">>></a> __aeabi_memcpy4
<LI><a href="#[c81120]">>></a> UARTSendByte
<LI><a href="#[c811b0]">>></a> UARTInit
</UL>
<BR>[Address Reference Count : 1]<UL><LI> kernel.o(.text)
</UL>
<P><STRONG><a name="[c7fbc8]"></a>__user_initial_stackheap</STRONG> (ARM, 0 bytes, Stack size unknown bytes, startup.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c7c520]">>></a> __user_setup_stackheap
</UL>
<P><STRONG><a name="[c7e240]"></a>__aeabi_memcpy4</STRONG> (ARM, 0 bytes, Stack size 8 bytes, rt_memcpy_w.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = __aeabi_memcpy4
</UL>
<BR>[Called By]<UL><LI><a href="#[c804a0]">>></a> main
</UL>
<P><STRONG><a name="[c7e1f8]"></a>__aeabi_memcpy8</STRONG> (ARM, 0 bytes, Stack size 8 bytes, rt_memcpy_w.o(.text), UNUSED)
<P><STRONG><a name="[c7e1b0]"></a>__rt_memcpy_w</STRONG> (ARM, 100 bytes, Stack size 8 bytes, rt_memcpy_w.o(.text), UNUSED)
<P><STRONG><a name="[c7e168]"></a>_memcpy_lastbytes_aligned</STRONG> (ARM, 0 bytes, Stack size unknown bytes, rt_memcpy_w.o(.text), UNUSED)
<P><STRONG><a name="[c7de18]"></a>__aeabi_idiv</STRONG> (ARM, 0 bytes, Stack size 8 bytes, aeabi_sdiv.o(.text), UNUSED)
<P><STRONG><a name="[c7ddd0]"></a>__aeabi_idivmod</STRONG> (ARM, 384 bytes, Stack size 8 bytes, aeabi_sdiv.o(.text), UNUSED)
<P><STRONG><a name="[c7d0d8]"></a>__use_two_region_memory</STRONG> (ARM, 4 bytes, Stack size 0 bytes, stkheap2.o(.text), UNUSED)
<P><STRONG><a name="[c7d090]"></a>__rt_stackheap_init</STRONG> (ARM, 36 bytes, Stack size 16 bytes, stkheap2.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 24 + Unknown Stack Size
<LI>Call Chain = __rt_stackheap_init ⇒ __user_setup_stackheap
</UL>
<BR>[Calls]<UL><LI><a href="#[c7bd90]">>></a> __rt_stackheap_storage
<LI><a href="#[c7c520]">>></a> __user_setup_stackheap
</UL>
<BR>[Called By]<UL><LI><a href="#[c7cb48]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[c7d048]"></a>__rt_heap_extend</STRONG> (ARM, 24 bytes, Stack size 8 bytes, stkheap2.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c7cf70]">>></a> __user_heap_extend (Weak Reference)
</UL>
<P><STRONG><a name="[c7cb48]"></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="#[c7a4f8]">>></a> _platform_post_lib_init
<LI><a href="#[c7a668]">>></a> _platform_post_stackheap_init
<LI><a href="#[c7b080]">>></a> __rt_lib_init (via Veneer)
<LI><a href="#[c7b500]">>></a> exit (via BX)
<LI><a href="#[c7d090]">>></a> __rt_stackheap_init
</UL>
<BR>[Called By]<UL><LI><a href="#[c76c78]">>></a> __scatterload_rt2
<LI><a href="#[c7ce08]">>></a> __main
</UL>
<P><STRONG><a name="[c7cb00]"></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="#[c7b038]">>></a> __rt_lib_shutdown (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[c7b500]">>></a> exit (via Veneer)
</UL>
<P><STRONG><a name="[c7cab8]"></a>__rt_abort</STRONG> (ARM, 8 bytes, Stack size 0 bytes, kernel.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c7bbd8]">>></a> _sys_exit
</UL>
<P><STRONG><a name="[c7c520]"></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="#[c7b900]">>></a> __user_perproc_libspace
<LI><a href="#[c7fbc8]">>></a> __user_initial_stackheap
</UL>
<BR>[Called By]<UL><LI><a href="#[c7d090]">>></a> __rt_stackheap_init
</UL>
<P><STRONG><a name="[c7bd90]"></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="#[c7d090]">>></a> __rt_stackheap_init
</UL>
<P><STRONG><a name="[c7bbd8]"></a>_sys_exit</STRONG> (ARM, 20 bytes, Stack size 0 bytes, sys_exit.o(.text), UNUSED)
<BR><BR>[Called By]<UL><LI><a href="#[c7cab8]">>></a> __rt_abort
</UL>
<P><STRONG><a name="[c7b948]"></a>__user_libspace</STRONG> (ARM, 8 bytes, Stack size 0 bytes, libspace.o(.text), UNUSED)
<P><STRONG><a name="[c7b900]"></a>__user_perproc_libspace</STRONG> (ARM, 0 bytes, Stack size 0 bytes, libspace.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c7c520]">>></a> __user_setup_stackheap
</UL>
<P><STRONG><a name="[c7b8b8]"></a>__user_perthread_libspace</STRONG> (ARM, 0 bytes, Stack size 0 bytes, libspace.o(.text), UNUSED)
<P><STRONG><a name="[c7b500]"></a>exit</STRONG> (Thumb, 12 bytes, Stack size 0 bytes, exit.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = exit ⇒ __rt_exit ⇒ __rt_lib_shutdown
</UL>
<BR>[Calls]<UL><LI><a href="#[c7b470]">>></a> _call_atexit_fns (Weak Reference)
<LI><a href="#[c7cb00]">>></a> __rt_exit (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[c7cb48]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[c7b080]"></a>__rt_lib_init</STRONG> (Thumb, 184 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="#[c79280]">>></a> _fp_init (via Veneer)
<LI><a href="#[c79e08]">>></a> __rt_locale (via Veneer)
<LI><a href="#[c7aa50]">>></a> _signal_init (Weak Reference)
<LI><a href="#[c7aa98]">>></a> _rand_init (Weak Reference)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -