DSP与FPGA之间EMIF接口之DSP参数配置下板测试问题总结

FPGA这部分很简单的一个参数配置模块,本来以为一两次测试就能搞定确认,结果用了一天的时间才成功,中间出了好多奇葩问题,这里总结一下,希望有所借鉴,下次能长点记性。

现象一:配置参数模块输出一千多个寄存器数据,我想要一次性全部抓取查看,一千多个数据不想用手动ila IP核去生成一千多个太麻烦。于是用了mark_debug的方式,结果编译速度极慢还一直报错

原因:无论是mark_debug方式还是生成ila IP核手动的方式都最多大概256个信号的限制,或者后期我来确认下上限值,所以我没办法一次性全部抓取查看。

解决办法:将mark_debug改成16个寄存器就不报错了,这种方法编译极慢,所以后面又改成了手动ila IP的方式,一次读取48个寄存器查看

现象二:首先DSP通过EMIF接口向我FPGA发送配置参数,结果我的ila波形显示输入数据一直为初始化默认数据不变,而不是DSP发送给FPGA的真实数据。

原因:DSP初始化后只发送一次配置参数所以抓不到真实数据。

解决办法:要求DSP人员将配置参数数据1ms为周期循环发送,这样我就可以正常读取配置参数数据了。

现象三:配置参数数据的最后一个时校验和取反数据,我的校验和验证失败,校验信号报错一直拉高,我闷闷的找自己的原因,以为是自己哪个环节算错了

原因:偶然跟DSP人员沟通,发现DSP那边给的校验和取反数据是不对的,没按照协议规定指定地址累加和

解决办法:DSP人员修改后不再报err错了

现象四:EMIF接口进来的数据为DSP真实发送数据,但我的模块内部数据依然是初始化配置数据不变

原因:FPGA配置参数模块代码的复位信号用反了,导致一直在复位状态里,参数无法传递。

解决办法:将外部传递的复位信号取反用~符号

现象五:内部数据也传递进来,但抓取的数据发现有的不正确,有的正确

原因:ila 抓取48个寄存器太多,导致输出异常波形数据

解决办法:将ila 波形数据抓取改成16个寄存器后,输出波形数据恢复正常

至此测试完毕。中间还有些小细节不再赘诉。

相关推荐
坏孩子的诺亚方舟9 天前
FPGA系统架构设计实践15_高云Arora V系列时钟体系
fpga开发·系统架构
FPGA小徐9 天前
入门 CNN 结构全解析|从流程图理论到 FPGA Verilog 硬件实现(含习题带讲解)
fpga开发
FPGA小徐9 天前
FPGA 数字信号处理:并行 FIR 与串行滤波器设计原理、对比与完整 Verilog 实现
fpga开发
Saniffer_SH10 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
zlinear数据采集卡10 天前
双核架构深度解析:ARM+FPGA如何让数据采集卡实现500Ksps高性能?
arm开发·fpga开发·架构
9527华安10 天前
FPGA实现GTH Transceivers Wizard传输2路视频,基于aurora 8b10b编解码架构,提供4套工程源码和技术支持
fpga开发·gth·aurora 8b10b·transceivers
FPGA小徐11 天前
FPGA 数字信号处理(二):并行 FIR 滤波器的 Verilog 全流程设计与实现
fpga开发
国科安芯11 天前
基于AS32S601ZIT2型抗辐照MCU的商业航天卫星姿态确定与控制系统研究
单片机·嵌入式硬件·安全·fpga开发·架构·risc-v
ALINX技术博客11 天前
【黑金云课堂】FPGA技术教程FPGA基础:I2C 总线通信技术
fpga开发·i2c
Hello-FPGA11 天前
Xilinx KU040 FPGA Camera Link 图像采集
c++·fpga开发