📄 mci_flash.htm
字号:
<!doctype html public "-//w3c//dtd html 4.0 transitional//en">
<html><head>
<title>Static Call Graph - [.\obj\MCI_Flash.axf]</title></head>
<body><HR>
<H1>Static Call Graph for image .\obj\MCI_Flash.axf</H1><HR>
<BR><P>#<CALLGRAPH># ARM Linker, RVCT3.0 [Build 951]: Last Updated: Tue Mar 18 22:06:40 2008
<BR><P>
<H3>Maximum Stack Usage = 116 bytes + Unknown(Functions without stacksize,Cycles,Untraceable Function Pointers)</H3><H3>
Call chain for Maximum Stack Depth:</H3>
main -> SD_Set_BusWidth -> MCI_Send_ACMD_Bus_Width -> MCI_Send_ACMD -> MCI_SendCmd<P>
<H3>
Functions with no stack information
</H3><UL>
<LI><a href="#[cde4d0]">Reset_Handler</a>
<LI><a href="#[1123aac]">__scatterload</a>
<LI><a href="#[11239dc]">__scatterload_rt2</a>
<LI><a href="#[1123a2c]">__scatterload_null</a>
<LI><a href="#[11234f8]">__scatterload_copy</a>
<LI><a href="#[11230a8]">__scatterload_zeroinit</a>
<LI><a href="#[cde2d4]">__user_initial_stackheap</a>
<LI><a href="#[c2063c]">MCI_ReadFifo</a>
<LI><a href="#[c205c0]">MCI_WriteFifo</a>
<LI><a href="#[cdf5e4]">SoftwareInterrupt</a>
<LI><a href="#[cdf56c]">IntEnable</a>
<LI><a href="#[cdf4f4]">IntDisable</a>
<LI><a href="#[112ea4c]">__fplib_config_pureend_doubles</a>
<LI><a href="#[cdf7cc]">IRQDisable</a>
<LI><a href="#[cdf754]">IRQEnable</a>
<LI><a href="#[cdf6dc]">FIQDisable</a>
<LI><a href="#[cdf664]">FIQEnable</a>
<LI><a href="#[cdea7c]">Undef_Handler</a>
<LI><a href="#[cdea04]">SWI_Handler</a>
<LI><a href="#[cde988]">PAbt_Handler</a>
<LI><a href="#[cde90c]">DAbt_Handler</a>
<LI><a href="#[cde894]">IRQ_Handler</a>
<LI><a href="#[cde81c]">FIQ_Handler</a>
</UL>
<P>
<H3>
Mutually Recursive functions
</H3><UL>
<LI><a href="#[cdea7c]">Undef_Handler</a> -> <a href="#[cdea7c]">Undef_Handler</a><BR>
<LI><a href="#[cdea04]">SWI_Handler</a> -> <a href="#[cdea04]">SWI_Handler</a><BR>
<LI><a href="#[cde988]">PAbt_Handler</a> -> <a href="#[cde988]">PAbt_Handler</a><BR>
<LI><a href="#[cde90c]">DAbt_Handler</a> -> <a href="#[cde90c]">DAbt_Handler</a><BR>
<LI><a href="#[cde894]">IRQ_Handler</a> -> <a href="#[cde894]">IRQ_Handler</a><BR>
<LI><a href="#[cde81c]">FIQ_Handler</a> -> <a href="#[cde81c]">FIQ_Handler</a><BR>
</UL>
<BR>
<P><STRONG><a name="[cde4d0]"></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="#[cde454]">>></a> TargetResetInit
</UL>
<BR>[Address Reference Count : 1]<UL><LI> startup.o(RESET)
</UL>
<P><STRONG><a name="[d16eb0]"></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="#[d16510]">>></a> __rt_entry
<LI><a href="#[1123aac]">>></a> __scatterload
</UL>
<P><STRONG><a name="[1123aac]"></a>__scatterload</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter))
<BR><BR>[Called By]<UL><LI><a href="#[d16eb0]"><<</a> __main
</UL>
<P><STRONG><a name="[11239dc]"></a>__scatterload_rt2</STRONG> (ARM, 48 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[d16510]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[1123a2c]"></a>__scatterload_null</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<P><STRONG><a name="[11234f8]"></a>__scatterload_copy</STRONG> (ARM, 40 bytes, Stack size unknown bytes, __scatter_copy.o(!!handler_copy), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[11234f8]">>></a> __scatterload_copy
</UL>
<BR>[Called By]<UL><LI><a href="#[11234f8]"><<</a> __scatterload_copy
</UL>
<P><STRONG><a name="[11230a8]"></a>__scatterload_zeroinit</STRONG> (ARM, 44 bytes, Stack size unknown bytes, __scatter_zi.o(!!handler_zi), UNUSED)
<P><STRONG><a name="[d10664]"></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="#[d10598]"><<</a> __rt_lib_init (via Veneer)
</UL>
<P><STRONG><a name="[c27104]"></a>main</STRONG> (ARM, 476 bytes, Stack size 16 bytes, mcitest.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 116<LI>Call Chain = main -> SD_Set_BusWidth -> MCI_Send_ACMD_Bus_Width -> MCI_Send_ACMD -> MCI_SendCmd</UL>
<BR>[Calls]<UL><LI><a href="#[c26a38]">>></a> SD_Set_BusWidth
<LI><a href="#[c26b2c]">>></a> MCI_Write_Block
<LI><a href="#[c26ba8]">>></a> MCI_Set_MCIClock
<LI><a href="#[c26c28]">>></a> MCI_Set_BlockLen
<LI><a href="#[c26ca8]">>></a> MCI_Set_Address
<LI><a href="#[c26d24]">>></a> MCI_Send_CSD
<LI><a href="#[c26da0]">>></a> MCI_Select_Card
<LI><a href="#[c26e1c]">>></a> MCI_Read_Block
<LI><a href="#[c26e98]">>></a> MCI_Init
<LI><a href="#[c26f10]">>></a> MCI_Check_CID
<LI><a href="#[c27008]">>></a> MCI_CardInit
</UL>
<BR>[Address Reference Count : 1]<UL><LI> kernel.o(.text)
</UL>
<P><STRONG><a name="[c210ac]"></a>MCI_TXEnable</STRONG> (ARM, 48 bytes, Stack size 0 bytes, mci.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c26b2c]"><<</a> MCI_Write_Block
</UL>
<P><STRONG><a name="[c21030]"></a>MCI_TXDisable</STRONG> (ARM, 48 bytes, Stack size 0 bytes, mci.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c20bc0]"><<</a> MCI_DATA_END_InterruptService
</UL>
<P><STRONG><a name="[c20fb4]"></a>MCI_RXEnable</STRONG> (ARM, 48 bytes, Stack size 0 bytes, mci.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c26e1c]"><<</a> MCI_Read_Block
</UL>
<P><STRONG><a name="[c20f38]"></a>MCI_RXDisable</STRONG> (ARM, 48 bytes, Stack size 0 bytes, mci.o(.text), UNUSED)
<P><STRONG><a name="[c20ebc]"></a>MCI_GetCmdResp</STRONG> (ARM, 360 bytes, Stack size 8 bytes, mci.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 8<LI>Call Chain = MCI_GetCmdResp</UL>
<BR>[Called By]<UL><LI><a href="#[c206b8]"><<</a> MCI_Send_Read_Block
<LI><a href="#[c20738]"><<</a> MCI_Send_Write_Block
<LI><a href="#[c207bc]"><<</a> MCI_Send_Stop
<LI><a href="#[c20838]"><<</a> MCI_Send_ACMD_OP_Cond
<LI><a href="#[c208bc]"><<</a> MCI_Send_OP_Cond
<LI><a href="#[c2093c]"><<</a> MCI_Go_Idle_State
<LI><a href="#[c209bc]"><<</a> MCI_Send_ACMD_Bus_Width
<LI><a href="#[c20a40]"><<</a> MCI_Send_ACMD
<LI><a href="#[c20dc8]"><<</a> MCI_Send_Status
<LI><a href="#[c26c28]"><<</a> MCI_Set_BlockLen
<LI><a href="#[c26ca8]"><<</a> MCI_Set_Address
<LI><a href="#[c26d24]"><<</a> MCI_Send_CSD
<LI><a href="#[c26da0]"><<</a> MCI_Select_Card
<LI><a href="#[c26f10]"><<</a> MCI_Check_CID
</UL>
<P><STRONG><a name="[c20e44]"></a>MCI_SendCmd</STRONG> (ARM, 164 bytes, Stack size 16 bytes, mci.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = MCI_SendCmd</UL>
<BR>[Called By]<UL><LI><a href="#[c206b8]"><<</a> MCI_Send_Read_Block
<LI><a href="#[c20738]"><<</a> MCI_Send_Write_Block
<LI><a href="#[c207bc]"><<</a> MCI_Send_Stop
<LI><a href="#[c20838]"><<</a> MCI_Send_ACMD_OP_Cond
<LI><a href="#[c208bc]"><<</a> MCI_Send_OP_Cond
<LI><a href="#[c2093c]"><<</a> MCI_Go_Idle_State
<LI><a href="#[c209bc]"><<</a> MCI_Send_ACMD_Bus_Width
<LI><a href="#[c20a40]"><<</a> MCI_Send_ACMD
<LI><a href="#[c20dc8]"><<</a> MCI_Send_Status
<LI><a href="#[c26c28]"><<</a> MCI_Set_BlockLen
<LI><a href="#[c26ca8]"><<</a> MCI_Set_Address
<LI><a href="#[c26d24]"><<</a> MCI_Send_CSD
<LI><a href="#[c26da0]"><<</a> MCI_Select_Card
<LI><a href="#[c26f10]"><<</a> MCI_Check_CID
</UL>
<P><STRONG><a name="[c20dc8]"></a>MCI_Send_Status</STRONG> (ARM, 160 bytes, Stack size 32 bytes, mci.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 48<LI>Call Chain = MCI_Send_Status -> MCI_SendCmd</UL>
<BR>[Calls]<UL><LI><a href="#[c20e44]">>></a> MCI_SendCmd
<LI><a href="#[c20ebc]">>></a> MCI_GetCmdResp
</UL>
<BR>[Called By]<UL><LI><a href="#[c20d4c]"><<</a> MCI_CheckStatus
</UL>
<P><STRONG><a name="[c20d4c]"></a>MCI_CheckStatus</STRONG> (ARM, 68 bytes, Stack size 8 bytes, mci.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 56<LI>Call Chain = MCI_CheckStatus -> MCI_Send_Status -> MCI_SendCmd</UL>
<BR>[Calls]<UL><LI><a href="#[c20dc8]">>></a> MCI_Send_Status
</UL>
<BR>[Called By]<UL><LI><a href="#[c26b2c]"><<</a> MCI_Write_Block
<LI><a href="#[c26e1c]"><<</a> MCI_Read_Block
</UL>
<P><STRONG><a name="[c20cd0]"></a>MCI_CmdProcess</STRONG> (ARM, 212 bytes, Stack size 0 bytes, mci.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c20abc]"><<</a> MCI_IRQHandler
</UL>
<P><STRONG><a name="[c20c4c]"></a>MCI_DataErrorProcess</STRONG> (ARM, 212 bytes, Stack size 0 bytes, mci.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c20abc]"><<</a> MCI_IRQHandler
</UL>
<P><STRONG><a name="[c20bc0]"></a>MCI_DATA_END_InterruptService</STRONG> (ARM, 180 bytes, Stack size 4 bytes, mci.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 4<LI>Call Chain = MCI_DATA_END_InterruptService</UL>
<BR>[Calls]<UL><LI><a href="#[c21030]">>></a> MCI_TXDisable
</UL>
<BR>[Called By]<UL><LI><a href="#[c20abc]"><<</a> MCI_IRQHandler
</UL>
<P><STRONG><a name="[c20b38]"></a>MCI_FIFOInterruptService</STRONG> (ARM, 296 bytes, Stack size 8 bytes, mci.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 8 + Unknown Stack Size
<LI>Call Chain = MCI_FIFOInterruptService</UL>
<BR>[Calls]<UL><LI><a href="#[c205c0]">>></a> MCI_WriteFifo
<LI><a href="#[c2063c]">>></a> MCI_ReadFifo
</UL>
<BR>[Called By]<UL><LI><a href="#[c20abc]"><<</a> MCI_IRQHandler
</UL>
<P><STRONG><a name="[c20abc]"></a>MCI_IRQHandler</STRONG> (ARM, 216 bytes, Stack size 32 bytes, mci.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 40 + Unknown Stack Size
<LI>Call Chain = MCI_IRQHandler -> MCI_FIFOInterruptService</UL>
<BR>[Calls]<UL><LI><a href="#[c20b38]">>></a> MCI_FIFOInterruptService
<LI><a href="#[c20bc0]">>></a> MCI_DATA_END_InterruptService
<LI><a href="#[c20c4c]">>></a> MCI_DataErrorProcess
<LI><a href="#[c20cd0]">>></a> MCI_CmdProcess
</UL>
<BR>[Address Reference Count : 1]<UL><LI> mci.o(.text)
</UL>
<P><STRONG><a name="[c26ba8]"></a>MCI_Set_MCIClock</STRONG> (ARM, 100 bytes, Stack size 0 bytes, mci.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[c26e98]"><<</a> MCI_Init
<LI><a href="#[c27104]"><<</a> main
</UL>
<P><STRONG><a name="[c20a40]"></a>MCI_Send_ACMD</STRONG> (ARM, 160 bytes, Stack size 36 bytes, mci.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 52<LI>Call Chain = MCI_Send_ACMD -> MCI_SendCmd</UL>
<BR>[Calls]<UL><LI><a href="#[c20e44]">>></a> MCI_SendCmd
<LI><a href="#[c20ebc]">>></a> MCI_GetCmdResp
</UL>
<BR>[Called By]<UL><LI><a href="#[c20838]"><<</a> MCI_Send_ACMD_OP_Cond
<LI><a href="#[c209bc]"><<</a> MCI_Send_ACMD_Bus_Width
</UL>
<P><STRONG><a name="[c209bc]"></a>MCI_Send_ACMD_Bus_Width</STRONG> (ARM, 156 bytes, Stack size 36 bytes, mci.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 88<LI>Call Chain = MCI_Send_ACMD_Bus_Width -> MCI_Send_ACMD -> MCI_SendCmd</UL>
<BR>[Calls]<UL><LI><a href="#[c20a40]">>></a> MCI_Send_ACMD
<LI><a href="#[c20e44]">>></a> MCI_SendCmd
<LI><a href="#[c20ebc]">>></a> MCI_GetCmdResp
</UL>
<BR>[Called By]<UL><LI><a href="#[c26a38]"><<</a> SD_Set_BusWidth
</UL>
<P><STRONG><a name="[c26a38]"></a>SD_Set_BusWidth</STRONG> (ARM, 124 bytes, Stack size 12 bytes, mci.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 100<LI>Call Chain = SD_Set_BusWidth -> MCI_Send_ACMD_Bus_Width -> MCI_Send_ACMD -> MCI_SendCmd</UL>
<BR>[Calls]<UL><LI><a href="#[c209bc]">>></a> MCI_Send_ACMD_Bus_Width
</UL>
<BR>[Called By]<UL><LI><a href="#[c27104]"><<</a> main
</UL>
<P><STRONG><a name="[c26e98]"></a>MCI_Init</STRONG> (ARM, 336 bytes, Stack size 8 bytes, mci.o(.text))
<BR><BR>[Stack]<UL><LI>Max Depth = 16<LI>Call Chain = MCI_Init -> install_irq</UL>
<BR>[Calls]<UL><LI><a href="#[c20548]">>></a> install_irq
<LI><a href="#[c26ba8]">>></a> MCI_Set_MCIClock
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -