📄 blinky.htm
字号:
<!doctype html public "-//w3c//dtd html 4.0 transitional//en">
<html><head>
<title>Static Call Graph - [D:\Keil\ARM\Boards\Embest\ATEBSAM7S\RTX_Blinky\Blinky.axf]</title></head>
<body><HR>
<H1>Static Call Graph for image D:\Keil\ARM\Boards\Embest\ATEBSAM7S\RTX_Blinky\Blinky.axf</H1><HR>
<BR><P>#<CALLGRAPH># ARM Linker, RVCT3.1 [Build 901]: Last Updated: Tue May 15 15:27:37 2007
<BR><P>
<H3>Maximum Stack Usage = 96 bytes + Unknown(Functions without stacksize, Cycles, Untraceable Function Pointers)</H3><H3>
Call chain for Maximum Stack Depth:</H3>
main ⇒ os_sys_init_user ⇒ os_tsk_create_user ⇒ os_init_context
<P>
<H3>
Functions with no stack information
</H3><UL>
<LI><a href="#[c80810]">Reset_Handler</a>
<LI><a href="#[c80858]">__user_initial_stackheap</a>
<LI><a href="#[c75d20]">os_clock_interrupt</a>
<LI><a href="#[c75cd8]">os_set_env</a>
<LI><a href="#[c758e8]">SWI_Handler</a>
<LI><a href="#[c80a98]">Undef_Handler</a>
<LI><a href="#[c80a50]">PAbt_Handler</a>
<LI><a href="#[c80a08]">DAbt_Handler</a>
<LI><a href="#[c809c0]">IRQ_Handler</a>
<LI><a href="#[c80978]">FIQ_Handler</a>
</UL>
</UL>
<P>
<H3>
Mutually Recursive functions
</H3> <LI><a href="#[c80a98]">Undef_Handler</a> ⇒ <a href="#[c80a98]">Undef_Handler</a><BR>
<LI><a href="#[c80a50]">PAbt_Handler</a> ⇒ <a href="#[c80a50]">PAbt_Handler</a><BR>
<LI><a href="#[c80a08]">DAbt_Handler</a> ⇒ <a href="#[c80a08]">DAbt_Handler</a><BR>
<LI><a href="#[c809c0]">IRQ_Handler</a> ⇒ <a href="#[c809c0]">IRQ_Handler</a><BR>
<LI><a href="#[c80978]">FIQ_Handler</a> ⇒ <a href="#[c80978]">FIQ_Handler</a><BR>
</UL>
<P>
<H3>
Function Pointers
</H3><UL>
<LI><a href="#[c80810]">Reset_Handler</a>
<LI><a href="#[c80a98]">Undef_Handler</a>
<LI><a href="#[c758e8]">SWI_Handler</a>
<LI><a href="#[c80a50]">PAbt_Handler</a>
<LI><a href="#[c80a08]">DAbt_Handler</a>
<LI><a href="#[c809c0]">IRQ_Handler</a>
<LI><a href="#[c80978]">FIQ_Handler</a>
<LI><a href="#[10de970]">__main</a>
<LI><a href="#[10db588]">__ARM_get_argv</a>
<LI><a href="#[c75d20]">os_clock_interrupt</a>
<LI><a href="#[c82eb0]">main</a>
<LI><a href="#[c81e90]">os_clock_interrupt0</a>
<LI><a href="#[c81aa0]">__SWI_0</a>
<LI><a href="#[c77ac8]">__SWI_1</a>
<LI><a href="#[c77a80]">__SWI_2</a>
<LI><a href="#[c76730]">__SWI_3</a>
<LI><a href="#[c766e8]">__SWI_4</a>
<LI><a href="#[c766a0]">__SWI_5</a>
<LI><a href="#[c76658]">__SWI_6</a>
<LI><a href="#[c76610]">__SWI_7</a>
<LI><a href="#[c74cc0]">os_clock_demon</a>
<LI><a href="#[c81f68]">os_idle_demon</a>
</UL>
<P>
<H3>
Global Symbols
</H3>
<P><STRONG><a name="[c80810]"></a>Reset_Handler</STRONG> (ARM, 0 bytes, Stack size unknown bytes, sam7.o(RESET))
<BR>[Address Reference Count : 1]<UL><LI> sam7.o(RESET)
</UL>
<P><STRONG><a name="[10de970]"></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="#[10d8b78]">>></a> __scatterload
<LI><a href="#[10de6b0]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[10d8b78]"></a>__scatterload</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter))
<BR><BR>[Called By]<UL><LI><a href="#[10de970]">>></a> __main
</UL>
<P><STRONG><a name="[10d8b30]"></a>__scatterload_rt2</STRONG> (ARM, 52 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[10de6b0]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[10d8ae8]"></a>__scatterload_null</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<P><STRONG><a name="[10d88a8]"></a>__scatterload_copy</STRONG> (ARM, 40 bytes, Stack size unknown bytes, __scatter_copy.o(!!handler_copy), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[10d88a8]">>></a> __scatterload_copy
</UL>
<BR>[Called By]<UL><LI><a href="#[10d88a8]">>></a> __scatterload_copy
</UL>
<P><STRONG><a name="[10d8740]"></a>__scatterload_zeroinit</STRONG> (ARM, 44 bytes, Stack size unknown bytes, __scatter_zi.o(!!handler_zi), UNUSED)
<P><STRONG><a name="[10dcfd0]"></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="#[10dcf40]">>></a> __rt_lib_init (via Veneer)
</UL>
<P><STRONG><a name="[c82fd0]"></a>phaseA</STRONG> (ARM, 44 bytes, Stack size 8 bytes, blinky.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c78c48]">>></a> os_dly_wait (via Veneer)
</UL>
<P><STRONG><a name="[c82f88]"></a>phaseB</STRONG> (ARM, 44 bytes, Stack size 8 bytes, blinky.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c78c48]">>></a> os_dly_wait (via Veneer)
</UL>
<P><STRONG><a name="[c82f40]"></a>phaseC</STRONG> (ARM, 44 bytes, Stack size 8 bytes, blinky.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c78c48]">>></a> os_dly_wait (via Veneer)
</UL>
<P><STRONG><a name="[c82ef8]"></a>init</STRONG> (ARM, 132 bytes, Stack size 8 bytes, blinky.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c7b8a8]">>></a> os_tsk_delete (via Veneer)
<LI><a href="#[c7b938]">>></a> os_tsk_create_user (via Veneer)
</UL>
<P><STRONG><a name="[c82eb0]"></a>main</STRONG> (ARM, 36 bytes, Stack size 8 bytes, blinky.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 96 + Unknown Stack Size
<LI>Call Chain = main ⇒ os_sys_init_user ⇒ os_tsk_create_user ⇒ os_init_context
</UL>
<BR>[Calls]<UL><LI><a href="#[c7b980]">>></a> os_sys_init_user (via Veneer)
</UL>
<BR>[Address Reference Count : 1]<UL><LI> kernel.o(.text)
</UL>
<P><STRONG><a name="[c81f68]"></a>os_idle_demon</STRONG> (ARM, 8 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c7b980]">>></a> os_sys_init_user (via Veneer)
</UL>
<BR>[Address Reference Count : 1]<UL><LI> rt_task.o(i.os_sys_init_user)
</UL>
<P><STRONG><a name="[c81f20]"></a>os_tmr_call</STRONG> (ARM, 8 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[10e04c8]">>></a> os_tmr_tick (via Veneer)
</UL>
<P><STRONG><a name="[c81ed8]"></a>tsk_lock</STRONG> (ARM, 16 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c78c48]">>></a> os_dly_wait (via Veneer)
<LI><a href="#[c7b8a8]">>></a> os_tsk_delete (via Veneer)
<LI><a href="#[c7b938]">>></a> os_tsk_create_user (via Veneer)
<LI><a href="#[c7b980]">>></a> os_sys_init_user (via Veneer)
<LI><a href="#[c81e90]">>></a> os_clock_interrupt0
</UL>
<P><STRONG><a name="[c81e90]"></a>os_clock_interrupt0</STRONG> (ARM, 132 bytes, Stack size 8 bytes, rtx_config.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = os_clock_interrupt0
</UL>
<BR>[Calls]<UL><LI><a href="#[c7e6b0]">>></a> os_put_rdy_first (via Veneer)
<LI><a href="#[c81ed8]">>></a> tsk_lock
</UL>
<BR>[Address Reference Count : 1]<UL><LI> IRQ_RTX.o(IRQ_Area)
</UL>
<P><STRONG><a name="[c81e48]"></a>os_def_interrupt</STRONG> (ARM, 20 bytes, Stack size 8 bytes, rtx_config.o(.text), UNUSED)
<P><STRONG><a name="[c81e00]"></a>os_tmr_init</STRONG> (ARM, 60 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c7b980]">>></a> os_sys_init_user (via Veneer)
</UL>
<P><STRONG><a name="[c81db8]"></a>os_tmr_reload</STRONG> (ARM, 4 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c74cc0]">>></a> os_clock_demon (via Veneer)
</UL>
<P><STRONG><a name="[c81d70]"></a>os_tmr_force_irq</STRONG> (ARM, 16 bytes, Stack size 0 bytes, rtx_config.o(.text), UNUSED)
<P><STRONG><a name="[c81d28]"></a>os_tmr_inspect_cnt</STRONG> (ARM, 20 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c74cc0]">>></a> os_clock_demon (via Veneer)
</UL>
<P><STRONG><a name="[c81ce0]"></a>os_tmr_inspect_ovf</STRONG> (ARM, 16 bytes, Stack size 0 bytes, rtx_config.o(.text), UNUSED)
<P><STRONG><a name="[c81c98]"></a>tsk_unlock</STRONG> (ARM, 16 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c78c48]">>></a> os_dly_wait (via Veneer)
<LI><a href="#[c7b8a8]">>></a> os_tsk_delete (via Veneer)
<LI><a href="#[c7b938]">>></a> os_tsk_create_user (via Veneer)
<LI><a href="#[c7b980]">>></a> os_sys_init_user (via Veneer)
</UL>
<P><STRONG><a name="[c81c50]"></a>os_init_mem</STRONG> (ARM, 76 bytes, Stack size 8 bytes, rtx_config.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 12<LI>Call Chain = os_init_mem ⇒ _init_box
</UL>
<BR>[Calls]<UL><LI><a href="#[c779f0]">>></a> _init_box (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[c7b980]">>></a> os_sys_init_user (via Veneer)
</UL>
<P><STRONG><a name="[c81c08]"></a>os_alloc_TCB</STRONG> (ARM, 20 bytes, Stack size 8 bytes, rtx_config.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = os_alloc_TCB
</UL>
<BR>[Called By]<UL><LI><a href="#[c7b938]">>></a> os_tsk_create_user (via Veneer)
</UL>
<P><STRONG><a name="[c81bc0]"></a>os_free_TCB</STRONG> (ARM, 68 bytes, Stack size 8 bytes, rtx_config.o(.text), UNUSED)
<BR><BR>[Called By]<UL><LI><a href="#[c7b8a8]">>></a> os_tsk_delete (via Veneer)
</UL>
<P><STRONG><a name="[c81b78]"></a>os_alloc_TMR</STRONG> (ARM, 8 bytes, Stack size 0 bytes, rtx_config.o(.text), UNUSED)
<P><STRONG><a name="[c81b30]"></a>os_free_TMR</STRONG> (ARM, 8 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[10e04c8]">>></a> os_tmr_tick (via Veneer)
</UL>
<P><STRONG><a name="[c81ae8]"></a>os_init_context</STRONG> (ARM, 280 bytes, Stack size 32 bytes, rtx_config.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 32<LI>Call Chain = os_init_context
</UL>
<BR>[Called By]<UL><LI><a href="#[c7b938]">>></a> os_tsk_create_user (via Veneer)
<LI><a href="#[c7b980]">>></a> os_sys_init_user (via Veneer)
</UL>
<P><STRONG><a name="[c81aa0]"></a>__SWI_0</STRONG> (ARM, 160 bytes, Stack size 8 bytes, rtx_config.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 20<LI>Call Chain = __SWI_0 ⇒ os_stk_overflow ⇒ os_get_TID
</UL>
<BR>[Calls]<UL><LI><a href="#[c765c8]">>></a> tstclrb
<LI><a href="#[c82358]">>></a> os_stk_overflow
</UL>
<BR>[Address Reference Count : 1]<UL><LI> SWI_Table.o(SWI_TABLE)
</UL>
<P><STRONG><a name="[c81a58]"></a>os_chk_robin</STRONG> (ARM, 136 bytes, Stack size 8 bytes, rtx_config.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = os_chk_robin ⇒ os_put_prio
</UL>
<BR>[Calls]<UL><LI><a href="#[c7e6f8]">>></a> os_put_prio (via Veneer)
<LI><a href="#[c7e860]">>></a> os_get_first (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[c74cc0]">>></a> os_clock_demon (via Veneer)
</UL>
<P><STRONG><a name="[c81000]"></a>_sys_exit</STRONG> (ARM, 8 bytes, Stack size 0 bytes, retarget.o(.text), UNUSED)
<BR><BR>[Called By]<UL><LI><a href="#[10de620]">>></a> __rt_abort
</UL>
<P><STRONG><a name="[c80858]"></a>__user_initial_stackheap</STRONG> (ARM, 0 bytes, Stack size unknown bytes, sam7.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[10de088]">>></a> __user_setup_stackheap
</UL>
<P><STRONG><a name="[10dedf8]"></a>__I_use_semihosting</STRONG> (ARM, 0 bytes, Stack size 0 bytes, use_no_semi.o(.text), UNUSED)
<P><STRONG><a name="[10dedb0]"></a>__use_no_semihosting_swi</STRONG> (ARM, 4 bytes, Stack size 0 bytes, use_no_semi.o(.text), UNUSED)
<P><STRONG><a name="[10dec40]"></a>__use_two_region_memory</STRONG> (ARM, 4 bytes, Stack size 0 bytes, stkheap2.o(.text), UNUSED)
<P><STRONG><a name="[10debf8]"></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="#[10ddc18]">>></a> __rt_stackheap_storage
<LI><a href="#[10de088]">>></a> __user_setup_stackheap
</UL>
<BR>[Called By]<UL><LI><a href="#[10de6b0]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[10debb0]"></a>__rt_heap_extend</STRONG> (ARM, 24 bytes, Stack size 8 bytes, stkheap2.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[10dead8]">>></a> __user_heap_extend (Weak Reference)
</UL>
<P><STRONG><a name="[10de6b0]"></a>__rt_entry</STRONG> (ARM, 76 bytes, Stack size 16 bytes, kernel.o(.text))
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -