📄 testhello.htm
字号:
<!doctype html public "-//w3c//dtd html 4.0 transitional//en">
<html><head>
<title>Static Call Graph - [C:\Keil\ARM\Examples\Hello2119\testhello.axf]</title></head>
<body><HR>
<H1>Static Call Graph for image C:\Keil\ARM\Examples\Hello2119\testhello.axf</H1><HR>
<BR><P>#<CALLGRAPH># ARM Linker, RVCT3.0 [Build 942]: Last Updated: Sun Sep 17 21:55:06 2006
<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="#[b483f0]">Reset_Handler</a>
<LI><a href="#[100a5a4]">__scatterload</a>
<LI><a href="#[100a4d4]">__scatterload_rt2</a>
<LI><a href="#[100a524]">__scatterload_null</a>
<LI><a href="#[1009e88]">__scatterload_copy</a>
<LI><a href="#[10098d0]">__scatterload_zeroinit</a>
<LI><a href="#[b48270]">__user_initial_stackheap</a>
<LI><a href="#[c2bebc]">__fplib_config_pureend_doubles</a>
<LI><a href="#[b489e0]">Undef_Handler</a>
<LI><a href="#[b48968]">SWI_Handler</a>
<LI><a href="#[b488ec]">PAbt_Handler</a>
<LI><a href="#[b48870]">DAbt_Handler</a>
<LI><a href="#[b487f8]">IRQ_Handler</a>
<LI><a href="#[b48780]">FIQ_Handler</a>
</UL>
<P>
<H3>
Mutually Recursive functions
</H3><UL>
<LI><a href="#[b489e0]">Undef_Handler</a> -> <a href="#[b489e0]">Undef_Handler</a><BR>
<LI><a href="#[b48968]">SWI_Handler</a> -> <a href="#[b48968]">SWI_Handler</a><BR>
<LI><a href="#[b488ec]">PAbt_Handler</a> -> <a href="#[b488ec]">PAbt_Handler</a><BR>
<LI><a href="#[b48870]">DAbt_Handler</a> -> <a href="#[b48870]">DAbt_Handler</a><BR>
<LI><a href="#[b487f8]">IRQ_Handler</a> -> <a href="#[b487f8]">IRQ_Handler</a><BR>
<LI><a href="#[b48780]">FIQ_Handler</a> -> <a href="#[b48780]">FIQ_Handler</a><BR>
</UL>
<BR>
<P><STRONG><a name="[b483f0]"></a>Reset_Handler</STRONG> (ARM, 0 bytes, Stack size unknown bytes, startup.o(RESET))
<BR>[Address Reference Count : 1]<UL><LI> startup.o(RESET)
</UL>
<P><STRONG><a name="[c0b1d8]"></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="#[c0a6d0]">>></a> __rt_entry
<LI><a href="#[100a5a4]">>></a> __scatterload
</UL>
<P><STRONG><a name="[100a5a4]"></a>__scatterload</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter))
<BR><BR>[Called By]<UL><LI><a href="#[c0b1d8]"><<</a> __main
</UL>
<P><STRONG><a name="[100a4d4]"></a>__scatterload_rt2</STRONG> (ARM, 48 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c0a6d0]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[100a524]"></a>__scatterload_null</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<P><STRONG><a name="[1009e88]"></a>__scatterload_copy</STRONG> (ARM, 40 bytes, Stack size unknown bytes, __scatter_copy.o(!!handler_copy), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[1009e88]">>></a> __scatterload_copy
</UL>
<BR>[Called By]<UL><LI><a href="#[1009e88]"><<</a> __scatterload_copy
</UL>
<P><STRONG><a name="[10098d0]"></a>__scatterload_zeroinit</STRONG> (ARM, 44 bytes, Stack size unknown bytes, __scatter_zi.o(!!handler_zi), UNUSED)
<P><STRONG><a name="[c33290]"></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="#[c331c4]"><<</a> __rt_lib_init (via Veneer)
</UL>
<P><STRONG><a name="[b48270]"></a>__user_initial_stackheap</STRONG> (ARM, 0 bytes, Stack size unknown bytes, startup.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c09bc4]"><<</a> __user_setup_stackheap
</UL>
<P><STRONG><a name="[b45b70]"></a>delay</STRONG> (ARM, 44 bytes, Stack size 0 bytes, hello.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b454f4]"><<</a> main
</UL>
<P><STRONG><a name="[b45af8]"></a>InitTimer1</STRONG> (ARM, 48 bytes, Stack size 0 bytes, hello.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b454f4]"><<</a> main
</UL>
<P><STRONG><a name="[b45a80]"></a>InitUart0</STRONG> (ARM, 68 bytes, Stack size 0 bytes, hello.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b454f4]"><<</a> main
</UL>
<P><STRONG><a name="[b45a0c]"></a>putchar</STRONG> (ARM, 72 bytes, Stack size 0 bytes, hello.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b4583c]"><<</a> putstr
<LI><a href="#[b45998]"><<</a> puthex
</UL>
<P><STRONG><a name="[b45998]"></a>puthex</STRONG> (ARM, 52 bytes, Stack size 4 bytes, hello.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[b45a0c]">>></a> putchar
</UL>
<BR>[Called By]<UL><LI><a href="#[b45924]"><<</a> putlong
</UL>
<P><STRONG><a name="[b45924]"></a>putlong</STRONG> (ARM, 104 bytes, Stack size 16 bytes, hello.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[b45998]">>></a> puthex
</UL>
<P><STRONG><a name="[b458b0]"></a>getchar</STRONG> (ARM, 32 bytes, Stack size 0 bytes, hello.o(.text), UNUSED)
<P><STRONG><a name="[b4583c]"></a>putstr</STRONG> (ARM, 40 bytes, Stack size 4 bytes, hello.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 4<LI>Call Chain = putstr</UL>
<BR>[Calls]<UL><LI><a href="#[b45a0c]">>></a> putchar
</UL>
<BR>[Called By]<UL><LI><a href="#[b454f4]"><<</a> main
<LI><a href="#[b45568]"><<</a> CAN2_Transmit
<LI><a href="#[b455e4]"><<</a> IRQ_CAN2Rx
<LI><a href="#[b4565c]"><<</a> CAN1_Transmit
</UL>
<P><STRONG><a name="[b457c8]"></a>InitCan</STRONG> (ARM, 180 bytes, Stack size 0 bytes, hello.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b454f4]"><<</a> main
</UL>
<P><STRONG><a name="[b45750]"></a>IRQ_Timer1</STRONG> (ARM, 148 bytes, Stack size 8 bytes, hello.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = IRQ_Timer1</UL>
<BR>[Address Reference Count : 1]<UL><LI> hello.o(.text)
</UL>
<P><STRONG><a name="[b456d8]"></a>IRQ_CAN1Rx</STRONG> (ARM, 144 bytes, Stack size 12 bytes, hello.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 12<LI>Call Chain = IRQ_CAN1Rx</UL>
<BR>[Address Reference Count : 1]<UL><LI> hello.o(.text)
</UL>
<P><STRONG><a name="[b4565c]"></a>CAN1_Transmit</STRONG> (ARM, 184 bytes, Stack size 12 bytes, hello.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[b4583c]">>></a> putstr
</UL>
<P><STRONG><a name="[b455e4]"></a>IRQ_CAN2Rx</STRONG> (ARM, 152 bytes, Stack size 28 bytes, hello.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[b4583c]">>></a> putstr
</UL>
<P><STRONG><a name="[b45568]"></a>CAN2_Transmit</STRONG> (ARM, 468 bytes, Stack size 12 bytes, hello.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = CAN2_Transmit -> putstr</UL>
<BR>[Calls]<UL><LI><a href="#[b4583c]">>></a> putstr
</UL>
<BR>[Called By]<UL><LI><a href="#[b454f4]"><<</a> main
</UL>
<P><STRONG><a name="[b454f4]"></a>main</STRONG> (ARM, 436 bytes, Stack size 8 bytes, hello.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 24<LI>Call Chain = main -> CAN2_Transmit -> putstr</UL>
<BR>[Calls]<UL><LI><a href="#[b45568]">>></a> CAN2_Transmit
<LI><a href="#[b457c8]">>></a> InitCan
<LI><a href="#[b4583c]">>></a> putstr
<LI><a href="#[b45a80]">>></a> InitUart0
<LI><a href="#[b45af8]">>></a> InitTimer1
<LI><a href="#[b45b70]">>></a> delay
</UL>
<BR>[Address Reference Count : 1]<UL><LI> kernel.o(.text)
</UL>
<P><STRONG><a name="[c0ba80]"></a>__use_two_region_memory</STRONG> (ARM, 4 bytes, Stack size 0 bytes, stkheap2.o(.text), UNUSED)
<P><STRONG><a name="[c0b9f8]"></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="#[c08dec]">>></a> __rt_stackheap_storage
<LI><a href="#[c09bc4]">>></a> __user_setup_stackheap
</UL>
<BR>[Called By]<UL><LI><a href="#[c0a6d0]"><<</a> __rt_entry
</UL>
<P><STRONG><a name="[c0b970]"></a>__rt_heap_extend</STRONG> (ARM, 24 bytes, Stack size 8 bytes, stkheap2.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c0bb54]">>></a> __user_heap_extend (Weak Reference)
</UL>
<P><STRONG><a name="[c0a6d0]"></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="#[c06de0]">>></a> exit (via BX)
<LI><a href="#[c0b9f8]">>></a> __rt_stackheap_init
<LI><a href="#[c30f98]">>></a> _platform_post_lib_init
<LI><a href="#[c31554]">>></a> _platform_post_stackheap_init
<LI><a href="#[c31a8c]">>></a> _platform_pre_stackheap_init
<LI><a href="#[c331c4]">>></a> __rt_lib_init (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[c0b1d8]"><<</a> __main
<LI><a href="#[100a4d4]"><<</a> __scatterload_rt2
</UL>
<P><STRONG><a name="[c0a588]"></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="#[c30a3c]">>></a> _platform_pre_lib_shutdown
<LI><a href="#[c33174]">>></a> __rt_lib_shutdown (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[c06de0]"><<</a> exit (via Veneer)
</UL>
<P><STRONG><a name="[c0a510]"></a>__rt_abort</STRONG> (ARM, 8 bytes, Stack size 0 bytes, kernel.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c07c80]">>></a> _sys_exit
</UL>
<P><STRONG><a name="[c09bc4]"></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="#[b48270]">>></a> __user_initial_stackheap
<LI><a href="#[c0763c]">>></a> __user_perproc_libspace
</UL>
<BR>[Called By]<UL><LI><a href="#[c0b9f8]"><<</a> __rt_stackheap_init
</UL>
<P><STRONG><a name="[c08dec]"></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="#[c0b9f8]"><<</a> __rt_stackheap_init
</UL>
<P><STRONG><a name="[c07c80]"></a>_sys_exit</STRONG> (ARM, 20 bytes, Stack size 0 bytes, sys_exit.o(.text), UNUSED)
<BR><BR>[Called By]<UL><LI><a href="#[c0a510]"><<</a> __rt_abort
</UL>
<P><STRONG><a name="[c07514]"></a>__user_libspace</STRONG> (ARM, 8 bytes, Stack size 0 bytes, libspace.o(.text), UNUSED)
<P><STRONG><a name="[c0763c]"></a>__user_perproc_libspace</STRONG> (ARM, 0 bytes, Stack size 0 bytes, libspace.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c09bc4]"><<</a> __user_setup_stackheap
</UL>
<P><STRONG><a name="[c075b4]"></a>__user_perthread_libspace</STRONG> (ARM, 0 bytes, Stack size 0 bytes, libspace.o(.text), UNUSED)
<P><STRONG><a name="[c06de0]"></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="#[c06c90]">>></a> _call_atexit_fns (Weak Reference)
<LI><a href="#[c06d10]">>></a> __ARM_stackcheck (Weak Reference)
<LI><a href="#[c0a588]">>></a> __rt_exit (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[c0a6d0]"><<</a> __rt_entry
</UL>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -