📄 mci_ram.htm
字号:
<!doctype html public "-//w3c//dtd html 4.0 transitional//en">
<html><head>
<title>Static Call Graph - [.\obj\MCI_RAM.axf]</title></head>
<body><HR>
<H1>Static Call Graph for image .\obj\MCI_RAM.axf</H1><HR>
<BR><P>#<CALLGRAPH># ARM Linker, RVCT3.0 [Build 947]: Last Updated: Tue Jan 08 23:00:02 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="#[bde494]">Reset_Handler</a>
<LI><a href="#[fddd50]">__scatterload</a>
<LI><a href="#[fddc80]">__scatterload_rt2</a>
<LI><a href="#[fddcd0]">__scatterload_null</a>
<LI><a href="#[fdd63c]">__scatterload_copy</a>
<LI><a href="#[fdd08c]">__scatterload_zeroinit</a>
<LI><a href="#[bde298]">__user_initial_stackheap</a>
<LI><a href="#[b20784]">MCI_ReadFifo</a>
<LI><a href="#[b20708]">MCI_WriteFifo</a>
<LI><a href="#[bdf594]">SoftwareInterrupt</a>
<LI><a href="#[bdf51c]">IntEnable</a>
<LI><a href="#[bdf4a4]">IntDisable</a>
<LI><a href="#[100bb5c]">__fplib_config_pureend_doubles</a>
<LI><a href="#[bdf77c]">IRQDisable</a>
<LI><a href="#[bdf704]">IRQEnable</a>
<LI><a href="#[bdf68c]">FIQDisable</a>
<LI><a href="#[bdf614]">FIQEnable</a>
<LI><a href="#[bdea40]">Undef_Handler</a>
<LI><a href="#[bde9c8]">SWI_Handler</a>
<LI><a href="#[bde94c]">PAbt_Handler</a>
<LI><a href="#[bde8d0]">DAbt_Handler</a>
<LI><a href="#[bde858]">IRQ_Handler</a>
<LI><a href="#[bde7e0]">FIQ_Handler</a>
</UL>
<P>
<H3>
Mutually Recursive functions
</H3><UL>
<LI><a href="#[bdea40]">Undef_Handler</a> -> <a href="#[bdea40]">Undef_Handler</a><BR>
<LI><a href="#[bde9c8]">SWI_Handler</a> -> <a href="#[bde9c8]">SWI_Handler</a><BR>
<LI><a href="#[bde94c]">PAbt_Handler</a> -> <a href="#[bde94c]">PAbt_Handler</a><BR>
<LI><a href="#[bde8d0]">DAbt_Handler</a> -> <a href="#[bde8d0]">DAbt_Handler</a><BR>
<LI><a href="#[bde858]">IRQ_Handler</a> -> <a href="#[bde858]">IRQ_Handler</a><BR>
<LI><a href="#[bde7e0]">FIQ_Handler</a> -> <a href="#[bde7e0]">FIQ_Handler</a><BR>
</UL>
<BR>
<P><STRONG><a name="[bde494]"></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="#[bde418]">>></a> TargetResetInit
</UL>
<BR>[Address Reference Count : 1]<UL><LI> startup.o(RESET)
</UL>
<P><STRONG><a name="[c17264]"></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="#[c16764]">>></a> __rt_entry
<LI><a href="#[fddd50]">>></a> __scatterload
</UL>
<P><STRONG><a name="[fddd50]"></a>__scatterload</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter))
<BR><BR>[Called By]<UL><LI><a href="#[c17264]"><<</a> __main
</UL>
<P><STRONG><a name="[fddc80]"></a>__scatterload_rt2</STRONG> (ARM, 48 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[c16764]">>></a> __rt_entry
</UL>
<P><STRONG><a name="[fddcd0]"></a>__scatterload_null</STRONG> (ARM, 0 bytes, Stack size unknown bytes, __scatter.o(!!!scatter), UNUSED)
<P><STRONG><a name="[fdd63c]"></a>__scatterload_copy</STRONG> (ARM, 40 bytes, Stack size unknown bytes, __scatter_copy.o(!!handler_copy), UNUSED)
<BR><BR>[Calls]<UL><LI><a href="#[fdd63c]">>></a> __scatterload_copy
</UL>
<BR>[Called By]<UL><LI><a href="#[fdd63c]"><<</a> __scatterload_copy
</UL>
<P><STRONG><a name="[fdd08c]"></a>__scatterload_zeroinit</STRONG> (ARM, 44 bytes, Stack size unknown bytes, __scatter_zi.o(!!handler_zi), UNUSED)
<P><STRONG><a name="[c0f540]"></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="#[c0f474]"><<</a> __rt_lib_init (via Veneer)
</UL>
<P><STRONG><a name="[b27184]"></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="#[b26ab8]">>></a> SD_Set_BusWidth
<LI><a href="#[b26bac]">>></a> MCI_Write_Block
<LI><a href="#[b26c28]">>></a> MCI_Set_MCIClock
<LI><a href="#[b26ca8]">>></a> MCI_Set_BlockLen
<LI><a href="#[b26d28]">>></a> MCI_Set_Address
<LI><a href="#[b26da4]">>></a> MCI_Send_CSD
<LI><a href="#[b26e20]">>></a> MCI_Select_Card
<LI><a href="#[b26e9c]">>></a> MCI_Read_Block
<LI><a href="#[b26f18]">>></a> MCI_Init
<LI><a href="#[b26f90]">>></a> MCI_Check_CID
<LI><a href="#[b27088]">>></a> MCI_CardInit
</UL>
<BR>[Address Reference Count : 1]<UL><LI> kernel.o(.text)
</UL>
<P><STRONG><a name="[b211f4]"></a>MCI_TXEnable</STRONG> (ARM, 48 bytes, Stack size 0 bytes, mci.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b26bac]"><<</a> MCI_Write_Block
</UL>
<P><STRONG><a name="[b21178]"></a>MCI_TXDisable</STRONG> (ARM, 48 bytes, Stack size 0 bytes, mci.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b20d08]"><<</a> MCI_DATA_END_InterruptService
</UL>
<P><STRONG><a name="[b210fc]"></a>MCI_RXEnable</STRONG> (ARM, 48 bytes, Stack size 0 bytes, mci.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b26e9c]"><<</a> MCI_Read_Block
</UL>
<P><STRONG><a name="[b21080]"></a>MCI_RXDisable</STRONG> (ARM, 48 bytes, Stack size 0 bytes, mci.o(.text), UNUSED)
<P><STRONG><a name="[b21004]"></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="#[b20800]"><<</a> MCI_Send_Read_Block
<LI><a href="#[b20880]"><<</a> MCI_Send_Write_Block
<LI><a href="#[b20904]"><<</a> MCI_Send_Stop
<LI><a href="#[b20980]"><<</a> MCI_Send_ACMD_OP_Cond
<LI><a href="#[b20a04]"><<</a> MCI_Send_OP_Cond
<LI><a href="#[b20a84]"><<</a> MCI_Go_Idle_State
<LI><a href="#[b20b04]"><<</a> MCI_Send_ACMD_Bus_Width
<LI><a href="#[b20b88]"><<</a> MCI_Send_ACMD
<LI><a href="#[b20f10]"><<</a> MCI_Send_Status
<LI><a href="#[b26ca8]"><<</a> MCI_Set_BlockLen
<LI><a href="#[b26d28]"><<</a> MCI_Set_Address
<LI><a href="#[b26da4]"><<</a> MCI_Send_CSD
<LI><a href="#[b26e20]"><<</a> MCI_Select_Card
<LI><a href="#[b26f90]"><<</a> MCI_Check_CID
</UL>
<P><STRONG><a name="[b20f8c]"></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="#[b20800]"><<</a> MCI_Send_Read_Block
<LI><a href="#[b20880]"><<</a> MCI_Send_Write_Block
<LI><a href="#[b20904]"><<</a> MCI_Send_Stop
<LI><a href="#[b20980]"><<</a> MCI_Send_ACMD_OP_Cond
<LI><a href="#[b20a04]"><<</a> MCI_Send_OP_Cond
<LI><a href="#[b20a84]"><<</a> MCI_Go_Idle_State
<LI><a href="#[b20b04]"><<</a> MCI_Send_ACMD_Bus_Width
<LI><a href="#[b20b88]"><<</a> MCI_Send_ACMD
<LI><a href="#[b20f10]"><<</a> MCI_Send_Status
<LI><a href="#[b26ca8]"><<</a> MCI_Set_BlockLen
<LI><a href="#[b26d28]"><<</a> MCI_Set_Address
<LI><a href="#[b26da4]"><<</a> MCI_Send_CSD
<LI><a href="#[b26e20]"><<</a> MCI_Select_Card
<LI><a href="#[b26f90]"><<</a> MCI_Check_CID
</UL>
<P><STRONG><a name="[b20f10]"></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="#[b20f8c]">>></a> MCI_SendCmd
<LI><a href="#[b21004]">>></a> MCI_GetCmdResp
</UL>
<BR>[Called By]<UL><LI><a href="#[b20e94]"><<</a> MCI_CheckStatus
</UL>
<P><STRONG><a name="[b20e94]"></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="#[b20f10]">>></a> MCI_Send_Status
</UL>
<BR>[Called By]<UL><LI><a href="#[b26bac]"><<</a> MCI_Write_Block
<LI><a href="#[b26e9c]"><<</a> MCI_Read_Block
</UL>
<P><STRONG><a name="[b20e18]"></a>MCI_CmdProcess</STRONG> (ARM, 212 bytes, Stack size 0 bytes, mci.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b20c04]"><<</a> MCI_IRQHandler
</UL>
<P><STRONG><a name="[b20d94]"></a>MCI_DataErrorProcess</STRONG> (ARM, 212 bytes, Stack size 0 bytes, mci.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b20c04]"><<</a> MCI_IRQHandler
</UL>
<P><STRONG><a name="[b20d08]"></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="#[b21178]">>></a> MCI_TXDisable
</UL>
<BR>[Called By]<UL><LI><a href="#[b20c04]"><<</a> MCI_IRQHandler
</UL>
<P><STRONG><a name="[b20c80]"></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="#[b20708]">>></a> MCI_WriteFifo
<LI><a href="#[b20784]">>></a> MCI_ReadFifo
</UL>
<BR>[Called By]<UL><LI><a href="#[b20c04]"><<</a> MCI_IRQHandler
</UL>
<P><STRONG><a name="[b20c04]"></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="#[b20c80]">>></a> MCI_FIFOInterruptService
<LI><a href="#[b20d08]">>></a> MCI_DATA_END_InterruptService
<LI><a href="#[b20d94]">>></a> MCI_DataErrorProcess
<LI><a href="#[b20e18]">>></a> MCI_CmdProcess
</UL>
<BR>[Address Reference Count : 1]<UL><LI> mci.o(.text)
</UL>
<P><STRONG><a name="[b26c28]"></a>MCI_Set_MCIClock</STRONG> (ARM, 100 bytes, Stack size 0 bytes, mci.o(.text))
<BR><BR>[Called By]<UL><LI><a href="#[b26f18]"><<</a> MCI_Init
<LI><a href="#[b27184]"><<</a> main
</UL>
<P><STRONG><a name="[b20b88]"></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="#[b20f8c]">>></a> MCI_SendCmd
<LI><a href="#[b21004]">>></a> MCI_GetCmdResp
</UL>
<BR>[Called By]<UL><LI><a href="#[b20980]"><<</a> MCI_Send_ACMD_OP_Cond
<LI><a href="#[b20b04]"><<</a> MCI_Send_ACMD_Bus_Width
</UL>
<P><STRONG><a name="[b20b04]"></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="#[b20b88]">>></a> MCI_Send_ACMD
<LI><a href="#[b20f8c]">>></a> MCI_SendCmd
<LI><a href="#[b21004]">>></a> MCI_GetCmdResp
</UL>
<BR>[Called By]<UL><LI><a href="#[b26ab8]"><<</a> SD_Set_BusWidth
</UL>
<P><STRONG><a name="[b26ab8]"></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="#[b20b04]">>></a> MCI_Send_ACMD_Bus_Width
</UL>
<BR>[Called By]<UL><LI><a href="#[b27184]"><<</a> main
</UL>
<P><STRONG><a name="[b26f18]"></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="#[b20690]">>></a> install_irq
<LI><a href="#[b26c28]">>></a> MCI_Set_MCIClock
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -