AD9371 官方例程HDL详解之JESD204B TX侧时钟生成 (三)

AD9371 系列快速入口

AD9371+ZCU102 移植到 ZCU106 : AD9371 官方例程构建及单音信号收发

ad9371_tx_jesd -->util_ad9371_xcvr接口映射: AD9371 官方例程之 tx_jesd 与 xcvr接口映射

AD9371 官方例程 时钟间的关系与生成 : AD9371 官方例程HDL详解之JESD204B TX侧时钟生成(一)

AD9371 官方例程 时钟间的关系与生成 : AD9371 官方例程HDL详解之JESD204B TX侧时钟生成 (二)

参考资料:
UltraScale Architecture GTH Transceivers User Guide UG576

Generic JESD204B block designs

文章目录

  • 前言
  • 一、AD9371官方例程 LineRate
  • 二、AD9371官方例程 TXOUTCLK、 TXUSRCLK 和 TXUSRCLK2
  • 三、JESD204B应用层给传输层数据的格式配置


前言

结合之前两讲内容,梳理 AD9371官方 demo 时钟,理解采样率和各个时钟之间的关系

一、AD9371官方例程 LineRate

AD9528 输出的OUT1 时钟 通过FMC 连接到FPGA,差分时钟信号通过 IBUFDS_GTE4 得到 ref_clk1 ,ref_clk1 连接到 block design 的 rx_ref_clk_0 、rx_ref_clk_2 和 tx_ref_clk_0 。

    .rx_ref_clk_0 (ref_clk1),.rx_ref_clk_2 (ref_clk1),....tx_ref_clk_0 (ref_clk1),

tx_ref_clk_0 ——> util_ad9371_xcvr ip 的 qpll_ref_clk_0
rx_ref_clk_0 ——> util_ad9371_xcvr ip 的 cpll_ref_clk_0 和 cpll_ref_clk_1
rx_ref_clk_2 ——> util_ad9371_xcvr ip 的 cpll_ref_clk_2 和 cpll_ref_clk_3

在这里插入图片描述

qpll_ref_clk_0 连接到 QPLL0 和 QPLL1 的参考时钟

    .GTREFCLK00 (qpll_ref_clk),.GTREFCLK01 (qpll_ref_clk),.GTREFCLK10 (1'd0),.GTREFCLK11 (1'd0),

所以 demo 中使用的这个 Quad 里的 QPLL0/1 和 4个Channel 里的每个CPLL的参考时钟都是ref_clk1 提供的

再通过 裸机C程序中的adxcvr_clk_set_rate 设置 lane_rate(根据采样率求出),ref_rate_khz 即为 ref_clk1 的122.88MHz ,根据ref_clk1 提供的122.88MHz 参考时钟,由QPLL0/1或者CPLL生成 对应LineRate所需的PLL _CLK,再由上升沿和下降沿有效得到LineRate


adxcvr_clk_set_rate(xcvr, xcvr->lane_rate_khz, xcvr->ref_rate_khz);tx_lane_rate_khz = mykDevice.tx->txProfile->iqRate_kHz *mykDevice.tx->deframer->M * (20 /no_os_hweight8(mykDevice.tx->deframer->deserializerLanesEnabled));

tx_lane_rate 和 采样率之间的关系

在这里插入图片描述
M是有几个转换器,每个采样数据是16 bit,经过8B/10B编码到 20bit , L是有几个LANE传数据

demo中 2T2R,M=4(1发 需要IQ 两路转换器), L=4的情况下 ,根据IQ rate(122.88M) 可以求得所需的TxLineRate(2457.6 MHz)
IQRate  = T x L i n e R a t e 20 \text {IQRate }=\frac{{TxLineRate} }{20} IQRate =20TxLineRate

二、AD9371官方例程 TXOUTCLK、 TXUSRCLK 和 TXUSRCLK2

例程中 TXUSRCLK 和 TXUSRCLK2时钟 由 TXOUTCLK 经过BUFG_GT后生成,TXOUTCLK 选择的 TXPLLREFCLK_DIV1 ,又选择的 QPLL0 的参考时钟(QPLL0/1 和CPLL 同一个参考时钟),即ref_clk1

  BUFG_GT i_tx_bufg (.CE (1'b1),.CEMASK (1'b0),.CLR (1'b0),.CLRMASK (1'b0),.DIV (3'd0),.I (tx_out_clk_s),.O (tx_out_clk));

在这里插入图片描述

TXOUTCLK 经过BUFG_GT后连接到每个Channel 的 tx_out_clk_< N >,例程使用的tx_out_clk_0,输入到axi_ad9371_tx_clkgen,产生TXOUTCLK、 TXUSRCLK2和Link rate(上一讲知道 TXOUTCLK、 TXUSRCLK2和Link rate 速率都是 LineRate/40, 即IQ rate/2=61.44 )

在这里插入图片描述
tx_clk_0、tx_clk_1、tx_clk_2、tx_clk_3 接入每个Channel 的 TXUSRCLK 和 TXUSRCLK2

    .TXUSRCLK  (tx_clk),.TXUSRCLK2 (tx_clk));

生成的 link clk 为 链路层 和 传输层 提供 61.44MHz 时钟

在这里插入图片描述

三、JESD204B应用层给传输层数据的格式配置

上述可知 AD9371 官方 demo 2T2R 中 IQ 采样率= 2 * LINK rate ,JESD204B 应用层 如何 给传输层数据 ?

在这里插入图片描述
在物理层GTH收发器 配置为32bit模式,链路层每个LINK CLK 需要给物理层每个 LANE 32bit数据

在这里插入图片描述
引入 SPC :每个数据时钟周期,每个转换器,需要提供/采集几个采样点
每个 LANE需要 32bit数据,下述约束必须满足
L × 32 = M × N P × S P C L \times 32=M \times N P \times S P C L×32=M×NP×SPC
2T2R demo 中 JESD TX参数配置为 L=4; M=4; S=1; F=2; NP=16; SPC=2
S P C = L ∗ 32 / ( M ∗ N P ) \mathrm{SPC}=\mathrm{L}^{*} 32 /(\mathrm{M} * \mathrm{NP}) SPC=L32/(MNP)

每个转换器提供 SPC=2个 16Bbit 采样数据 Frame0 和 Frame1拼在一起 ,每帧 F=2 ,两帧凑成 2 * 2 * 8=32bit

在这里插入图片描述
MmSn 表示 第m个转换器的第n个采样数据, AD9371 2T2R 中 M=4,n=SPC=2 ;

[ M3S1, M3S0, M2S1, M2S0, M1S1, M1S0, M0S1, M0S0]

每个Lane 数据排列如下图所示
在这里插入图片描述


TX=1时,M=2,L=4,F=1,S=1, IQ 采样率= 4* LINK rate= line rate/10 ,SPC=4

数据送给官方传输层 排布如下 [ M1S3, M1S2, M1S1, M1S0, M0S3, M0S2, M0S1, M0S0]
在这里插入图片描述
具体数据重新映射代码见 tx_ad9371_tpl_core/tpl_core

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/116577.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

GB28181学习(十一)——控制(PTZ、镜头、光圈等控制)

要求 源设备向目标设备发送控制命令&#xff0c;控制命令类型包括&#xff1a; 摄像机云台控制远程启动录像控制报警布防/撤防报警复位强制关键帧拉框放大/缩小看守位控制PTZ精准控制存储卡格式化目标跟踪软件升级设备配置 设备配置的内容包括&#xff1a; 基本参数视频参数范…

React TypeScript安装npm第三方包时,些包并不是 TypeScript 编写的

npm install types/包名称 例如&#xff1a;npm install types/jquery 学习链接

QSPI介绍

0 Preface/Foreword 1 QSPI介绍

Python 编程语言的介绍

Python 是一种高级、动态类型的解释型语言。由 Guido van Rossum 于1989年底发明&#xff0c;并在1991年首次发布。Python 的设计哲学强调代码的可读性和简洁的语法&#xff0c;特别是使用缩进来表示代码块&#xff0c;这使得开发者能够用更少的代码表达想法。 基础概念: 语法…

shell_38.Linux读取脚本名

读取脚本名 (1)示例 $ cat positional0.sh #!/bin/bash # Handling the $0 command-line parameter # echo This script name is $0. exit $ $ bash positional0.sh This script name is positional0.sh. $ (2)如果使用另一个命令来运行 shell 脚本&#xff0c;则命令…

Win10下基于VS2015编译SQLite3源码

一、下载SQLite SQLite SQLite Download Page 下载红框部分的3个文件 提示&#xff1a;这里有个 sglite-autoconf-3420000.tar.gz 是免编译版&#xff0c;想省事就下载这个&#xff0c;但我自己用这个老是编译不过 所以我这里不推荐这个了 二、配置SQLite 打开vs 2015或者其他…

Android Kotlin 协程初探 | 京东物流技术团队

1 它是什么&#xff08;协程 和 Kotlin协程&#xff09; 1.1 协程是什么 维基百科&#xff1a;协程&#xff0c;英文Coroutine [kəru’tin] &#xff08;可入厅&#xff09;&#xff0c;是计算机程序的一类组件&#xff0c;推广了协作式多任务的子程序&#xff0c;允许执行被…

SqueezeNet 一维,二维网络复现 pytorch 小白易懂版

SqueezeNet 时隔一年我又开始复现神经网络的经典模型&#xff0c;这次主要复的是轻量级网络全家桶&#xff0c;轻量级神经网络旨在使用更小的参数量&#xff0c;无限的接近大模型的准确率&#xff0c;降低处理时间和运算量&#xff0c;这次要复现的是轻量级网络的非常经典的一…

【Node.js】暴露自定义响应头和预检请求的时机

1. 暴露自定义响应头 // server.js app.post(/api/user/hello, (req, res) > {res.setHeader(Access-Control-Allow-Origin, *)// 权限设置&#xff08;如果有个多&#xff0c;用 &#xff0c;隔开&#xff09;&#xff0c;暴露给前端res.setHeader(Access-Control-expose-…

muduo源码学习base——Atomic(原子操作与原子整数)

Atomic(原子操作与原子整数&#xff09; 前置知识AtomicIntegerTget()getAndAdd()getAndSet() 关于原子操作实现无锁队列(lock-free-queue) 前置知识 happens-before&#xff1a; 用来描述两个操作的内存可见性 如果操作 X happens-before 操作 Y&#xff0c;那么 X 的结果对于…

React hooks介绍及使用

介绍&#xff1a; React hooks 是 React 16.8 版本引入的新特性&#xff0c;它允许你在无需编写类组件的情况下&#xff0c;能够使用状态和其他 React 特性。它是基于函数组件的&#xff0c;使得函数组件也能够拥有类组件的状态和生命周期等特性&#xff0c;同时减少了处理一些…

有奖招募——2023年度清华社“荐书官”活动今日开始了!

又到“1024程序员节”了&#xff0c;维护网络世界稳定和平的程序员大大们&#xff0c;辛苦了&#xff01;生活难免有bug&#xff0c;来给彼此个hug~ 过完1024&#xff0c;这一年也快要结束了&#xff0c;岁末回顾又要提上日程。很多人都有整理年度书单的习惯&#xff0c;那么这…

架构风格区别-架构案例(五十九)

管道-过滤器和仓库的区别&#xff1f; 独立的数据仓库&#xff0c;处理流独立&#xff0c;处理数据用连接仓库工具数据与处理在一起&#xff0c;改动的话需要重启系统需要仓库工具与仓库连接&#xff0c;数据与处理分离&#xff0c;性能差可以支持并发连接访问仓库&#xff0c…

隐藏微信网页右上角的按钮、在微信网页中获取用户的网络状态,支付等

1.隐藏微信网页右上角按钮 <script type"text/javascript">document.addEventListener(WeixinJSBridgeReady,function onBridgeReady() {// 通过下面这个API隐藏右上角按钮WeixinJSBridge.call(hideOptionMenu); });document.addEventListener(WeixinJSBridge…

【经验分享】如何构建openGauss开发编译提交一体化环境

前文 本文适合对openGauss源代码有好奇心的爱好者&#xff0c;那么一个友好的openGauss源代码环境应该是怎么样的。openGauss的开发环境是如何设置的&#xff1f;openGauss的编译环境是如何构建的&#xff1f;如何向openGauss提交代码&#xff0c;笔者集合官方和几位博主实践提…

为什么要学习python?

Python是一种广泛使用的编程语言&#xff0c;它的简洁易读以及强大的功能使得它成为了许多人喜爱的编程语言之一。无论是初学者还是有经验的开发者&#xff0c;学习Python都是非常有价值的。在本篇博文中&#xff0c;我们将探讨学习Python的一些重要原因&#xff0c;并提供一些…

2023年【危险化学品生产单位主要负责人】考试报名及危险化学品生产单位主要负责人模拟考试题

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 危险化学品生产单位主要负责人考试报名考前必练&#xff01;安全生产模拟考试一点通每个月更新危险化学品生产单位主要负责人模拟考试题题目及答案&#xff01;多做几遍&#xff0c;其实通过危险化学品生产单位主要负…

cpp中this和*this区别

大家好&#xff0c;我叫徐锦桐&#xff0c;个人博客地址为www.xujintong.com。平时记录一下学习计算机过程中获取的知识&#xff0c;还有日常折腾的经验&#xff0c;欢迎大家访问。 this&#xff1a;是返回当前对象的地址&#xff08;指向当前对象的指针&#xff09;。 *this&a…

用nodejs爬虫台湾痞客邦相册

情景:是这样的,我想保存一些喜欢的小伙伴的照片,一张张保存太慢了, 所以我写了个js,放在国外服务器爬,国内的自己解决~ 使用方法 1.点相册随便一张, 复制url, 这张开始接下来的图片都会保存 /*** 2023年10月23日 22:58:44* 支持解析痞客邦相册* 只需要复制相册第一张图片的ur…

新款模块上线实现SIP模块与扩拨电话之间打点与喊话功能 IP矿用电话模块SV-2800VP

新款模块上线实现SIP模块与扩拨电话之间打点与喊话功能 IP矿用电话模块SV-2800VP 一、简介 SV-2800VP系列模块是我司设计研发的一款用于井下的矿用IP音频传输模块&#xff0c;可用此模块打造一套低延迟、高效率、高灵活和多扩展的IP矿用广播对讲系统&#xff0c;亦可对传统煤…