OpenRisc-52-run openrisc&orpmon on ml501 board
引言
之前关于openrisc的内容,几乎都是基于opencores官方的ordb2a那个开发板的,但是,实际情况是有那个板子的人不是很多,所以目前我在做一个与之类似的板子,并且很快就会跟大家见面,这是后话。
在新做的板子出来之前,本小节我们先在xilinx ml501板子上跑一下openrisc和orpmon。
1,实验准备
1>熟悉开发板
ML501是xilinx比较老的一款FPGA开发板,在最开始,如果对这个板子不是很熟悉的话,可以先参考一下相关文档,链接如下:
1,Getting Started with ML501 Demonstrations
http://www.xilinx.com/products/boards/ml501/reference_designs.htm
2,Restoring ML501 Demonstration Images:
http://www.xilinx.com/products/boards/ml501/ml501_12.1/images.htm
3,Xilinx ML501 Stand-Alone Applications
http://www.xilinx.com/products/boards/ml501/ml501_12.1/standalone_apps.htm
2>准备opencores提供的Pre-built image for SPI flash
http://opencores.org/or1k/FPGA_Development_Boards#Xilinx_ML501
下载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> help ic_enable - enable instruction cache ic_disable - disable instruction cache dc_enable - enable data cache dc_disable - disable data cache mfspr <spr_addr> - show SPR mtspr <spr_addr> <value> - set SPR dm <start addr> [<end addr>] - display 32-bit memory location(s) pm <addr> [<stop_addr>] <value> - patch 32-bit memory location(s) ram_test <start_addr> <stop_addr> [<test_no>] - run a simple RAM test better_ram_test <start_addr> <stop_addr> - run a better RAM test crc [<src_addr> [<length> [<init_crc>]]] - Calculates a 32-bit CRC on specified memory region dhry [<num_runs>] - run dhrystone coremark [<mode>] [<iterations>] - run coremark, mode: p - performance run, o - profile run, default - validation run tftp_conf [ <file> [ <srv_ip> [ <src_addr>]]] - TFTP configuration tboot [<image number>] - Bootstrap image downloaded via tftp sdboot [<image number>] - Read image from SD-CARD help - shows this help CPU info Frequency 66MHz Instruction cache: 32kB (BS: 32 Sets: 1024) Data cache: 32kB (BS: 32 Sets: 1024) Info: Stack section addr 0x23c60 Build tag: Wed Jun 1 13:30:21 CEST 2011 Xilinx 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:
http://www.rte.se/blog/blogg-modesty-corex/programming-spi-flash-memory/2.6
Loading and executing a program:
http://www.rte.se/blog/blogg-modesty-corex/loading-and-executing-program/2.7
ORPSoC User Guide的第6章:
http://download.csdn.net/detail/rill_zhen/6378603
上面的文档中有关于ml501的ORPSoC RTL工程的搭建,综合,以及如何将软件和FPGA硬件信息整合成一个mcs文件的操作步骤。
OpenRisc-52-run openrisc&orpmon on ml501 board的更多相关文章
- OpenRISC自定义指令GCC修改
This short tutorial shows how to use the custom instructions defined by OpenRISC architecture. The O ...
- OpenRisc-44-or1200的pipeline整体分析
引言 我们在前面分析了ORPSoC,or1200_top,和or1200_cpu的整体架构,在最近,我们也分析了or1200的pipeline(流水线)中的两级,EX级和IF级. 但是,我们还没有从宏 ...
- orpsocv2 从ROM(bootrom)启动分析--以atlys板子的启动为例子
1 复位后的启动地址 1) 复位后,启动地址在or1200_defines.v最后宏定义,atlys板子的目录:orpsocv2\boards\xilinx\atlys\rtl\verilog\inc ...
- 【嵌入式】FS2410非操作系统外围资源测试
在刚接触FS2410时,其实这个测试也没有多大意义,但是对于以后来说,当一个产品做成功时,产品测试还是一个必须经过的一个阶段,所以这个流程还是有必要走一下! 在非操作系统下,主要进行RTC测试,按键测 ...
- Open Source Software List: The Ultimate List
http://www.datamation.com/open-source/ Accessibility 1. The Accessibility Project The Business Value ...
- ZooKeeper测试笔记
1. 下载ZooKeeper.官网:http://zookeeper.apache.org 下载后解压,假定zookeeper程序目录为/home/test/zookeeper,为陈述方便此目录记为 ...
- Oracle GoldenGate for Oracle 11g to PostgreSQL 9.2.4 Configuration
Installing and setting up Oracle GoldenGate connecting to an Oracle database Also please make sure t ...
- OpenRisc-37-OpenRISC的CPU&core的整体架构分析
引言 前面我们分析了ORPSoC的整体架构,并对其子系统进行了深入的分析和了解.但对于ORPSoC的核心模块or1200_top及其内部的core--or1200_cpu模块却鲜有涉及,算是ORPSo ...
- 系统级性能分析工具perf的介绍与使用[转]
测试环境:Ubuntu16.04(在VMWare虚拟机使用perf top存在无法显示问题) Kernel:3.13.0-32 系统级性能优化通常包括两个阶段:性能剖析(performance pro ...
随机推荐
- oracle 存储过程编辑 卡死
一.可用SYS登录, 二.查锁session_ID查找存储过程OPERATIONDATA_IMP被哪些session锁住而无法编译select * FROM dba_ddl_locks where n ...
- UML中的六大关系
转自:http://www.cnblogs.com/shengtianlong/archive/2010/10/23/1858953.html UML定义的关系主要有六种:依赖.类属.关联.实现.聚合 ...
- linux第四周作业
一.用户态内核态与中断 1.库函数把内核调用封装起来. 2.区分内核态和用户态是为了让系统更稳定.Linux里吧用户态定位3级,把内核态定位0级. 3.中断处理就是从用户态进入内核态的主要方法,系统调 ...
- C# 浅谈委托----温故而知新
先看看委托的概述: •委托类似于 C++ 函数指针,但它们是类型安全的. • 委托允许将方法作为参数进行传递. • 委托可用于定义回调方法. • 委托可以链接在一起:例如,可以对一个事件调用多个方法. ...
- 百度快收录吧!!!a39fe054b88866bc737dd5fb02f39e41
百度快收录吧!!!a39fe054b88866bc737dd5fb02f39e41 }416oTemocleW{yek
- [转载]eclipse中设置文件的编码格式为utf-8
免责声明: 本文转自网络文章,转载此文章仅为个人收藏,分享知识,如有侵权,请联系博主进行删除. 原文作者:ryxxlong 原文地址:http://ryxxlong.iteye ...
- Maven--(一个坑)在settings.xml文件中添加mirrors导致无法新建Maven项目
这是用新电脑第一次创建Maven项目--当然是一个测试项目.已经差不多忘了该怎样做,所以参考我的博客:http://www.cnblogs.com/wql025/p/4996486.html,这应该是 ...
- 【HDOJ】【4336】Card Collector
概率DP/数学期望/状压DP/容斥原理 kuangbin总结中的第14题 好神奇的做法……题解看kuangbin的代码好了…… //HDOJ 4336 #include<cstdio> # ...
- 20160723数据结构节alexandrali
大坑最后再填. 20160803:心情好回来填啦(5/7) 做的题目是: poj2970 我们先每个人都不给钱qwq 然后我们发现有一位的工作时间超过了d 那么我们就从以前安排过工作的人里,a最大的, ...
- 以“图片渐入渐出”为例讲述jQuery插件的具体实现
首先声明,此代码以网友“斯迈欧”原创作为此例的讲解: 在这之前我们先看看我们要做的效果是什么样的: 解析下面的样式:我们要图片在过“一定时间”后自动切换,在右下角处有小方块似数字1,2,3,4,这些数 ...