当前位置:   article > 正文

OpenRisc-61-烧写orpmon到ML501的SPI Flash并启动linux_riscv elf 烧到flash

riscv elf 烧到flash

引言

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


  1. // Boot from 0xe0000100
  2. `define OR1200_BOOT_PCREG_DEFAULT 30'h3800003f
  3. `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:

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/577681
推荐阅读
相关标签
  

闽ICP备14008679号