AMD为MicroBlaze提供Boot Loader,比如SREC Boot Loader。它能将代码从QSPI Flash搬移到目标存储器(多半是DRAM)运行,使MicroBlaze运行大程序成为可能。
如果MicroBlaze的Block Design设计有问题,比如Block Design设计中把DRAM链接到了DP(外设)端口,DRAM不能正常运行程序,也会导致Boot Loader运行失败。建议在运行Boot Loader之前,先测试DRAM运行程序,是否正常。
Boot Loader运行时,假设MicroBlaze刚退出复位,系统中所有设置处于复位之后的默认状态。如果MicroBlaze运行了其它程序,可能使MicroBlaze的状态改变,可能导致问题。比如有程序使能了定时器中断,会定时产生中断。如果Boot Loader在运行过程中,硬件产生了中断,而Boot Loader又不能处理,则可能导致系统进入异常状态。 因此,建议在Boot Loader中增加下列代码,关闭中断处理、关闭cache等。
Xil_ExceptionDisable();
Xil_DCacheFlush( );
Xil_DCacheDisable();
Xil_ICacheDisable();
使用Boot Loader时,建议的调试步骤如下: