OpenRisc-29-ORPSoC的debug子系统分析

引言

正如前面所说,“如果把SOC比作一个人的话”,那么debug子系统就相当于医生,可以检测身体的健康状态。本小节就简单分析一下ORPSoC的debug子系统。

debug系统担任两个主要任务,除了调试以外,还负责对flash的编程。

1,子系统的结构


OpenRisc-29-ORPSoC的debug子系统分析_第1张图片


2,结构的说明

整个debug系统可简单的分成两部分,上部分和下部分,上下两部分之间通过JTAG协议通信。

1>上部分

上部分包括PC部分和FTDI。

FTDI是一个4in1的芯片,其中两路是jtag接口(FPGA本身一路,ORPSoC的jtag一路),另外两路是uart,如图:

OpenRisc-29-ORPSoC的debug子系统分析_第2张图片

or32-debug_proxy是FTDI的驱动,可以用svn在opencores官网SVN server上download,其svn目录结构如下:

需要说明的是,trunk目录下的内容较多,可根据需要单独下载对应的子目录:


OpenRisc-29-ORPSoC的debug子系统分析_第3张图片


可使用svn,输入对应的checkout路径下载对应的资源:

OpenRisc-29-ORPSoC的debug子系统分析_第4张图片


2>下部分

下部分是FPGA内部的ORPSoC的模块部分,通过内部自定义协议,根据上部分的jtag指令,读取sprs(特殊功能寄存器)来获得系统状态信息,返回给上部分,最终给or32-elf-gdb(or1200平台的gdb),在终端打印出来,完成调试工作。

下部分对应的芯片引脚和模块的端口名称等信息,请参考:

http://blog.csdn.net/rill_zhen/article/details/9044791


3,程序的下载

要想让ORPSoC运行软件至少需要做三部分工作,第一,将ORPSoC的硬件逻辑烧写到FPGA,第二,将软件烧写到ORPSoC的flash里面,第三,上电后将flash的软件copy到SDRAM。

1>对于第一,二步,请参考:

http://blog.csdn.net/rill_zhen/article/details/9162275

2>主要说明一下第二步。

1》simple-spi模块操作ORPSoC的altserial_flash_loader模块,这是altera的LPM,这个模块的作用是什么呢?

手册里描述如下:

Serial flash loader megafunction. The altserial_flash_loader is a bridge that allows programming data to cross from the JTAG interface via the FPGA to the active serial interface.

2》altserial_flash_loader可以读取外部的spi-flash(软件程序),受ORPSoC的simple_spi模块的控制,传到arbiter_bytebus模块,而arbiter_bytebus模块又是arbiter_dbus的从设备(s3),arbiter_dbus的master正好是or1200_top的data接口。事先存在bootrom里面的指令可以读取spi flash的内容到sdram,然后启动系统。

关于ORPSoC的启动过程,请参考:

http://blog.csdn.net/rill_zhen/article/details/8855743


3>小结

自此,我们对ORPSoC的bootloader(orpmon)启动过程比较清晰了。

1》FPGA工具将orpmon写到外部的spi-flsh里面供altserial_flash_loader使用。

2》bootrom里面的启动代码的硬件固化。

3》上电运行bootrom的指令

4》bootrom的指令读取altserial_flash_loader到sdram,并运行。

5》加载linux,应用程序

6》系统的大厦展现在我们面前。

OpenRisc-29-ORPSoC的debug子系统分析_第5张图片

7》总体的数据路径如下,

红色:事先初始化。

黄色:上电bootrom运行。

绿色:oprmon的代码读取。

蓝色:oromon的写入内存。

OpenRisc-29-ORPSoC的debug子系统分析_第6张图片

4,疑问及推测

1>疑问

细心的读者可能会有下面一个疑问,ORPSoC的最外层的引脚并没有跟spi-flash相关的引脚。但是vbox的文档里有以下描述:如下图:
OpenRisc-29-ORPSoC的debug子系统分析_第7张图片
根据上面的描述,ORPSoC在上电之后会从外部的sp-flash里面读取bootloader(orpmon)然后运行。但是ORPSoC连跟外部spi-flash的引脚都没有,怎么可能读取外部spi-flash呢?
值得注意的是外部spi-flash确实连到了FPGA芯片的引脚上(H2,H1,D2,C1),如下图:OpenRisc-29-ORPSoC的debug子系统分析_第8张图片

2>推测

外部spi-flash连到了FPGA芯片引脚上,但是ORPSoC并没有任何一个模块的外部端口与之对应,上电后bootrom.S的程序还能访问到外部的spiflash
其实这正说明了上面介绍的altserial_flash_loader这个altera的库模块的作用。这个模块是外部spi-flash和ORPSoC simple_spi两个模块的bridge。
事先,通过quartusII的工具,将orpmon的程序烧到外部的spi-flash里面,在上电后,ORPSoC通过altserial_flash_loader这个模块读取外部spi-flash里面的内容,而不是通过外部的引脚来读取,所以ORPSoC就没有所对应的引脚引出来了。下面的原理图显示,可以用quartusII的jtag blaster对外部的spi-flash(U6和U7)进行编程(将orpmon烧到外部的spi-flash)。
OpenRisc-29-ORPSoC的debug子系统分析_第9张图片
OpenRisc-29-ORPSoC的debug子系统分析_第10张图片
通过FPGA芯片的datasheet,也可以看出这一点:
OpenRisc-29-ORPSoC的debug子系统分析_第11张图片
上面的过程只是我根据目前掌握的资料来做的一个合理推测,我现在手里没有altera的blaster,所以不能在线仿真。如果读者有blaster,可以仿真一下,就能知道推测的真伪。

5,小结

本小节简单介绍了ORPSoC的debug系统的结构和调试过程的数据通路。

如果在调试中遇到问题,可以分阶段的逐步的进行分析和排查,解决问题。



你可能感兴趣的:(OpenRisc-29-ORPSoC的debug子系统分析)