?? 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.1 [Build 942]: Last Updated: Fri Mar 06 21:53:20 2009
<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="#[c7ff50]">Reset_Handler</a>
<LI><a href="#[c7ff98]">__user_initial_stackheap</a>
<LI><a href="#[c7fa70]">SoftwareInterrupt</a>
<LI><a href="#[c7fa28]">IntEnable</a>
<LI><a href="#[c7f9e0]">IntDisable</a>
<LI><a href="#[c80220]">Undef_Handler</a>
<LI><a href="#[c801d8]">SWI_Handler</a>
<LI><a href="#[c80190]">PAbt_Handler</a>
<LI><a href="#[c80148]">DAbt_Handler</a>
<LI><a href="#[c80100]">IRQ_Handler</a>
<LI><a href="#[c800b8]">FIQ_Handler</a>
<LI><a href="#[c7fbd8]">IRQDisable</a>
<LI><a href="#[c7fb90]">IRQEnable</a>
<LI><a href="#[c7fb48]">FIQDisable</a>
<LI><a href="#[c7fb00]">FIQEnable</a>
</UL>
</UL>
<P>
<H3>
Mutually Recursive functions
</H3> <LI><a href="#[c80220]">Undef_Handler</a> ⇒ <a href="#[c80220]">Undef_Handler</a><BR>
<LI><a href="#[c801d8]">SWI_Handler</a> ⇒ <a href="#[c801d8]">SWI_Handler</a><BR>
<LI><a href="#[c80190]">PAbt_Handler</a> ⇒ <a href="#[c80190]">PAbt_Handler</a><BR>
<LI><a href="#[c80148]">DAbt_Handler</a> ⇒ <a href="#[c80148]">DAbt_Handler</a><BR>
<LI><a href="#[c80100]">IRQ_Handler</a> ⇒ <a href="#[c80100]">IRQ_Handler</a><BR>
<LI><a href="#[c800b8]">FIQ_Handler</a> ⇒ <a href="#[c800b8]">FIQ_Handler</a><BR>
</UL>
<P>
<H3>
Function Pointers
</H3><UL>
<LI><a href="#[c7ff50]">Reset_Handler</a>
<LI><a href="#[c80220]">Undef_Handler</a>
<LI><a href="#[c801d8]">SWI_Handler</a>
<LI><a href="#[c80190]">PAbt_Handler</a>
<LI><a href="#[c80148]">DAbt_Handler</a>
<LI><a href="#[c80100]">IRQ_Handler</a>
<LI><a href="#[c800b8]">FIQ_Handler</a>
<LI><a href="#[c7d5f0]">__main</a>
<LI><a href="#[c79c40]">__ARM_get_argv</a>
<LI><a href="#[c807d8]">main</a>
<LI><a href="#[c7a9a8]">__I_use_semihosting</a>
<LI><a href="#[c7fbd8]">IRQDisable</a>
<LI><a href="#[c7fb90]">IRQEnable</a>
<LI><a href="#[c7fb48]">FIQDisable</a>
<LI><a href="#[c7fb00]">FIQEnable</a>
</UL>
<P>
<H3>
Global Symbols
</H3>
<P><STRONG><a name="[c7ff50]"></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="#[c82370]">>></a> TargetResetInit
</UL>
<BR>[Address Reference Count : 1]<UL><LI> startup.o(RESET)
</UL>
<P><STRONG><a name="[c7d5f0]"></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="#[c76418]">>></a> __scatterload
<LI><a href="#[c7d330]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[c76418]"></a>__scatterload</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter))
<BR><BR>[Called By]<UL><LI><a href="#[c7d5f0]">>></a> __main
</UL>
<P><STRONG><a name="[c763d0]"></a>__scatterload_rt2</STRONG> (ARM, 52 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c7d330]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[c76388]"></a>__scatterload_null</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<P><STRONG><a name="[c76148]"></a>__scatterload_copy</STRONG> (ARM, 40 bytes, Stack size unknown bytes, __scatter_copy.o(!!handler_copy), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c76148]">>></a> __scatterload_copy
</UL>
<BR>[Called By]<UL><LI><a href="#[c76148]">>></a> __scatterload_copy
</UL>
<P><STRONG><a name="[c75fe0]"></a>__scatterload_zeroinit</STRONG> (ARM, 44 bytes, Stack size unknown bytes, __scatter_zi.o(!!handler_zi), UNUSED)
<P><STRONG><a name="[c7b8f8]"></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="#[c7b868]">>></a> __rt_lib_init (via Veneer)
</UL>
<P><STRONG><a name="[c82f38]"></a>init_VIC</STRONG> (ARM, 88 bytes, Stack size 0 bytes, irq.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c82370]">>></a> TargetResetInit
</UL>
<P><STRONG><a name="[c82ef0]"></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="#[c81430]">>></a> UARTInit
</UL>
<P><STRONG><a name="[c82448]"></a>TargetInit</STRONG> (ARM, 4 bytes, Stack size 0 bytes, target.o(.text), UNUSED)
<P><STRONG><a name="[c82400]"></a>GPIOResetInit</STRONG> (ARM, 120 bytes, Stack size 0 bytes, target.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c82370]">>></a> TargetResetInit
</UL>
<P><STRONG><a name="[c823b8]"></a>ConfigurePLL</STRONG> (ARM, 304 bytes, Stack size 0 bytes, target.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c82370]">>></a> TargetResetInit
</UL>
<P><STRONG><a name="[c82370]"></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="#[c823b8]">>></a> ConfigurePLL
<LI><a href="#[c82400]">>></a> GPIOResetInit
<LI><a href="#[c82f38]">>></a> init_VIC
</UL>
<BR>[Called By]<UL><LI><a href="#[c7ff50]">>></a> Reset_Handler
</UL>
<P><STRONG><a name="[c814c0]"></a>UART0Handler</STRONG> (ARM, 408 bytes, Stack size 24 bytes, uart.o(.text), UNUSED)
<P><STRONG><a name="[c81478]"></a>UART1Handler</STRONG> (ARM, 408 bytes, Stack size 24 bytes, uart.o(.text), UNUSED)
<P><STRONG><a name="[c81430]"></a>UARTInit</STRONG> (ARM, 316 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="#[c7e528]">>></a> __aeabi_uidivmod
<LI><a href="#[c82ef0]">>></a> install_irq
</UL>
<BR>[Called By]<UL><LI><a href="#[c807d8]">>></a> main
</UL>
<P><STRONG><a name="[c813e8]"></a>UARTSend</STRONG> (ARM, 144 bytes, Stack size 0 bytes, uart.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c807d8]">>></a> main
</UL>
<P><STRONG><a name="[c807d8]"></a>main</STRONG> (ARM, 180 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="#[c813e8]">>></a> UARTSend
<LI><a href="#[c81430]">>></a> UARTInit
</UL>
<BR>[Address Reference Count : 1]<UL><LI> kernel.o(.text)
</UL>
<P><STRONG><a name="[c7ff98]"></a>__user_initial_stackheap</STRONG> (ARM, 0 bytes, Stack size unknown bytes, startup.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c7cd08]">>></a> __user_setup_stackheap
</UL>
<P><STRONG><a name="[c7e600]"></a>__aeabi_idiv</STRONG> (ARM, 0 bytes, Stack size 8 bytes, aeabi_sdiv.o(.text), UNUSED)
<P><STRONG><a name="[c7e5b8]"></a>__aeabi_idivmod</STRONG> (ARM, 384 bytes, Stack size 8 bytes, aeabi_sdiv.o(.text), UNUSED)
<P><STRONG><a name="[c7d8c0]"></a>__use_two_region_memory</STRONG> (ARM, 4 bytes, Stack size 0 bytes, stkheap2.o(.text), UNUSED)
<P><STRONG><a name="[c7d878]"></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="#[c7c578]">>></a> __rt_stackheap_storage
<LI><a href="#[c7cd08]">>></a> __user_setup_stackheap
</UL>
<BR>[Called By]<UL><LI><a href="#[c7d330]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[c7d830]"></a>__rt_heap_extend</STRONG> (ARM, 24 bytes, Stack size 8 bytes, stkheap2.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c7d758]">>></a> __user_heap_extend (Weak Reference)
</UL>
<P><STRONG><a name="[c7d330]"></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="#[c7ace0]">>></a> _platform_post_lib_init
<LI><a href="#[c7ae50]">>></a> _platform_post_stackheap_init
<LI><a href="#[c7b868]">>></a> __rt_lib_init (via Veneer)
<LI><a href="#[c7bce8]">>></a> exit (via BX)
<LI><a href="#[c7d878]">>></a> __rt_stackheap_init
</UL>
<BR>[Called By]<UL><LI><a href="#[c763d0]">>></a> __scatterload_rt2
<LI><a href="#[c7d5f0]">>></a> __main
</UL>
<P><STRONG><a name="[c7d2e8]"></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="#[c7b820]">>></a> __rt_lib_shutdown (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[c7bce8]">>></a> exit (via Veneer)
</UL>
<P><STRONG><a name="[c7d2a0]"></a>__rt_abort</STRONG> (ARM, 8 bytes, Stack size 0 bytes, kernel.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c7c3c0]">>></a> _sys_exit
</UL>
<P><STRONG><a name="[c7cd08]"></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="#[c7c0e8]">>></a> __user_perproc_libspace
<LI><a href="#[c7ff98]">>></a> __user_initial_stackheap
</UL>
<BR>[Called By]<UL><LI><a href="#[c7d878]">>></a> __rt_stackheap_init
</UL>
<P><STRONG><a name="[c7c578]"></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="#[c7d878]">>></a> __rt_stackheap_init
</UL>
<P><STRONG><a name="[c7c3c0]"></a>_sys_exit</STRONG> (ARM, 20 bytes, Stack size 0 bytes, sys_exit.o(.text), UNUSED)
<BR><BR>[Called By]<UL><LI><a href="#[c7d2a0]">>></a> __rt_abort
</UL>
<P><STRONG><a name="[c7c130]"></a>__user_libspace</STRONG> (ARM, 8 bytes, Stack size 0 bytes, libspace.o(.text), UNUSED)
<P><STRONG><a name="[c7c0e8]"></a>__user_perproc_libspace</STRONG> (ARM, 0 bytes, Stack size 0 bytes, libspace.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c7cd08]">>></a> __user_setup_stackheap
</UL>
<P><STRONG><a name="[c7c0a0]"></a>__user_perthread_libspace</STRONG> (ARM, 0 bytes, Stack size 0 bytes, libspace.o(.text), UNUSED)
<P><STRONG><a name="[c7bce8]"></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="#[c7bc58]">>></a> _call_atexit_fns (Weak Reference)
<LI><a href="#[c7d2e8]">>></a> __rt_exit (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[c7d330]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[c7b868]"></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="#[c79a68]">>></a> _fp_init (via Veneer)
<LI><a href="#[c7a5f0]">>></a> __rt_locale (via Veneer)
<LI><a href="#[c7b238]">>></a> _signal_init (Weak Reference)
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -