博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
OpenRisc-52-run openrisc&orpmon on ml501 board
阅读量:6624 次
发布时间:2019-06-25

本文共 2784 字,大约阅读时间需要 9 分钟。

引言

之前关于openrisc的内容,几乎都是基于opencores官方的ordb2a那个开发板的,但是,实际情况是有那个板子的人不是很多,所以目前我在做一个与之类似的板子,并且很快就会跟大家见面,这是后话。

在新做的板子出来之前,本小节我们先在xilinx ml501板子上跑一下openrisc和orpmon。

 

1,实验准备

1>熟悉开发板

ML501是xilinx比较老的一款FPGA开发板,在最开始,如果对这个板子不是很熟悉的话,可以先参考一下相关文档,链接如下:

1,Getting Started with ML501 Demonstrations

2,Restoring ML501 Demonstration Images:
3,Xilinx ML501 Stand-Alone Applications

 

2>准备opencores提供的Pre-built image for SPI flash

 

下载orpsoc-ml501-66MHz.mcs文件,这个文件里面包含FPGA的配置信息,也包含orpmon软件信息。

 

3>准备USB转串口线

由于我们需要查看ML501的串口输出,但是目前很少有电脑上还有串口,所以就需要一条转换线,当然需要安装USB转串口的驱动程序才能使用。

 

4>运行ml501的demo程序和Stand-Alone Applications

在ML501出厂时,板子的CF card,SPI flash,platform Flash,,liner flash里面都是有数据的,可以根据相关文档直接运行的,如果你的flash里面没有,可以restore,方法上面已经给出链接了,不再赘述。

做这些测试程序的目的有两个,其一是熟悉开发板,其二就是确定USB转串口线是否正常工作,因为在运行测试程序时,通过PC机上的串口工具是可以看到打印信息的。

 

2,实验步骤

1>安装xilinx的EDA工具,尤其是iMPACT。

2>打开iMPACT 设置:Edit menu -> Preferences, and in the Configuration Preferences category, set the SPI Byte Swap option to Ignore Setting.

3>初始化JTAG chain并增加SPI flash(选择之前下载的orpsoc-ml501-66MHz.mcs文件)

4>右击SPI flash->program

需要注意的是模式选择一定要正确:MODE[2:0] = 001。

 

3,实验结果

program的过程需要大概几分钟的时间,在显示“program successded”之后,我们再断电,上电。

打开并配置串口工具,就可以看到orpmon的启动结果了,如下所示:

可见这时orpmon已经启动了,键入help可以看到帮助信息,令人沮丧的是没有换行,看起来有点不舒服,How annoying!

下面是稍作整理的help信息:

 

 

Xilinx ML501> helpic_enable           - enable instruction cacheic_disable            - disable instruction cachedc_enable                       - enable data cachedc_disable                      - disable data cachemfspr      
- show SPRmtspr
- set SPRdm
[
] - display 32-bit memory location(s)pm
[
]
- patch 32-bit memory location(s)ram_test
[
] - run a simple RAM testbetter_ram_test
- run a better RAM testcrc [
[
[
]]] - Calculates a 32-bit CRC on specified memory regiondhry [
] - run dhrystonecoremark [
] [
] - run coremark, mode: p - performance run, o - profile run, default - validation runtftp_conf [
[
[
]]] - TFTP configurationtboot [
] - Bootstrap image downloaded via tftpsdboot [
] - Read image from SD-CARDhelp - shows this helpCPU infoFrequency 66MHzInstruction cache: 32kB (BS: 32 Sets: 1024)Data cache: 32kB (BS: 32 Sets: 1024)Info: Stack section addr 0x23c60Build tag: Wed Jun 1 13:30:21 CEST 2011Xilinx ML501>

 

4,小结

本小节我们在ML501的板子上运行了openrisc和orpmon,enjoy!

 

5,future work

1>boot linux

通过上面的命令,我们可以预测,使用orpmon可以通过tftp将linux的镜像经网口download到板子上,这样,我们就可以启动linux了!

2>综合编译orpsoc & orpmon for ml501

上面的内容使用的是opencores提供的实现弄好的文件,但是这是远远不够的,因为我们要对ORPSoC进行修改,所以就需要创建orpsoc的ml501的ISE 工程,自己综合,生成mcs文件。当然可能需要重新编译orpmon。

关于这方面的内容请参考:

Programming the SPI flash memory:

Loading and executing a program:

 

ORPSoC User Guide的第6章:

 

上面的文档中有关于ml501的ORPSoC RTL工程的搭建,综合,以及如何将软件和FPGA硬件信息整合成一个mcs文件的操作步骤。

 

 

 

你可能感兴趣的文章
【WebService】使用jaxb完成对象和xml的转换
查看>>
如何去除My97 DatePicker控件上右键弹出官网的链接 - 如何debug混淆过的代码
查看>>
多文档
查看>>
输入5个学生的信息(包括学号,姓名,英语成绩,计算机语言成绩和数据库成绩), 统计各学生的总分,然后将学生信息和统计结果存入test.txt文件中...
查看>>
BZOJ2337 [HNOI2011]XOR和路径
查看>>
C# 该行已经属于另一个表 ...
查看>>
android 避免线程的重复创建(HandlerThread、线程池)
查看>>
手游-放开那三国socket协议分析
查看>>
SQL Lazy Spool Eager Spool
查看>>
type的解释
查看>>
Windows Phone 8 开发环境搭建
查看>>
2017:IDC市场规模将持续增长 增速放缓
查看>>
从自动驾驶到学习机器学习:解读2017科技发展的15大趋势
查看>>
SinoBBD探索"一体化"大数据创新发展
查看>>
互联网金融带来新机遇 数据合规性不容忽视
查看>>
智能家庭本周锋闻:专注跨界100年
查看>>
在Linux中永久并安全删除文件和目录的方法
查看>>
全民直播时代 内容监管还得靠技术
查看>>
10款Web开发最佳的Python框架
查看>>
c++ 类的对象与指针
查看>>