📄 spi_main.htm
字号:
<!doctype html public "-//w3c//dtd html 4.0 transitional//en">
<html><head>
<title>Static Call Graph - [C:\Documents and Settings\Magicoe\桌面\光盘\LPC24XX_KEIL代码包\14-SPI\SPI_Main\SPI_Main.axf]</title></head>
<body><HR>
<H1>Static Call Graph for image C:\Documents and Settings\Magicoe\桌面\光盘\LPC24XX_KEIL代码包\14-SPI\SPI_Main\SPI_Main.axf</H1><HR>
<BR><P>#<CALLGRAPH># ARM Linker, RVCT3.1 [Build 919]: Last Updated: Wed Apr 16 10:08:39 2008
<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="#[cc25d8]">Reset_Handler</a>
<LI><a href="#[cc2620]">__user_initial_stackheap</a>
<LI><a href="#[cc20a8]">SoftwareInterrupt</a>
<LI><a href="#[cc2060]">IntEnable</a>
<LI><a href="#[cc2018]">IntDisable</a>
<LI><a href="#[cc28a8]">Undef_Handler</a>
<LI><a href="#[cc2860]">SWI_Handler</a>
<LI><a href="#[cc2818]">PAbt_Handler</a>
<LI><a href="#[cc27d0]">DAbt_Handler</a>
<LI><a href="#[cc2788]">IRQ_Handler</a>
<LI><a href="#[cc2740]">FIQ_Handler</a>
<LI><a href="#[cc2210]">IRQDisable</a>
<LI><a href="#[cc21c8]">IRQEnable</a>
<LI><a href="#[cc2180]">FIQDisable</a>
<LI><a href="#[cc2138]">FIQEnable</a>
</UL>
</UL>
<P>
<H3>
Mutually Recursive functions
</H3> <LI><a href="#[cc28a8]">Undef_Handler</a> ⇒ <a href="#[cc28a8]">Undef_Handler</a><BR>
<LI><a href="#[cc2860]">SWI_Handler</a> ⇒ <a href="#[cc2860]">SWI_Handler</a><BR>
<LI><a href="#[cc2818]">PAbt_Handler</a> ⇒ <a href="#[cc2818]">PAbt_Handler</a><BR>
<LI><a href="#[cc27d0]">DAbt_Handler</a> ⇒ <a href="#[cc27d0]">DAbt_Handler</a><BR>
<LI><a href="#[cc2788]">IRQ_Handler</a> ⇒ <a href="#[cc2788]">IRQ_Handler</a><BR>
<LI><a href="#[cc2740]">FIQ_Handler</a> ⇒ <a href="#[cc2740]">FIQ_Handler</a><BR>
</UL>
<P>
<H3>
Function Pointers
</H3><UL>
<LI><a href="#[cc25d8]">Reset_Handler</a>
<LI><a href="#[cc28a8]">Undef_Handler</a>
<LI><a href="#[cc2860]">SWI_Handler</a>
<LI><a href="#[cc2818]">PAbt_Handler</a>
<LI><a href="#[cc27d0]">DAbt_Handler</a>
<LI><a href="#[cc2788]">IRQ_Handler</a>
<LI><a href="#[cc2740]">FIQ_Handler</a>
<LI><a href="#[cbd5a0]">__main</a>
<LI><a href="#[cba490]">__ARM_get_argv</a>
<LI><a href="#[cbf8e0]">main</a>
<LI><a href="#[cbae40]">__I_use_semihosting</a>
<LI><a href="#[cc2210]">IRQDisable</a>
<LI><a href="#[cc21c8]">IRQEnable</a>
<LI><a href="#[cc2180]">FIQDisable</a>
<LI><a href="#[cc2138]">FIQEnable</a>
</UL>
<P>
<H3>
Global Symbols
</H3>
<P><STRONG><a name="[cc25d8]"></a>Reset_Handler</STRONG> (ARM, 0 bytes, Stack size unknown bytes, startup.o(RESET))
<BR><BR>[Stack]<UL><LI>Max Depth = 8 + Unknown Stack Size
<LI>Call Chain = Reset_Handler ⇒ TargetResetInit
</UL>
<BR>[Calls]<UL><LI><a href="#[cc2590]">>></a> TargetResetInit
</UL>
<BR>[Address Reference Count : 1]<UL><LI> startup.o(RESET)
</UL>
<P><STRONG><a name="[cbd5a0]"></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="#[cb7dc0]">>></a> __scatterload
<LI><a href="#[cbd2e0]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[cb7dc0]"></a>__scatterload</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter))
<BR><BR>[Called By]<UL><LI><a href="#[cbd5a0]">>></a> __main
</UL>
<P><STRONG><a name="[cb7d78]"></a>__scatterload_rt2</STRONG> (ARM, 52 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[cbd2e0]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[cb7d30]"></a>__scatterload_null</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<P><STRONG><a name="[cb7af0]"></a>__scatterload_copy</STRONG> (ARM, 40 bytes, Stack size unknown bytes, __scatter_copy.o(!!handler_copy), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[cb7af0]">>></a> __scatterload_copy
</UL>
<BR>[Called By]<UL><LI><a href="#[cb7af0]">>></a> __scatterload_copy
</UL>
<P><STRONG><a name="[cb7988]"></a>__scatterload_zeroinit</STRONG> (ARM, 44 bytes, Stack size unknown bytes, __scatter_zi.o(!!handler_zi), UNUSED)
<P><STRONG><a name="[cbbd90]"></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="#[cbbd00]">>></a> __rt_lib_init (via Veneer)
</UL>
<P><STRONG><a name="[cc2da8]"></a>init_VIC</STRONG> (ARM, 88 bytes, Stack size 0 bytes, irq.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[cc2590]">>></a> TargetResetInit
</UL>
<P><STRONG><a name="[cc2d60]"></a>install_irq</STRONG> (ARM, 92 bytes, Stack size 8 bytes, irq.o(.text), UNUSED)
<BR><BR>[Called By]<UL><LI><a href="#[cc0588]">>></a> init_timer
</UL>
<P><STRONG><a name="[cc2620]"></a>__user_initial_stackheap</STRONG> (ARM, 0 bytes, Stack size unknown bytes, startup.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[cbccb8]">>></a> __user_setup_stackheap
</UL>
<P><STRONG><a name="[cc1518]"></a>TargetInit</STRONG> (ARM, 4 bytes, Stack size 0 bytes, target.o(.text), UNUSED)
<P><STRONG><a name="[cc14d0]"></a>GPIOResetInit</STRONG> (ARM, 120 bytes, Stack size 0 bytes, target.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[cc2590]">>></a> TargetResetInit
</UL>
<P><STRONG><a name="[cc1488]"></a>ConfigurePLL</STRONG> (ARM, 308 bytes, Stack size 0 bytes, target.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[cc2590]">>></a> TargetResetInit
</UL>
<P><STRONG><a name="[cc2590]"></a>TargetResetInit</STRONG> (ARM, 84 bytes, Stack size 8 bytes, target.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = TargetResetInit
</UL>
<BR>[Calls]<UL><LI><a href="#[cc1488]">>></a> ConfigurePLL
<LI><a href="#[cc14d0]">>></a> GPIOResetInit
<LI><a href="#[cc2da8]">>></a> init_VIC
</UL>
<BR>[Called By]<UL><LI><a href="#[cc25d8]">>></a> Reset_Handler
</UL>
<P><STRONG><a name="[cc0738]"></a>delayMs</STRONG> (ARM, 176 bytes, Stack size 0 bytes, timer.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[cbf970]">>></a> SPI0_Test
</UL>
<P><STRONG><a name="[cc06f0]"></a>Timer0Handler</STRONG> (ARM, 84 bytes, Stack size 8 bytes, timer.o(.text), UNUSED)
<P><STRONG><a name="[cc06a8]"></a>Timer1Handler</STRONG> (ARM, 104 bytes, Stack size 8 bytes, timer.o(.text), UNUSED)
<P><STRONG><a name="[cc0660]"></a>enable_timer</STRONG> (ARM, 40 bytes, Stack size 0 bytes, timer.o(.text), UNUSED)
<P><STRONG><a name="[cc0618]"></a>disable_timer</STRONG> (ARM, 40 bytes, Stack size 0 bytes, timer.o(.text), UNUSED)
<P><STRONG><a name="[cc05d0]"></a>reset_timer</STRONG> (ARM, 48 bytes, Stack size 0 bytes, timer.o(.text), UNUSED)
<P><STRONG><a name="[cc0588]"></a>init_timer</STRONG> (ARM, 184 bytes, Stack size 16 bytes, timer.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[cc2d60]">>></a> install_irq
</UL>
<P><STRONG><a name="[cbf9b8]"></a>SegDisplay</STRONG> (ARM, 112 bytes, Stack size 16 bytes, spi_main.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = SegDisplay
</UL>
<BR>[Calls]<UL><LI><a href="#[cbf850]">>></a> SPISend
</UL>
<BR>[Called By]<UL><LI><a href="#[cbf970]">>></a> SPI0_Test
</UL>
<P><STRONG><a name="[cbf970]"></a>SPI0_Test</STRONG> (ARM, 144 bytes, Stack size 32 bytes, spi_main.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 48<LI>Call Chain = SPI0_Test ⇒ SegDisplay
</UL>
<BR>[Calls]<UL><LI><a href="#[cbf9b8]">>></a> SegDisplay
<LI><a href="#[cc0738]">>></a> delayMs
</UL>
<BR>[Called By]<UL><LI><a href="#[cbf8e0]">>></a> main
</UL>
<P><STRONG><a name="[cbf928]"></a>SegPort</STRONG> (ARM, 44 bytes, Stack size 0 bytes, spi_main.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[cbf8e0]">>></a> main
</UL>
<P><STRONG><a name="[cbf8e0]"></a>main</STRONG> (ARM, 24 bytes, Stack size 8 bytes, spi_main.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 56<LI>Call Chain = main ⇒ SPI0_Test ⇒ SegDisplay
</UL>
<BR>[Calls]<UL><LI><a href="#[cbf898]">>></a> SPIInit
<LI><a href="#[cbf928]">>></a> SegPort
<LI><a href="#[cbf970]">>></a> SPI0_Test
</UL>
<BR>[Address Reference Count : 1]<UL><LI> kernel.o(.text)
</UL>
<P><STRONG><a name="[cbec18]"></a>SPI0Handler</STRONG> (ARM, 148 bytes, Stack size 12 bytes, spi.o(.text), UNUSED)
<P><STRONG><a name="[cbf898]"></a>SPIInit</STRONG> (ARM, 84 bytes, Stack size 0 bytes, spi.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[cbf8e0]">>></a> main
</UL>
<P><STRONG><a name="[cbf850]"></a>SPISend</STRONG> (ARM, 88 bytes, Stack size 0 bytes, spi.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[cbf9b8]">>></a> SegDisplay
</UL>
<P><STRONG><a name="[cbebd0]"></a>SPIReceiveByte</STRONG> (ARM, 48 bytes, Stack size 0 bytes, spi.o(.text), UNUSED)
<BR><BR>[Called By]<UL><LI><a href="#[cbeb88]">>></a> SPIReceive
</UL>
<P><STRONG><a name="[cbeb88]"></a>SPIReceive</STRONG> (ARM, 52 bytes, Stack size 12 bytes, spi.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[cbebd0]">>></a> SPIReceiveByte
</UL>
<P><STRONG><a name="[cbd870]"></a>__use_two_region_memory</STRONG> (ARM, 4 bytes, Stack size 0 bytes, stkheap2.o(.text), UNUSED)
<P><STRONG><a name="[cbd828]"></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="#[cbc848]">>></a> __rt_stackheap_storage
<LI><a href="#[cbccb8]">>></a> __user_setup_stackheap
</UL>
<BR>[Called By]<UL><LI><a href="#[cbd2e0]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[cbd7e0]"></a>__rt_heap_extend</STRONG> (ARM, 24 bytes, Stack size 8 bytes, stkheap2.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[cbd708]">>></a> __user_heap_extend (Weak Reference)
</UL>
<P><STRONG><a name="[cbd2e0]"></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="#[cbb178]">>></a> _platform_post_lib_init
<LI><a href="#[cbb2e8]">>></a> _platform_post_stackheap_init
<LI><a href="#[cbbd00]">>></a> __rt_lib_init (via Veneer)
<LI><a href="#[cbc180]">>></a> exit (via BX)
<LI><a href="#[cbd828]">>></a> __rt_stackheap_init
</UL>
<BR>[Called By]<UL><LI><a href="#[cb7d78]">>></a> __scatterload_rt2
<LI><a href="#[cbd5a0]">>></a> __main
</UL>
<P><STRONG><a name="[cbd298]"></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="#[cbbcb8]">>></a> __rt_lib_shutdown (via Veneer)
</UL>
<BR>[Called By]<UL><LI><a href="#[cbc180]">>></a> exit (via Veneer)
</UL>
<P><STRONG><a name="[cbd250]"></a>__rt_abort</STRONG> (ARM, 8 bytes, Stack size 0 bytes, kernel.o(.text), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[cbc690]">>></a> _sys_exit
</UL>
<P><STRONG><a name="[cbccb8]"></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="#[cbc3b8]">>></a> __user_perproc_libspace
<LI><a href="#[cc2620]">>></a> __user_initial_stackheap
</UL>
<BR>[Called By]<UL><LI><a href="#[cbd828]">>></a> __rt_stackheap_init
</UL>
<P><STRONG><a name="[cbc848]"></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="#[cbd828]">>></a> __rt_stackheap_init
</UL>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -