引言
前面,我们已经实现用or32-elf-gdb将vmlinux烧到ML501上的DDR2SDRAM,并成功启动了linux,如有疑问请参考(http://blog.csdn.net/rill_zhen/article/details/17142327)。
采用gdb的方式适合在调试和开发过程中,由于在项目开发调试过程中,需要频繁的修改和调试代码,所以使用gdb无疑是最好的方式。但是,采用gdb直接将elf文件直接烧到RAM的方式,是断电不保存的,要想让程序运行的话,每次上电之后都需要重新操作一遍,这对于项目完成之后,显然是不行的。这时就需要将软件固化到非易失性设备了。
本小节就来对ML501 SPI Flash进行烧写,实现程序的自动运行。
1,基本思想
首先配置ML501开发板的启动模式为从SPI Flash启动,将ORPSoC配置到FPGA,ORPSoC选择从bootrom启动,bootrom读取SPI Flash中的软件内容(orpmon)到RAM,然后执行orpmon,然后orpmon通过tftp下载linux镜像,最终启动linux。
2,操作步骤
本实验的基础采用(http://blog.csdn.net/rill_zhen/article/details/17142327)中的ORPSoC和orpmon以及linux。
此外还要注意以下几点:
检查一下ORPSoC的启动地址是否为从bootrom启动。
or1200_defines.v:
// Boot from 0xe0000100
`define OR1200_BOOT_PCREG_DEFAULT 30'h3800003f
`define OR1200_BOOT_ADR 32'he0000100
正确生成针对ML501的bootrom.v,如有疑问请参考( http://blog.csdn.net/rill_zhen/article/details/16880801)。
确认没有问题之后,我们需要对ORPSoC进行以下修改:
1>FPGA配置文件的生成
a,使能SPI模块
由于针对ML501板子的ORPSoC中,默认情况下SPI Flash是关闭的,所以我们在综合之前要使能之。
orpsoc-defines.v: