- 易迪拓培训,专注于微波、射频、天线设计工程师的培养
基于SoPC的通用在线调试器设计
参数指令传递模块用于合并总线读写模块接收的参数和指令。当写有效且主控模块没有工作时,将从Avalon总线接收的前128位数据拼接起来存放在参数寄存器中,后32位数据由指令寄存器接收;当写无效时停止输入,并且启动状态机模块。参数寄存器和指令寄存器均在在本模块中定义。
状态机模块负责仿真JTAG状态机中的16个状态,凭借主控模块中TMS序列驱动实现状态间的转移,同时向JTAG的TMS端口送出TMS序列,以控制目标机中JTAG状态机的运行。在SHIFT_IR和SHIFT_DR状态下,相应的目标机指令(如ARM指令)和数据通过JTAG的TDI端口送入目标机。
目标机TDO序列接收模块负责接收目标机传来的数据,并将其存放在相应的寄存器中。
主控模块在JTAG状态机运行之前,根据参数指令传递模块中指令寄存器的值更新状态机的TMS和TDI序列数据;然后初始化TMS寄存器、TDI寄存器、标志寄存器,通过标志寄存器的值判断JTAG状态机的运行;在其运行结束后,在状态机结束处理子模块中把目标机传来的数据送到输出寄存器,并设置读有效以启动总线读写模块。
1.2 JTAG IP core接口程序
在线仿真子系统中,JTAG IP core接口为JTAG IPcore子系统与NiosII CPU硬件环境之间提供数据交互服务。接口程序分成宏定义、写数据、读数据3个部分。
宏定义部分,JTAG IP core中的操作指令包括:进入调试状态、获取CPU IDCODE、读/写寄存器、读/写内存、设置断点、设置观察点、跳出调试状态等。
写数据部分,目标机的内存地址和寄存器号作为参数数据传递到JTAG IP core子系统中,调试指令(即宏定义中的指令)与参数一起被写入JTAG IP core子系统中。部分程序代码如下:
其中,pi表示参数数据(i=0,…,3),ir表示指令。IOWR_32DIRECT(JTAGTEST_0_BASE,ADDR(i),pi)表示将pi或ir的值写入JTAG IP core。
读数据部分的功能是从JTAG IP core子系统中读取目标机传回的数据。当在线仿真子系统的Nios II CPU准备从JTAG IP core子系统中读取数据时,JTAG IP core子系统中的寄存器数据不一定是有效数据,因而需设置一个寄存器(命名为read_ready)来循环检测数据是否有效。如果寄存器的值不为0,则允许读取数据。
2 JTAG IP core子系统仿真验证
JTAG IP core子系统设计完成后,为了验证逻辑的正确性,在QuartusII环境下对该IP core模块进行了仿真验证。在仿真中,将NiosII CPU给出的触发信号cLK修改为2分频,以便能较直观地看清触发子系统允许的TCK信号的产生。当JTAG IP core接口程序被启动时,总线读写模块开始从Avalon总线上读取参数和指令(如图4所示,writedata、address、inst∣reg_in[0,1,4]及ir寄存器中出现数据)。当参数指令传递模块中的palm和ir寄存器中出现数据后,主控模块开始工作;同时,主控模块的busy_flag信号触发状态机模块工作。从图中可看到,TMS序列出现数据,TDI端口开始送出数据。JTAG IP core模块能按照预定设计输出TMS和TDI调试序列,说明该IPcore在逻辑上是正确的。
结 语
本文提出了以知识产权核(即IP core)复用技术为主的通用性调试器设计思路以及实现方法。下一步,可以基于ARM、MIPS系列芯片,结合本文的解决方案实现具体的IP core,同时增加多线程调试等优化工作。(中电网 柳琳琳,桑楠)
来源:维库开发网