📄 rtldemo.htm
字号:
<!doctype html public "-//w3c//dtd html 4.0 transitional//en">
<html><head>
<title>Static Call Graph - [E:\qjs\armpro\RTLDemo\RTLDemo.axf]</title></head>
<body><HR>
<H1>Static Call Graph for image E:\qjs\armpro\RTLDemo\RTLDemo.axf</H1><HR>
<BR><P>#<CALLGRAPH># ARM Linker, RVCT3.0 [Build 951]: Last Updated: Tue Jun 05 14:19:36 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="#[beee28]">Vectors</a>
<LI><a href="#[beed34]">Reset_Handler</a>
<LI><a href="#[1029794]">__scatterload</a>
<LI><a href="#[10296c4]">__scatterload_rt2</a>
<LI><a href="#[1029714]">__scatterload_null</a>
<LI><a href="#[10291e0]">__scatterload_copy</a>
<LI><a href="#[1028d90]">__scatterload_zeroinit</a>
<LI><a href="#[beebb4]">__user_initial_stackheap</a>
<LI><a href="#[fec2c8]">os_clock_interrupt</a>
<LI><a href="#[fec278]">os_set_env</a>
<LI><a href="#[feb998]">SWI_Handler</a>
<LI><a href="#[109a448]">__fplib_config_pureend_doubles</a>
<LI><a href="#[bef36c]">UndefHandler</a>
<LI><a href="#[bef2f4]">PAbtHandler</a>
<LI><a href="#[bef27c]">DAbtHandler</a>
<LI><a href="#[bef204]">IRQHandler</a>
<LI><a href="#[bef18c]">FIQHandler</a>
<LI><a href="#[fd7b4c]">__arm_div4</a>
<LI><a href="#[fd7ad4]">__arm_div8</a>
<LI><a href="#[fd7a58]">__arm_div_large</a>
</UL>
<P>
<H3>
Mutually Recursive functions
</H3><UL>
<LI><a href="#[bef36c]">UndefHandler</a> -> <a href="#[bef36c]">UndefHandler</a><BR>
<LI><a href="#[bef2f4]">PAbtHandler</a> -> <a href="#[bef2f4]">PAbtHandler</a><BR>
<LI><a href="#[bef27c]">DAbtHandler</a> -> <a href="#[bef27c]">DAbtHandler</a><BR>
<LI><a href="#[bef204]">IRQHandler</a> -> <a href="#[bef204]">IRQHandler</a><BR>
<LI><a href="#[bef18c]">FIQHandler</a> -> <a href="#[bef18c]">FIQHandler</a><BR>
</UL>
<BR>
<P><STRONG><a name="[beee28]"></a>Vectors</STRONG> (ARM, 4 bytes, Stack size unknown bytes, str71x.o(Reset), UNUSED)
<P><STRONG><a name="[beed34]"></a>Reset_Handler</STRONG> (ARM, 0 bytes, Stack size unknown bytes, str71x.o(Reset))
<BR>[Address Reference Count : 1]<UL><LI> str71x.o(Reset)
</UL>
<P><STRONG><a name="[fd43b4]"></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="#[fd3a34]">>></a> __rt_entry
<LI><a href="#[1029794]">>></a> __scatterload
</UL>
<P><STRONG><a name="[1029794]"></a>__scatterload</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter))
<BR><BR>[Called By]<UL><LI><a href="#[fd43b4]"><<</a> __main
</UL>
<P><STRONG><a name="[10296c4]"></a>__scatterload_rt2</STRONG> (ARM, 48 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[fd3a34]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[1029714]"></a>__scatterload_null</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<P><STRONG><a name="[10291e0]"></a>__scatterload_copy</STRONG> (ARM, 40 bytes, Stack size unknown bytes, __scatter_copy.o(!!handler_copy), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[10291e0]">>></a> __scatterload_copy
</UL>
<BR>[Called By]<UL><LI><a href="#[10291e0]"><<</a> __scatterload_copy
</UL>
<P><STRONG><a name="[1028d90]"></a>__scatterload_zeroinit</STRONG> (ARM, 44 bytes, Stack size unknown bytes, __scatter_zi.o(!!handler_zi), UNUSED)
<P><STRONG><a name="[10a04c4]"></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="#[10a03f8]"><<</a> __rt_lib_init (via Veneer)
</UL>
<P><STRONG><a name="[b23d54]"></a>LED_A_Init</STRONG> (ARM, 72 bytes, Stack size 0 bytes, blanky.o(.text), UNUSED)
<BR><BR>[Called By]<UL><LI><a href="#[b23b78]"><<</a> init
</UL>
<P><STRONG><a name="[b23cdc]"></a>LED_A_ON</STRONG> (ARM, 24 bytes, Stack size 0 bytes, blanky.o(.text), UNUSED)
<BR><BR>[Called By]<UL><LI><a href="#[b23bec]"><<</a> LED_A_flash
</UL>
<P><STRONG><a name="[b23c64]"></a>LED_A_OFF</STRONG> (ARM, 24 bytes, Stack size 0 bytes, blanky.o(.text), UNUSED)
<BR><BR>[Called By]<UL><LI><a href="#[b23bec]"><<</a> LED_A_flash
</UL>
<P><STRONG><a name="[b23bec]"></a>LED_A_flash</STRONG> (ARM, 36 bytes, Stack size 8 bytes, blanky.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[b23c64]">>></a> LED_A_OFF
<LI><a href="#[b23cdc]">>></a> LED_A_ON
<LI><a href="#[1006fd4]">>></a> os_dly_wait (via Veneer)
</UL>
<P><STRONG><a name="[b23b78]"></a>init</STRONG> (ARM, 212 bytes, Stack size 8 bytes, blanky.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[b23d54]">>></a> LED_A_Init
<LI><a href="#[beb148]">>></a> RCCU_RCLKSourceConfig
<LI><a href="#[beb298]">>></a> RCCU_PLL1Config
<LI><a href="#[ff1bbc]">>></a> os_tsk_delete (via Veneer)
<LI><a href="#[ff1c90]">>></a> os_tsk_create_user (via Veneer)
</UL>
<P><STRONG><a name="[b23b04]"></a>main</STRONG> (ARM, 36 bytes, Stack size 8 bytes, blanky.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="#[ff1ce0]">>></a> os_sys_init_user (via Veneer)
</UL>
<BR>[Address Reference Count : 1]<UL><LI> kernel.o(.text)
</UL>
<P><STRONG><a name="[bd8610]"></a>_ttywrch</STRONG> (ARM, 4 bytes, Stack size 0 bytes, retarget.o(.text), UNUSED)
<P><STRONG><a name="[bd8598]"></a>_sys_exit</STRONG> (ARM, 8 bytes, Stack size 0 bytes, retarget.o(.text), UNUSED)
<BR><BR>[Called By]<UL><LI><a href="#[fd3874]"><<</a> __rt_abort
</UL>
<P><STRONG><a name="[bd4130]"></a>os_idle_demon</STRONG> (ARM, 8 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[ff1ce0]"><<</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="[bd40b8]"></a>os_tmr_call</STRONG> (ARM, 8 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[1015134]"><<</a> os_tmr_tick (via Veneer)
</UL>
<P><STRONG><a name="[bd4038]"></a>os_clock_interrupt0</STRONG> (ARM, 160 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="#[ffc008]">>></a> os_put_rdy_first (via Veneer)
</UL>
<BR>[Address Reference Count : 1]<UL><LI> IRQ_RTX.o(IRQ_Area)
</UL>
<P><STRONG><a name="[bd3fb8]"></a>os_def_interrupt</STRONG> (ARM, 4 bytes, Stack size 0 bytes, rtx_config.o(.text), UNUSED)
<P><STRONG><a name="[bd3f40]"></a>os_tmr_init</STRONG> (ARM, 88 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[ff1ce0]"><<</a> os_sys_init_user (via Veneer)
</UL>
<P><STRONG><a name="[bd3ec4]"></a>os_tmr_reload</STRONG> (ARM, 4 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[fea4e8]"><<</a> os_clock_demon (via Veneer)
</UL>
<P><STRONG><a name="[b20490]"></a>os_tmr_force_irq</STRONG> (ARM, 24 bytes, Stack size 0 bytes, rtx_config.o(.text), UNUSED)
<P><STRONG><a name="[b20448]"></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="#[fea4e8]"><<</a> os_clock_demon (via Veneer)
</UL>
<P><STRONG><a name="[b203d0]"></a>os_tmr_inspect_ovf</STRONG> (ARM, 16 bytes, Stack size 0 bytes, rtx_config.o(.text), UNUSED)
<P><STRONG><a name="[b2035c]"></a>__SWI_7</STRONG> (ARM, 36 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR>[Address Reference Count : 1]<UL><LI> SWI_Table.o(SWI_TABLE)
</UL>
<P><STRONG><a name="[b202e4]"></a>tsk_lock</STRONG> (ARM, 16 bytes, Stack size 8 bytes, rtx_config.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = tsk_lock</UL>
<BR>[Called By]<UL><LI><a href="#[ff1bbc]"><<</a> os_tsk_delete (via Veneer)
<LI><a href="#[ff1c90]"><<</a> os_tsk_create_user (via Veneer)
<LI><a href="#[ff1ce0]"><<</a> os_sys_init_user (via Veneer)
<LI><a href="#[1006fd4]"><<</a> os_dly_wait (via Veneer)
</UL>
<P><STRONG><a name="[b2026c]"></a>tsk_unlock</STRONG> (ARM, 24 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[ff1bbc]"><<</a> os_tsk_delete (via Veneer)
<LI><a href="#[ff1c90]"><<</a> os_tsk_create_user (via Veneer)
<LI><a href="#[ff1ce0]"><<</a> os_sys_init_user (via Veneer)
<LI><a href="#[1006fd4]"><<</a> os_dly_wait (via Veneer)
</UL>
<P><STRONG><a name="[b201f4]"></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="#[1003a28]">>></a> _init_box (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[ff1ce0]"><<</a> os_sys_init_user (via Veneer)
</UL>
<P><STRONG><a name="[b20178]"></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="#[ff1c90]"><<</a> os_tsk_create_user (via Veneer)
</UL>
<P><STRONG><a name="[b20100]"></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="#[ff1bbc]"><<</a> os_tsk_delete (via Veneer)
</UL>
<P><STRONG><a name="[b20084]"></a>os_alloc_TMR</STRONG> (ARM, 8 bytes, Stack size 0 bytes, rtx_config.o(.text), UNUSED)
<P><STRONG><a name="[bf3c7c]"></a>os_free_TMR</STRONG> (ARM, 8 bytes, Stack size 0 bytes, rtx_config.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[1015134]"><<</a> os_tmr_tick (via Veneer)
</UL>
<P><STRONG><a name="[bf3c00]"></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="#[ff1c90]"><<</a> os_tsk_create_user (via Veneer)
<LI><a href="#[ff1ce0]"><<</a> os_sys_init_user (via Veneer)
</UL>
<P><STRONG><a name="[bf3b8c]"></a>__SWI_0</STRONG> (ARM, 168 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="#[bd53f4]">>></a> os_stk_overflow
<LI><a href="#[fef8bc]">>></a> tstclrb
</UL>
<BR>[Address Reference Count : 1]<UL><LI> SWI_Table.o(SWI_TABLE)
</UL>
<P><STRONG><a name="[bf3b10]"></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="#[ffc058]">>></a> os_put_prio (via Veneer)
<LI><a href="#[ffc294]">>></a> os_get_first (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[fea4e8]"><<</a> os_clock_demon (via Veneer)
</UL>
<P><STRONG><a name="[beebb4]"></a>__user_initial_stackheap</STRONG> (ARM, 0 bytes, Stack size unknown bytes, str71x.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[fd30e4]"><<</a> __user_setup_stackheap
</UL>
<P><STRONG><a name="[fd7ff4]"></a>__I_use_semihosting</STRONG> (ARM, 0 bytes, Stack size 0 bytes, use_no_semi.o(.text), UNUSED)
<P><STRONG><a name="[fd7fa4]"></a>__use_no_semihosting_swi</STRONG> (ARM, 4 bytes, Stack size 0 bytes, use_no_semi.o(.text), UNUSED)
<P><STRONG><a name="[fd78c0]"></a>__aeabi_idiv</STRONG> (ARM, 0 bytes, Stack size 0 bytes, aeabi_sdiv.o(.text), UNUSED)
<P><STRONG><a name="[fd7844]"></a>__aeabi_idivmod</STRONG> (ARM, 364 bytes, Stack size 0 bytes, aeabi_sdiv.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[fd2c60]">>></a> __aeabi_idiv0
</UL>
<P><STRONG><a name="[fd4af4]"></a>__use_two_region_memory</STRONG> (ARM, 4 bytes, Stack size 0 bytes, stkheap2.o(.text), UNUSED)
<P><STRONG><a name="[fd4a6c]"></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="#[fd1d88]">>></a> __rt_stackheap_storage
<LI><a href="#[fd30e4]">>></a> __user_setup_stackheap
</UL>
<BR>[Called By]<UL><LI><a href="#[fd3a34]"><<</a> __rt_entry
</UL>
<P><STRONG><a name="[fd49e4]"></a>__rt_heap_extend</STRONG> (ARM, 24 bytes, Stack size 8 bytes, stkheap2.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[fd4bc8]">>></a> __user_heap_extend (Weak Reference)
</UL>
<P><STRONG><a name="[fd3a34]"></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="#[fd0498]">>></a> exit (via BX)
<LI><a href="#[fd4a6c]">>></a> __rt_stackheap_init
<LI><a href="#[109e76c]">>></a> _platform_post_lib_init
<LI><a href="#[109ebc0]">>></a> _platform_post_stackheap_init
<LI><a href="#[10a03f8]">>></a> __rt_lib_init (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[fd43b4]"><<</a> __main
<LI><a href="#[10296c4]"><<</a> __scatterload_rt2
</UL>
<P><STRONG><a name="[fd38ec]"></a>__rt_exit</STRONG> (ARM, 20 bytes, Stack size 8 bytes, kernel.o(.text))
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -