OpenRisc-61-烧写orpmon到ML501的SPI Flash并启动linux

本文介绍了如何将ORPSoC配置到FPGA,通过SPI Flash启动orpmon,然后通过tftp下载Linux镜像,最终在ML501开发板上实现Linux的自动运行。详细步骤包括FPGA配置文件生成、orpmon软件编译、SPI Flash文件格式化、iMPACT烧录、启动orpmon、设置tftp server等。
摘要由CSDN通过智能技术生成

引言

前面,我们已经实现用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:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值