⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 blinky.htm

📁 基于AT91SAM7S64的RTX程序,基于AT91SAM7S64的RTX程序
💻 HTM
📖 第 1 页 / 共 3 页
字号:
<!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>#&#060CALLGRAPH&#062# 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 &rArr; os_sys_init_user &rArr; os_tsk_create_user &rArr; 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>&nbsp;&nbsp;&nbsp;&rArr;&nbsp;&nbsp;&nbsp;<a href="#[c80a98]">Undef_Handler</a><BR>
 <LI><a href="#[c80a50]">PAbt_Handler</a>&nbsp;&nbsp;&nbsp;&rArr;&nbsp;&nbsp;&nbsp;<a href="#[c80a50]">PAbt_Handler</a><BR>
 <LI><a href="#[c80a08]">DAbt_Handler</a>&nbsp;&nbsp;&nbsp;&rArr;&nbsp;&nbsp;&nbsp;<a href="#[c80a08]">DAbt_Handler</a><BR>
 <LI><a href="#[c809c0]">IRQ_Handler</a>&nbsp;&nbsp;&nbsp;&rArr;&nbsp;&nbsp;&nbsp;<a href="#[c809c0]">IRQ_Handler</a><BR>
 <LI><a href="#[c80978]">FIQ_Handler</a>&nbsp;&nbsp;&nbsp;&rArr;&nbsp;&nbsp;&nbsp;<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 &rArr; __rt_entry &rArr; __rt_lib_init &rArr; _fp_init
</UL>
<BR>[Calls]<UL><LI><a href="#[10d8b78]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__scatterload
<LI><a href="#[10de6b0]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__scatterload_copy
</UL>
<BR>[Called By]<UL><LI><a href="#[10d88a8]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_tsk_delete (via Veneer)
<LI><a href="#[c7b938]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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 &rArr; os_sys_init_user &rArr; os_tsk_create_user &rArr; os_init_context
</UL>
<BR>[Calls]<UL><LI><a href="#[c7b980]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_dly_wait (via Veneer)
<LI><a href="#[c7b8a8]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_tsk_delete (via Veneer)
<LI><a href="#[c7b938]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_tsk_create_user (via Veneer)
<LI><a href="#[c7b980]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_sys_init_user (via Veneer)
<LI><a href="#[c81e90]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_put_rdy_first (via Veneer)
<LI><a href="#[c81ed8]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_dly_wait (via Veneer)
<LI><a href="#[c7b8a8]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_tsk_delete (via Veneer)
<LI><a href="#[c7b938]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_tsk_create_user (via Veneer)
<LI><a href="#[c7b980]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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 &rArr; _init_box
</UL>
<BR>[Calls]<UL><LI><a href="#[c779f0]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;_init_box (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[c7b980]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_tsk_create_user (via Veneer)
<LI><a href="#[c7b980]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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 &rArr; os_stk_overflow &rArr; os_get_TID
</UL>
<BR>[Calls]<UL><LI><a href="#[c765c8]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;tstclrb
<LI><a href="#[c82358]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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 &rArr; os_put_prio
</UL>
<BR>[Calls]<UL><LI><a href="#[c7e6f8]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_put_prio (via Veneer)
<LI><a href="#[c7e860]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_get_first (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[c74cc0]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__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 &rArr; __user_setup_stackheap
</UL>
<BR>[Calls]<UL><LI><a href="#[10ddc18]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__rt_stackheap_storage
<LI><a href="#[10de088]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__user_setup_stackheap
</UL>
<BR>[Called By]<UL><LI><a href="#[10de6b0]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__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]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__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 + -