引言

之前关于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信息:

  1. Xilinx ML501> help
  2.  
  3. ic_enable - enable instruction cache
  4.  
  5. ic_disable - disable instruction cache
  6.  
  7. dc_enable - enable data cache
  8.  
  9. dc_disable - disable data cache
  10.  
  11. mfspr <spr_addr> - show SPR
  12.  
  13. mtspr <spr_addr> <value> - set SPR
  14.  
  15. dm <start addr> [<end addr>] - display 32-bit memory location(s)
  16.  
  17. pm <addr> [<stop_addr>] <value> - patch 32-bit memory location(s)
  18.  
  19. ram_test <start_addr> <stop_addr> [<test_no>] - run a simple RAM test
  20.  
  21. better_ram_test <start_addr> <stop_addr> - run a better RAM test
  22.  
  23. crc [<src_addr> [<length> [<init_crc>]]] - Calculates a 32-bit CRC on specified memory region
  24.  
  25. dhry [<num_runs>] - run dhrystone
  26.  
  27. coremark [<mode>] [<iterations>] - run coremark, mode: p - performance run, o - profile run, default - validation run
  28.  
  29. tftp_conf [ <file> [ <srv_ip> [ <src_addr>]]] - TFTP configuration
  30.  
  31. tboot [<image number>] - Bootstrap image downloaded via tftp
  32.  
  33. sdboot [<image number>] - Read image from SD-CARD
  34.  
  35. help - shows this help
  36.  
  37. CPU info
  38.  
  39. Frequency 66MHz
  40.  
  41. Instruction cache: 32kB (BS: 32 Sets: 1024)
  42.  
  43. Data cache: 32kB (BS: 32 Sets: 1024)
  44.  
  45. Info: Stack section addr 0x23c60
  46.  
  47. Build tag: Wed Jun 1 13:30:21 CEST 2011
  48.  
  49. 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的更多相关文章

  1. OpenRISC自定义指令GCC修改

    This short tutorial shows how to use the custom instructions defined by OpenRISC architecture. The O ...

  2. OpenRisc-44-or1200的pipeline整体分析

    引言 我们在前面分析了ORPSoC,or1200_top,和or1200_cpu的整体架构,在最近,我们也分析了or1200的pipeline(流水线)中的两级,EX级和IF级. 但是,我们还没有从宏 ...

  3. orpsocv2 从ROM(bootrom)启动分析--以atlys板子的启动为例子

    1 复位后的启动地址 1) 复位后,启动地址在or1200_defines.v最后宏定义,atlys板子的目录:orpsocv2\boards\xilinx\atlys\rtl\verilog\inc ...

  4. 【嵌入式】FS2410非操作系统外围资源测试

    在刚接触FS2410时,其实这个测试也没有多大意义,但是对于以后来说,当一个产品做成功时,产品测试还是一个必须经过的一个阶段,所以这个流程还是有必要走一下! 在非操作系统下,主要进行RTC测试,按键测 ...

  5. Open Source Software List: The Ultimate List

    http://www.datamation.com/open-source/ Accessibility 1. The Accessibility Project The Business Value ...

  6. ZooKeeper测试笔记

    1. 下载ZooKeeper.官网:http://zookeeper.apache.org 下载后解压,假定zookeeper程序目录为/home/test/zookeeper,为陈述方便此目录记为 ...

  7. 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 ...

  8. OpenRisc-37-OpenRISC的CPU&core的整体架构分析

    引言 前面我们分析了ORPSoC的整体架构,并对其子系统进行了深入的分析和了解.但对于ORPSoC的核心模块or1200_top及其内部的core--or1200_cpu模块却鲜有涉及,算是ORPSo ...

  9. 系统级性能分析工具perf的介绍与使用[转]

    测试环境:Ubuntu16.04(在VMWare虚拟机使用perf top存在无法显示问题) Kernel:3.13.0-32 系统级性能优化通常包括两个阶段:性能剖析(performance pro ...

随机推荐

  1. oracle作业

    http://blog.csdn.net/hao_ds/article/details/38382931 oracle作业各种参数的详细介绍

  2. intellij 设置-试验过的

    1.已修改的文件星号“*”标记 2.在PROJECT窗口中快速定位,编辑窗口中的文件 在编辑的所选文件按ALT+F1, 然后选择PROJECT VIEW 3.改变编辑文本字体大小 FILE -> ...

  3. java 泛型通配符 extends, super

    引自:http://sharewind.iteye.com/blog/1622164 关键字说明 ? 通配符类型 <? extends T> 表示类型的上界,表示参数化类型的可能是T 或是 ...

  4. MapInfo格式转arggis格式

    1. 下载MapInfo 11.0 2. 打开工具里的转换工具 3. 选择数据源和结果文件夹(目录中不能包含中文) 4. 转换成功.

  5. PythonChallenge 2:爬虫和正则表达式

    题目: 解题思路:题目里已经说的很清楚了,字符可能在网页的源代码里.右键查看网页源代码,发现其中有一段:find rare characters in the mess below.有些人是直接把下面 ...

  6. JXL读取写入excel表格数据

    问题描述: 使用java的jxl包创建.写入excel表格数据 问题解决: (1)说明 (2)写入execel数据 注: 以上是写入数据需要调用的函数接口 注: 具体接口调用过程,如上所示 (3)读取 ...

  7. text-align:-moz-center与text-align:-webkit-center区别与用法

    最近发现各浏览器的不兼容,关于text-align:center这个很多浏览器不兼容. 1.测试发现:text-align:center在IE下是管用的. 2.text-align:-moz-cent ...

  8. 【CodeForces】【148D】Bag of mice

    概率DP kuangbin总结中的第9题 啊……题目给的数据只有白鼠和黑鼠的数量,所以我们只能在这个上面做(gao)文(D)章(P)了…… 明显可以用两种老鼠的数量来作为状态= = 我的WA做法: 令 ...

  9. oracle——session

    一.解释session web应用中,session是服务器段保存用户信息的一个对象,cookie是浏览器端保存用户信息的对象.今天了解了oracle也有session对象,那么什么是oracle的s ...

  10. hadoop浅尝 第一个hadoop程序

    hadoop编程程序员需要完成三个类. map类,reduce类和主类. map和reduce类自然是分别完成map和reduce.而主类则负责对这两个类设置job.完成这三个类之后,我们生成一个ja ...