AD9371 官方例程裸机SW 和 HDL配置概述(三)

AD9371 系列快速入口

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

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

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

JESD204B相关IP端口信号 : AD9371 官方例程HDL JESD204B相关IP端口信号

裸机程序配置 AD9528、AD9371、FPGA IP 和主函数梳理: AD9371 官方例程裸机SW 和 HDL配置概述(一)

裸机程序配置 AD9528、AD9371、FPGA IP 和主函数梳理: AD9371 官方例程裸机SW 和 HDL配置概述(二)


继续上一讲 AD9371 官方例程裸机SW 和 HDL配置概述(二)内容,重点讲解 util_ad9371_xcvr IP 和 axi_ad9371_tx_clkgen 配置

大部分参数不需要修改, 重要的参数如 TX_OUT_DIV 、QPLL_FBDIV、TX_CLK25_DIV等 ,后续可以通过DRP 重配置,而 num of Lane 等参数 需要正确配置,以例化正确数量的通道

主函数见下一节


文章目录

  • util_ad9371_xcvr
  • axi_ad9371_tx_clkgen

util_ad9371_xcvr

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
TX

TX_NUM_OF_LANES = 4, TX使用的 LANE 通道 ,便于确定后续COMMON 和 Channel 例化数目
TX_OUT_DIV = 2, 初始化 TXOUT_DIV 值,RATE 绑定到 000,D初始为 2 分频,后续通过DRP修改TXOUT_DIV
TX_CLK25_DIV = 5, 生成25MHz的分频系数,5: 100 MHz ≤ TXPLLREFCLK_DIV1 ≤ 125 MHz
TX_LANE_INVERT = 0, 0不反转, 端口TXPOLARITY用于反转输出数据的极性
TX_PI_BIASSET = 1, 配置 TX phase interpolator
TXPI CFG = 0x0054, 配置 TX phase interpolator,仅 UltraScale+ FPGAs
A_TXDIFFCTRL = 5’b10110, 0-31,配置A_TXDIFFCTRL


RX

RX_NUM_OF_LANES = 4, RX 和 RX_OS使用的 LANE 通道
RX_OUT_DIV = 1, 同TX
RX_CLK25_DIV = 5 , 同TX
RX_LANE_INVERT = 0, 同TX

RX_DFE_LPM_CFG = 16’h0104, 配置GTX 使用
RX_PMA_CFG = 0x00018480, 配置GTX 使用 配置 PMA_RSV
RX_CDR_CFG = 0x03000023ff20400020, 配置 GTX 使用

RXCDR_CFG0 = 0x0002, 配置 CDR ,使用向导软件 推荐值
RXCDR_CFG2_GEN2 = “1001100101”, 配置 CDR ,使用向导软件 推荐值
RXCDR_CFG2_GEN4 = 0x00B4, 配置 CDR ,使用向导软件 推荐值
RXCDR_CFG3 = 0x0012, 配置 CDR ,使用向导软件 推荐值
RXCDR_CFG3_GEN2 = “011010”, 配置 CDR ,使用向导软件 推荐值
RXCDR_CFG3_GEN3 = 0x0012, 配置 CDR ,使用向导软件 推荐值
RXCDR_CFG3_GEN4 = 0x0024, 配置 CDR ,使用向导软件 推荐值


QPLL
在这里插入图片描述

QPLL_REFCLK_DIV = 1, M ,QPLL系数,后续DRP可修改,配置 QPLL0_REFCLK_DIV 和 QPLL1_REFCLK_DIV
QPLL_FBDIV = “0001010000”, N ,QPLL系数,后续DRP可修改,QPLL0_FBDIV 和QPLL1_FBDIV

QPLL_FBDIV_RATIO = 1, 配置 GTX
QPLL_CFG = “000011010000000000110000001”, GTX

POR_CFG = 0x0006, 保留 ,使用向导软件 推荐值
PPF0_CFG = 0x0600, 保留 ,使用向导软件 推荐值
QPLL_CFG0 = 0x331C, QPLL0 和 1, 保留 ,使用向导软件 推荐值
QPLL_CFG1 = 0xD038, QPLL0 和 1, 保留 ,使用向导软件 推荐值
QPLL_CFG1_G3 = 0xD038,QPLL0 和 1, 保留 ,使用向导软件 推荐值
QPLL_CFG2 = 0x0FC0,QPLL0 和 1, 保留 ,使用向导软件 推荐值
QPLL_CFG2_G3 = 0x0FC0,QPLL0 和 1, 保留 ,使用向导软件 推荐值
QPLL_CFG3 = 0x0120,QPLL0 和 1, 保留 ,使用向导软件 推荐值
QPLL_CFG4 = 0x0003,QPLL0 和 1, 保留 ,使用向导软件 推荐值
QPLL_CP = “0001111111”, QPLL0 , 保留 ,使用向导软件 推荐值
QPLL_CP_G3 = “0000011111”, QPLL0 , 保留 ,使用向导软件 推荐值
QPLL_LPF = “0100110111”, QPLL0 , 保留 ,使用向导软件 推荐值

GTY4_PPF0_CFG = 0x0800, GTY4


CPLL
在这里插入图片描述

CPLL_FBDIV = 2, CPLL 系数 N2 ,后续DRP可修改
CPLL_FBDIV_4_5 = 5, CPLL 系数 N1,后续DRP可修改

CPLL_CFG0 = 0x01FA,CPLL , 保留 ,使用向导软件 推荐值
CPLL_CFG1 = 0x0023, CPLL , 保留 ,使用向导软件 推荐值
CPLL_CFG2 = 0x0002, CPLL , 保留 ,使用向导软件 推荐值
CPLL_CFG3 = 0x0000, CPLL , 保留 ,使用向导软件 推荐值


GTH4_CH_HSPMUX = 0x2424, 配置 GTH
GTH4_PREIQ_FREQ_BST = 0, 配置 GTH
GTH4_RXPI_CFG0 = 0x0002, 配置 GTH , 保留 ,使用向导软件 推荐值, 仅 UltraScale FPGAs
GTH4_RXPI_CFG1 = 0x0015, 配置 GTH , 保留 ,使用向导软件 推荐值

GTY4_CH_HSPMUX = 0x2020, 配置 GTY
GTY4_PREIQ_FREQ_BST = 0, 配置 GTY
GTY4_RTX_BUF_CML_CTRL = 3’b011, 配置 GTY
GTY4_RXPI_CFG0 = 0x0100, 配置 GTY


axi_ad9371_tx_clkgen

参考 UG572,MMCM框架如下,根据 DS925, Zynq UltraScale+ MPSoC 的MMCM VCO的工作频率为 800 M 到 1600MHz

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

Enable secondary clock input :勾上可以打开MMCM 的 Secondary clock,当 CLK SEL =1,选用 Primary clock ,当 CLK SEL =0,选用 Secondary clock

Enable secondary clock output:勾上可以打开MMCM 输出的第二个 clock,例程例化的 MMCM 输出了3个 OUT CLK,顶层引出了2个,CLK_0 和 CLK_1

CLK OUT 0 和 1的控制参数,后续通过DRP 可以对MMCM 中的这几个参数 重配置
Clk0 Div :公式中的O0,CLKOUT0_DIVIDE_F,1-128,或者 2.000 到 128.000 增量 0.125
Clk0 Phase : CLKOUT0_PHASE,–360.000 to 360.000

Clk1 Div :公式中的O1, CLKOUT1_DIVIDE,1-128
Clk1 Phase : CLKOUT1_PHASE,–360.000 to 360.000

VCO 配置参数,也可以通过DRP修改
Vco Div : 公式中的D, DIVCLK_DIVIDE,1-106
Vco Mul :公式中的 M,CLKFBOUT_MULT_F,2 到128 或 2.000 到 128.000 增量 0.125

CLK_IN 周期 ,也可以通过DRP修改
Clkin Period : CLKIN1, Primary clock 周期 ,0.968 to 100.000,ns
Clkin2 Period : CLKIN2,Secondary clock 周期,0.968 to 100.000,ns

      .DIVCLK_DIVIDE (MMCM_VCO_DIV),.CLKFBOUT_MULT_F (MMCM_VCO_MUL),.CLKOUT0_DIVIDE_F (MMCM_CLK0_DIV),.CLKOUT0_PHASE (MMCM_CLK0_PHASE),.CLKOUT1_DIVIDE (MMCM_CLK1_DIV),.CLKOUT1_PHASE (MMCM_CLK1_PHASE),.CLKIN1_PERIOD (MMCM_CLKIN_PERIOD),.CLKIN2_PERIOD (MMCM_CLKIN2_PERIOD),

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

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

相关文章

【GitHub】Watch、Star、Fork、Follow 有什么区别?

目录 一、前言二、区别1. Watch2. Star3. Fork4. Follow 一、前言 GitHub 是最受欢迎的代码托管平台之一,拥有大量的开源代码可供学习。 Github 中也有类似 “点赞”、“收藏”、“加关注” 的功能。 下面介绍下,GitHub 中 Watch、Star、Fork、Follow 有…

野火霸天虎 STM32F407 学习笔记_1 stm32介绍;调试方法介绍

STM32入门——基于野火 F407 霸天虎课程学习 前言 博主开始探索嵌入式以来,其实很早就开始玩 stm32 了。但是学了一段时间之后总是感觉还是很没有头绪,不知道在学什么。前前后后分别尝试了江协科技、正点原子、野火霸天虎三次 stm32 的课程学习。江协科…

【C++】:类和对象(中):const成员 || 取地址及const取地址操作符重载

📪1.const成员 📪将const修饰的“成员函数”称之为const成员函数,const修饰类成员函数,实际修饰该成员函数隐含的this指针,表明在该成员函数中不能对类的任何成员进行修改 🎈首先我们来想一想为什么在C中…

layui form表单 调整 label 宽度

这个可以调整所有label .layui-form-label {width: 120px !important; } .layui-input-block {margin-left: 150px !important; }情况是这样的&#xff0c;表单里有多个输入框&#xff0c;只有个别label 是长的&#xff0c;我就想调整一下个别长的&#xff0c;其它不变 <di…

非关系型数据库Redis的安装【Linux】及常用命令

前言 Redis&#xff08;Remote Dictionary Server&#xff09;是一种开源的内存数据库管理系统&#xff0c;它以键值存储方式来存储数据&#xff0c;并且支持多种数据结构&#xff0c;如字符串、哈希、列表、集合、有序集合等。Redis最初由Salvatore Sanfilippo开发&#xff0c…

华为升腾C92安装windows NAS

华为升腾C92安装windows NAS NAS&#xff08;Network Attached Storage&#xff1a;网络附属存储&#xff09;&#xff0c;我们之前所了解的群晖&#xff0c;也仅仅是NAS当中的一个品牌运营而已。 这次&#xff0c;我决定在C92上面试着安装Windows NAS。虽然群晖NAS是基于Linu…

sitespeedio.io 前端页面监控安装部署接入influxdb 到grafana

1.docker部署influxdb,部署1.8一下&#xff0c;不然语法有变化后面用不了grafana模板 docker run -d -p 8086:8086 --name influxdb -v $PWD/influxdb-data:/var/lib/influxdb influxdb:1.7.11-alpine docker exec -it influxdb_id bash #influx create user admin with pass…

【计算机网络】运输层

概述运输层服务 运输层协议为运行在不同主机上的应用程序提供了逻辑通信功能。 运输层协议是在端系统中而不是在路由器中实现的。 运输层和网络层的关系&#xff1a; 网络层提供主机之间的逻辑通信&#xff0c;而运输层为**运行在不同主机上的应用程序&#xff08;进程&#…

「视频编码软件」Media Encoder(Me) 2024 Mac/win中文版下载安装

Adobe Media Encoder(Me) 2024是一款专业的视频编码工具&#xff0c;它可以将各种视频格式进行转换、压缩和编码&#xff0c;以满足不同媒体平台和设备的需求。 以下是 Media Encoder 2023 的主要功能和新增功能&#xff1a; 视频编码和转换&#xff1a;支持将各种视频格式进…

Pytorch网络模型训练

现有网络模型的使用与修改 vgg16_false torchvision.models.vgg16(pretrainedFalse) # 加载一个未预训练的模型 vgg16_true torchvision.models.vgg16(pretrainedTrue) # 把数据分为了1000个类别print(vgg16_true) 以下是vgg16预训练模型的输出 VGG((features): S…

2023全新小程序广告流量主奖励发放系统源码 流量变现系统 带安装教程

2023全新小程序广告流量主奖励发放系统源码 流量变现系统 分享软件&#xff0c;吃瓜视频&#xff0c;或其他资源内容&#xff0c;通过用户付费买会员来变现&#xff0c;用户需要付费&#xff0c;有些人喜欢白嫖&#xff0c;所以会流失一部分用户&#xff0c;所以就写了这个系统…

CSGO饰品价格暴跌的原因分析

CSGO饰品暴跌3个月&#xff0c;盘点6大原因 今天我们来聊一下CSGO饰品市场的情况。大部分装备从3月份开始就一直持续走低&#xff0c;到现在已经是7月份了&#xff0c;还有部分饰品呈阴跌趋势。整个市场沉寂一片&#xff0c;还有些悲观主义者天天在吆喝&#xff1a;市场崩盘了&…

【论文阅读笔记】GLM-130B: AN OPEN BILINGUAL PRE-TRAINEDMODEL

Glm-130b:开放式双语预训练模型 摘要 我们介绍了GLM-130B&#xff0c;一个具有1300亿个参数的双语(英语和汉语)预训练语言模型。这是一个至少与GPT-3(达芬奇)一样好的100b规模模型的开源尝试&#xff0c;并揭示了如何成功地对这种规模的模型进行预训练。在这一过程中&#xff0…

香港金融科技周2023:AIGC重塑金融形态

10月31日&#xff0c;由香港财经事务及库务局与投资推广署主办的“香港金融科技周2023大湾区专场”盛大启幕。中国AI决策领先企业萨摩耶云科技集团创始人、董事长兼 CEO林建明受邀参加圆桌会议&#xff0c;与中国内地、香港以及全球金融科技行业顶尖人才、创新企业、监管机构和…

【C++】特殊类设计

文章目录 一、设计一个类&#xff0c;不能被拷贝二、设计一个类&#xff0c;不能被继承三、设计一个类&#xff0c;只能在栈上创建对象四、设计一个类&#xff0c;只能在堆上创建对象五、设计一个类&#xff0c;只能创建一个对象(单例模式) 在某些特殊的场景下&#xff0c;我们…

“免单优选模式:引爆电商革命,颠覆传统购物体验!“

免单优选模式是一种新型的电商销售模式&#xff0c;其核心理念是通过降低商品售价、设置阶梯式奖励以及利用社交关系链&#xff0c;激发消费者购买欲望&#xff0c;实现销售快速增长。 1、合法合规&#xff0c;不存在多层级奖励。 在免单优选模式中&#xff0c;平台不设置多层…

深度学习_8_对Softmax回归的理解

回归问题&#xff0c;例如之前做房子价格预测的线性回归问题 而softmax回归是一个分类问题,即给定一个图片&#xff0c;从猫狗两种动物类别中选出最可靠的那种答案&#xff0c;这个是两类分类问题&#xff0c;因为狗和猫是两类 上述多个输出可以这样理解&#xff0c;假设一个图…

oracle查询数据库内全部的表名、列明、注释、数据类型、长度、精度等

Oracle查询数据库内全部的表名、列明、注释、数据类型、长度、精度 SELECT a.TABLE_NAME 表名, row_number() over(partition by a.TABLE_NAME order by a.COLUMN_NAME desc) 字段顺序,a.COLUMN_NAME 列名, b.COMMENTS 注释,a.DATA_TYPE 数据类型, a.DATA_LENGTH 长度,DATA_SC…

【后端开发】手写一个简单的线程池

半同步半异步线程池 半同步半异步线程池分为三层&#xff1a; 同步服务层 —— 处理来自上层的任务请求&#xff0c;将它们加入到排队层中等待处理。 同步排队层 —— 实际上是一个“同步队列”&#xff0c;允许多线程添加/取出任务&#xff0c;并保证线程安全。 异步服务层…

R语言657中单色colors颜色索引表---全平台可用

R语言657中单色colors颜色索引表—全平台可用