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

📄 blinky.htm

📁 ADuC7020/26是ADI模拟公司开发的ARM7TDMI内核
💻 HTM
📖 第 1 页 / 共 3 页
字号:
<!doctype html public "-//w3c//dtd html 4.0 transitional//en">
<html><head>
<title>Static Call Graph - [.\Obj\Blinky.axf]</title></head>
<body><HR>
<H1>Static Call Graph for image .\Obj\Blinky.axf</H1><HR>
<BR><P>#&#060CALLGRAPH&#062# ARM Linker, RVCT3.0 [Build 942]: Last Updated: Mon Dec 10 16:33:44 2007
<BR><P>
<H3>Maximum Stack Usage =        104 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="#[be2afc]">Reset_Handler</a>
 <LI><a href="#[1010208]">__scatterload</a>
 <LI><a href="#[1010138]">__scatterload_rt2</a>
 <LI><a href="#[1010188]">__scatterload_null</a>
 <LI><a href="#[100faec]">__scatterload_copy</a>
 <LI><a href="#[100f534]">__scatterload_zeroinit</a>
 <LI><a href="#[be297c]">__user_initial_stackheap</a>
 <LI><a href="#[be2b78]">IRQ_Handler</a>
 <LI><a href="#[be0e6c]">os_clock_interrupt</a>
 <LI><a href="#[be0df4]">os_set_env</a>
 <LI><a href="#[c0a910]">SWI_Handler</a>
 <LI><a href="#[1030740]">__fplib_config_pureend_doubles</a>
 <LI><a href="#[be30c8]">Undef_Handler</a>
 <LI><a href="#[be304c]">PAbt_Handler</a>
 <LI><a href="#[be2fd0]">DAbt_Handler</a>
 <LI><a href="#[be2f58]">FIQ_Handler</a>
</UL>
<P>
<H3>
Mutually Recursive functions
</H3><UL>
 <LI><a href="#[be30c8]">Undef_Handler</a>&nbsp;&nbsp;&nbsp;->&nbsp;&nbsp;&nbsp;<a href="#[be30c8]">Undef_Handler</a><BR>
 <LI><a href="#[be304c]">PAbt_Handler</a>&nbsp;&nbsp;&nbsp;->&nbsp;&nbsp;&nbsp;<a href="#[be304c]">PAbt_Handler</a><BR>
 <LI><a href="#[be2fd0]">DAbt_Handler</a>&nbsp;&nbsp;&nbsp;->&nbsp;&nbsp;&nbsp;<a href="#[be2fd0]">DAbt_Handler</a><BR>
 <LI><a href="#[be2f58]">FIQ_Handler</a>&nbsp;&nbsp;&nbsp;->&nbsp;&nbsp;&nbsp;<a href="#[be2f58]">FIQ_Handler</a><BR>
</UL>
<BR>
<P><STRONG><a name="[be2afc]"></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="[ffed98]"></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="#[ffe2b8]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__rt_entry
<LI><a href="#[1010208]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__scatterload
</UL>

<P><STRONG><a name="[1010208]"></a>__scatterload</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter))
<BR><BR>[Called By]<UL><LI><a href="#[ffed98]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;__main
</UL>

<P><STRONG><a name="[1010138]"></a>__scatterload_rt2</STRONG> (ARM, 48 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[ffe2b8]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__rt_entry
</UL>

<P><STRONG><a name="[1010188]"></a>__scatterload_null</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)

<P><STRONG><a name="[100faec]"></a>__scatterload_copy</STRONG> (ARM, 40 bytes, Stack size unknown bytes, __scatter_copy.o(!!handler_copy), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[100faec]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__scatterload_copy
</UL>
<BR>[Called By]<UL><LI><a href="#[100faec]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;__scatterload_copy
</UL>

<P><STRONG><a name="[100f534]"></a>__scatterload_zeroinit</STRONG> (ARM, 44 bytes, Stack size unknown bytes, __scatter_zi.o(!!handler_zi), UNUSED)

<P><STRONG><a name="[ff7698]"></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="#[ff75cc]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;__rt_lib_init (via Veneer)
</UL>

<P><STRONG><a name="[b26630]"></a>keyin</STRONG> (ARM, 52 bytes, Stack size 24 bytes, blinky.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c0d780]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_itv_wait (via Veneer)
<LI><a href="#[c0d7d0]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_itv_set (via Veneer)
</UL>

<P><STRONG><a name="[b265bc]"></a>blink</STRONG> (ARM, 36 bytes, Stack size 16 bytes, blinky.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c0d820]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_dly_wait (via Veneer)
</UL>

<P><STRONG><a name="[b26548]"></a>init</STRONG> (ARM, 76 bytes, Stack size 8 bytes, blinky.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[bf71d0]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_tsk_delete (via Veneer)
<LI><a href="#[bf72a4]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_tsk_create_user (via Veneer)
</UL>

<P><STRONG><a name="[b264d4]"></a>main</STRONG> (ARM, 36 bytes, Stack size 8 bytes, blinky.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 104 + 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="#[bf72f4]">&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="[bcfa88]"></a>os_idle_demon</STRONG> (ARM, 8 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[bf72f4]">&lt;&lt;</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="[bcfa10]"></a>os_tmr_call</STRONG> (ARM, 4 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[fdbe4c]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_tmr_tick (via Veneer)
</UL>

<P><STRONG><a name="[bcf998]"></a>tsk_lock</STRONG> (ARM, 16 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[bcf918]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_clock_interrupt0
<LI><a href="#[bf71d0]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_tsk_delete (via Veneer)
<LI><a href="#[bf72a4]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_tsk_create_user (via Veneer)
<LI><a href="#[bf72f4]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_sys_init_user (via Veneer)
<LI><a href="#[c0d780]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_itv_wait (via Veneer)
<LI><a href="#[c0d820]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_dly_wait (via Veneer)
</UL>

<P><STRONG><a name="[bcf918]"></a>os_clock_interrupt0</STRONG> (ARM, 148 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="#[bcf998]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;tsk_lock
<LI><a href="#[bd78b0]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_put_rdy_first (via Veneer)
</UL>
<BR>[Address Reference Count : 1]<UL><LI> IRQ_RTX.o(IRQ_Area)
</UL>
<P><STRONG><a name="[bcf898]"></a>os_def_interrupt</STRONG> (ARM, 4 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR>[Address Reference Count : 1]<UL><LI> irq.o(IRQ)
</UL>
<P><STRONG><a name="[bcf820]"></a>os_tmr_init</STRONG> (ARM, 36 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[bf72f4]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_sys_init_user (via Veneer)
</UL>

<P><STRONG><a name="[bcf7a4]"></a>os_tmr_reload</STRONG> (ARM, 4 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c08c34]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_clock_demon (via Veneer)
</UL>

<P><STRONG><a name="[bcf724]"></a>os_tmr_force_irq</STRONG> (ARM, 56 bytes, Stack size 0 bytes, rtx_config.o(.text), UNUSED)

<P><STRONG><a name="[bcf6a4]"></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="#[c08c34]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_clock_demon (via Veneer)
</UL>

<P><STRONG><a name="[bcf624]"></a>os_tmr_inspect_ovf</STRONG> (ARM, 16 bytes, Stack size 0 bytes, rtx_config.o(.text), UNUSED)

<P><STRONG><a name="[bcf5ac]"></a>tsk_unlock</STRONG> (ARM, 56 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[bf71d0]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_tsk_delete (via Veneer)
<LI><a href="#[bf72a4]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_tsk_create_user (via Veneer)
<LI><a href="#[bf72f4]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_sys_init_user (via Veneer)
<LI><a href="#[c0d780]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_itv_wait (via Veneer)
<LI><a href="#[c0d820]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_dly_wait (via Veneer)
</UL>

<P><STRONG><a name="[bcf534]"></a>os_init_mem</STRONG> (ARM, 76 bytes, Stack size 8 bytes, rtx_config.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 20<LI>Call Chain = os_init_mem -> _init_box</UL>
<BR>[Calls]<UL><LI><a href="#[bff080]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;_init_box (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[bf72f4]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_sys_init_user (via Veneer)
</UL>

<P><STRONG><a name="[bcf4b8]"></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="#[bf72a4]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_tsk_create_user (via Veneer)
</UL>

<P><STRONG><a name="[bcf440]"></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="#[bf71d0]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_tsk_delete (via Veneer)
</UL>

<P><STRONG><a name="[bcf3c4]"></a>os_alloc_TMR</STRONG> (ARM, 8 bytes, Stack size 0 bytes, rtx_config.o(.text), UNUSED)

<P><STRONG><a name="[bcf34c]"></a>os_free_TMR</STRONG> (ARM, 4 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[fdbe4c]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_tmr_tick (via Veneer)
</UL>

<P><STRONG><a name="[bcf2d0]"></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="#[bf72a4]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_tsk_create_user (via Veneer)
<LI><a href="#[bf72f4]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_sys_init_user (via Veneer)
</UL>

<P><STRONG><a name="[bcf25c]"></a>__SWI_0</STRONG> (ARM, 200 bytes, Stack size 8 bytes, rtx_config.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = __SWI_0 -> os_stk_overflow</UL>
<BR>[Calls]<UL><LI><a href="#[bd0620]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_stk_overflow
<LI><a href="#[bdec04]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;tstclrb
</UL>
<BR>[Address Reference Count : 1]<UL><LI> SWI_Table.o(SWI_TABLE)
</UL>
<P><STRONG><a name="[bcf1e0]"></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="#[bd7900]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_put_prio (via Veneer)
<LI><a href="#[bd7b3c]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;os_get_first (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[c08c34]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;os_clock_demon (via Veneer)
</UL>

<P><STRONG><a name="[bc4ca0]"></a>_sys_exit</STRONG> (ARM, 4 bytes, Stack size 0 bytes, retarget.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[bc4ca0]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;_sys_exit
</UL>
<BR>[Called By]<UL><LI><a href="#[bc4ca0]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;_sys_exit
<LI><a href="#[ffe0f8]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;__rt_abort
</UL>

<P><STRONG><a name="[be297c]"></a>__user_initial_stackheap</STRONG> (ARM, 0 bytes, Stack size unknown bytes, startup.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[ffd7fc]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;__user_setup_stackheap
</UL>

<P><STRONG><a name="[fffd84]"></a>__I_use_semihosting</STRONG> (ARM, 0 bytes, Stack size 0 bytes, use_no_semi.o(.text), UNUSED)

<P><STRONG><a name="[fffd34]"></a>__use_no_semihosting_swi</STRONG> (ARM, 4 bytes, Stack size 0 bytes, use_no_semi.o(.text), UNUSED)

<P><STRONG><a name="[fff640]"></a>__use_two_region_memory</STRONG> (ARM, 4 bytes, Stack size 0 bytes, stkheap2.o(.text), UNUSED)

<P><STRONG><a name="[fff5b8]"></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="#[ffca24]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__rt_stackheap_storage
<LI><a href="#[ffd7fc]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__user_setup_stackheap
</UL>
<BR>[Called By]<UL><LI><a href="#[ffe2b8]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;__rt_entry
</UL>

<P><STRONG><a name="[fff530]"></a>__rt_heap_extend</STRONG> (ARM, 24 bytes, Stack size 8 bytes, stkheap2.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[fff714]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__user_heap_extend (Weak Reference)
</UL>

<P><STRONG><a name="[ffe2b8]"></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="#[ff53a0]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;_platform_post_lib_init
<LI><a href="#[ff595c]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;_platform_post_stackheap_init
<LI><a href="#[ff5e94]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;_platform_pre_stackheap_init
<LI><a href="#[ff75cc]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__rt_lib_init (via Veneer)
<LI><a href="#[ffb00c]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;exit (via BX)
<LI><a href="#[fff5b8]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__rt_stackheap_init
</UL>
<BR>[Called By]<UL><LI><a href="#[ffed98]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;__main
<LI><a href="#[1010138]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;__scatterload_rt2
</UL>

<P><STRONG><a name="[ffe170]"></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="#[ff4e44]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;_platform_pre_lib_shutdown
<LI><a href="#[ff757c]">&gt;&gt;</a>&nbsp;&nbsp;&nbsp;__rt_lib_shutdown (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[ffb00c]">&lt;&lt;</a>&nbsp;&nbsp;&nbsp;exit (via Veneer)
</UL>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -