AD9162数据链路lanes与FPGA高速BANK引脚交叉相连导致vivado编译失败

本文主要是介绍AD9162数据链路lanes与FPGA高速BANK引脚交叉相连导致vivado编译失败,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1. 问题概述

对AD9162芯片进行功能开发时,发现AD9162的链路lanes与FPGA的高速BANK引脚存在交叉相连的情况,按照实际的引脚连接关系进行约束后,vivado编译失败。

  1. 问题阐述及原因分析
    1. 问题详情阐述

板卡对AD9162芯片进行功能开发时,发现硬件电路的设计结果存在AD9162数据链路与FPGA高速BANK引脚交叉相连的问题,示意图如图3‑1,若根据图示的引脚连接关系进行管脚约束,vivado无法通过编译,图3‑2是报错结果截图。

31  板卡AD9162数据链路与FPGA高速BANK引脚的硬件连接关系图

32  vivado编译失败截图

    1. 原因分析

根据图3‑2的报错结果,将提示内容中的约束语句加入到XDC文件中,依然无法完成编译。AD9162的数据链路lanes与FPGA端高速BANK引脚交叉约束导致这一问题。

  1. 解决方法

将lane2与F4、lane5与E2进行约束,如图4‑1,编译通过。但这会导致FPGA输出给GSM019的数据存在混乱的问题,为此本报告提供3种解决方法。

41  数据链路与FPGA高速BANK引脚的软件连接关系图

    1. 修改AD9162数据链路选择寄存器

AD9162的寄存器0x308、0x309、0x30A、0x30B用于配置lane0~lane7数据链路的选择,如图4‑2。由于在xdc中替换lane2与lane5对应的FPGA引脚,因此为解决这两路数据交错的问题,可以在GSM019的寄存器配置环节中往0x309的bit[2:0]写入3b101、往寄存器0x30A的bit[5:3]写入3b010,即将lane2与lane5的数据来源替换。

42  GSM019数据选择寄存器

    1. 修改数据拼接方式

若不修改AD9162的数据选择寄存器,可以通过修改数据拼接方式的方法来解决数据混乱的问题。以复信号的数据拼接方式为例,如图4‑3,按照原数据拼接格式,lane2与lane5的原数据为蓝色框,我们通过将代码修改为红色框的内容即可替换lane2与lane5数据。

43  修改数据拼接方式代码截图

    1. 修改JESD204B IP核数据对应关系

另外,还可以通过修改JESD204B IP核数据的对应关系来解决数据混乱问题。具体为:按图红色框将JESD204B IP核输出的gt2_txdata与gt5_txdata、gt2_txcharisk与gt5tx_charisk进行互换。

44  修改JESD204B IP核数据对应关系

  1. 实验结果
    1. 修改GSM019寄存器数据链路选择寄存器实验
  1. 按照4.1节提供的解决方法对AD9162寄存器的配置代码进行修改,并编译工程;
  2. 使用射频信号线连接安捷伦与DAC模拟输出口,板卡上电;
  3. 将bit文件下载至板卡中,并在vio界面控制DDS的信号频率,观察频谱仪上的信号频率;
  4. 频谱仪上显示的信号频点与控制DDC输出的信号频点一致,实验通过,并拍照或截图记录。

51  修改AD9162数据选择寄存器的结果(1313MHz0dBm

52  修改AD9162数据选择寄存器的结果(1050MHz0dBm

    1. 修改数据拼接方式实验
  1. 按照4.2节提供的解决方法对数据拼接代码进行修改,并编译工程;
  2. 使用射频信号线连接安捷伦与DAC模拟输出口,板卡上电;
  3. 将bit文件下载至板卡中,并在vio界面控制DDS的信号频率,观察频谱仪上的信号频率;
  4. 频谱仪上显示的信号频点与控制DDC输出的信号频点一致,实验通过,并拍照或截图记录。

53  修改数据拼接方式的结果(1310MHz0dBm

54  修改数据拼接方式的结果(1110MHz0dBm

    1. 修改JESD204B IP核数据对应关系实验
  1. 按照4.3节介绍的解决方法修改JESD204B IP核数据对应关系的代码,并编译工程,使用射频信号线连接安捷伦与DAC模拟输出口,板卡上电;
  2. 将bit文件下载至板卡中,并在vio界面控制DDS的信号频率,观察频谱仪上的信号频率;
  3. 频谱仪上显示的信号频点与控制DDC输出的信号频点一致,实验通过,并拍照或截图记录。

55  修改JESD204B IP核数据对应关系的结果(1310MHz0dBm

56  修改JESD204B IP核数据对应关系的结果(1110MHz0dBm

这篇关于AD9162数据链路lanes与FPGA高速BANK引脚交叉相连导致vivado编译失败的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1110173

相关文章

MySQL版本问题导致项目无法启动问题的解决方案

《MySQL版本问题导致项目无法启动问题的解决方案》本文记录了一次因MySQL版本不一致导致项目启动失败的经历,详细解析了连接错误的原因,并提供了两种解决方案:调整连接字符串禁用SSL或统一MySQL... 目录本地项目启动报错报错原因:解决方案第一个:第二种:容器启动mysql的坑两种修改时区的方法:本地

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Android NDK版本迭代与FFmpeg交叉编译完全指南

《AndroidNDK版本迭代与FFmpeg交叉编译完全指南》在Android开发中,使用NDK进行原生代码开发是一项常见需求,特别是当我们需要集成FFmpeg这样的多媒体处理库时,本文将深入分析A... 目录一、android NDK版本迭代分界线二、FFmpeg交叉编译关键注意事项三、完整编译脚本示例四

MySQL中的交叉连接、自然连接和内连接查询详解

《MySQL中的交叉连接、自然连接和内连接查询详解》:本文主要介绍MySQL中的交叉连接、自然连接和内连接查询,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、引入二、交php叉连接(cross join)三、自然连接(naturalandroid join)四

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

idea maven编译报错Java heap space的解决方法

《ideamaven编译报错Javaheapspace的解决方法》这篇文章主要为大家详细介绍了ideamaven编译报错Javaheapspace的相关解决方法,文中的示例代码讲解详细,感兴趣的... 目录1.增加 Maven 编译的堆内存2. 增加 IntelliJ IDEA 的堆内存3. 优化 Mave

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

Docker镜像pull失败两种解决办法小结

《Docker镜像pull失败两种解决办法小结》有时候我们在拉取Docker镜像的过程中会遇到一些问题,:本文主要介绍Docker镜像pull失败两种解决办法的相关资料,文中通过代码介绍的非常详细... 目录docker 镜像 pull 失败解决办法1DrQwWCocker 镜像 pull 失败解决方法2总

pip无法安装osgeo失败的问题解决

《pip无法安装osgeo失败的问题解决》本文主要介绍了pip无法安装osgeo失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 进入官方提供的扩展包下载网站寻找版本适配的whl文件注意:要选择cp(python版本)和你py

MySQL安装时initializing database失败的问题解决

《MySQL安装时initializingdatabase失败的问题解决》本文主要介绍了MySQL安装时initializingdatabase失败的问题解决,文中通过图文介绍的非常详细,对大家的学... 目录问题页面:解决方法:问题页面:解决方法:1.勾选红框中的选项:2.将下图红框中全部改为英