【AD9361 数字接口CMOS LVDSSPI】B 并行数据之CMOS

2023-10-29 00:04

本文主要是介绍【AD9361 数字接口CMOS LVDSSPI】B 并行数据之CMOS,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

##接上一篇;
本节介绍 AD9361 数字接口CMOS &LVDS&SPI最后一张表中四种工作模式的具体配置及时序波形图。

目录

  • 1、单端口半双工模式 (CMOS) *代称 SHC*
      • 换句话说,最大值是12‘b0111_1111_1111,即0x7FF,最小值的数字量是12‘b0111_1111_1111,即 0x800。
          • 这里提个问题,byte的范围是 -127~127 ? 还是 -128 ~127? 答案放在最后一篇吧
    • 单端口TDD 时序(CMOS)
  • 2、单端口全双工模式 (CMOS) *代称 SFC*
      • 最大值是12‘b0111_1111_1111,即0x7FF;第一个字节是6‘b01_1111,即 0x1F,第二个字节是6'b11_1111 ,即0x3F。注意这里的“字节”不是8bit的标准字节。
      • 最小值的数字量是12‘b0111_1111_1111,即 0x800;同理,第一个字节为 0x20,第二个字节为 0x00。
    • 单端口TDD 时序(CMOS)
  • 3、双端口半双工模式 (CMOS) *代称 DHC*
      • 最大值是12‘b0111_1111_1111,即0x7FF,最小值的数字量是12‘b0111_1111_1111,即 0x800。
    • 双端口TDD时序(CMOS)
  • 4、双端口全双工模式 (CMOS) *代称 DDC*
      • 最大值是12‘b0111_1111_1111,即0x7FF,最小值的数字量是12‘b0111_1111_1111,即 0x800。
    • 双端口FDD 时序(CMOS)

1、单端口半双工模式 (CMOS) 代称 SHC

【SINGLE PORT HALF DUPLEX MODE (CMOS)】

SHC模式用于需要TDD操作和数据速率低于61.44 MHz的应用。

在这种模式下,总线以双向方式使用,因此可以在同一条线路上接收或传输数据。此模式可用于所有接收器-发送器配置(1R1T、2R1T、1R2T 和 2R2T),通常用于 PCB 空间有限或 BBP 只有一个数据总线端口可用的情况。在此配置中,总线可以作为单数据速率 (SDR) 或双数据速率 (DDR) 运行。在此模式下,启用的端口在传输和接收操作之间多路复用,而未使用的端口被禁用。
使能端口由 SPI 寄存器0x012中的交换端口位确定。下图显示了AD9361与BBP在这种工作模式下的连接。
在这里插入图片描述

在Rx突发期间,D[11:0]由AD9361驱动,因此DATA_CLKD[11:0]之间的建立和保持时间允许BBP使用DATA_CLK捕获数据。
同样,在Tx突发期间,D[11:0]由BBP驱动,因此FB_CLK
D[11:0]之间的建立和保持时间允许AD9361使用FB_CLK捕获数据。
ENABLE
信号脉冲(或变为高电平)时,数据传输开始,数据传输结束被标记为ENABLE线路上的另一个脉冲(或当它返回低电平时)。
数据传输的方向由TXNRX信号决定。当该信号为低电平且ENSM处于Rx或FDD状态时,总线配置为接收方向(数据从AD9361传输到BBP)。当TXNRX被驱动为高电平ENSM已脱离Rx或FDD状态时,ENSM将总线更改为发送方向(数据从BBP传输到AD9361)。
Rx_FRAMETx_FRAME 信号表示一组(帧)数据样本的开始。Rx_FRAME可以设置为在每次数据传输的突发开始时发生一次(仅一次高转换),或者在每帧开始时有一个上升沿,并以 50% 的占空比重复,直到数据传输完成。同样,Tx_FRAME接受 BBP 中的任一格式。

在传输突发期间,BBP 使用 FB_CLK 和 Tx_FRAME 驱动 P0_D[11:0] 上的数据值。在Rx突发期间,AD9361使用DATA_CLK和Rx_FRAME驱动P0_D[11:0]上的数据值。

采样数据以二进制补码格式进行,其中D[11]为数值最高有效位,D[0]为最低有效位。

换句话说,最大值是12‘b0111_1111_1111,即0x7FF,最小值的数字量是12‘b0111_1111_1111,即 0x800。

这里提个问题,byte的范围是 -127~127 ? 还是 -128 ~127? 答案放在最后一篇吧

在这种模式下,I 和 Q 数据样本在数据总线上时间交错。对于每个方向的单个射频路径(1R1T 系统),I 和 Q 样本以 2 路交错方式传输:
I, Q, I, Q, …
对于使用两个 Rx/Tx 通道的系统,来自 RF 通道 1 和 2 的 I 和 Q 样本以 4 路交错方式传输:
I1 , Q1 , I2 , Q2, I1 , Q1, I2, Q2, … …
当 配置为2R1T 或 1R2T 的系统,时钟频率、采样周期和数据捕获时序与为配置为2R2T 系统,所配置的时钟频率、采样周期和数据捕获时序相同。
但是,在仅使用单个通道的路径中,每个数据组中禁用通道的 I-Q 数据对未使用。AD9361忽略这些未使用的数据位。例如,在仅使用 Tx 通道 1 的 2R1T 系统中,发射突发将有两个未使用的时隙,如下所示:
I, Q, X, X, I, Q, X, X, …
BBP 可能会用任意数据值填充未使用的 X 数据位。这些值可以是固定的常数值,也可以重复前面的数据采样值以降低总线开关因数,减少反转功耗。

单端口TDD 时序(CMOS)

SINGLE PORT TDD FUNCTIONAL TIMING

本小节附图中的时序图说明了单端口TDD模式下总线信号之间的关系。这些图显示了 SDR 和 DDR 工作模式的时序示例。对于本节的所有后续部分,将仅显示 DDR 时序。本小节附图还包括 1R1T 场景的时序图,其中设置了 2R2T 时序位,强制数据传输格式与 2R2T 情况相同。此模式适用于可能需要在单通道和多通道操作之间切换但无法更改其数据传输格式的单端口系统。如果设备未配置 1R1T 模式,则 2R2T 位不起作用。

请注意,Tx_FRAME 和 Tx 数据的传输必须满足与 FB_CLK 相关的建立和保持要求。除了 1R1T 和 2R2T 场景外,还显示了 1R2T 和 2R1T 配置,以说明它们的时序与 2R2T 配置相同。在其他模式下,接收器和发射器通道的不同组合的行为也遵循 2R2T 时序行为,因此对于所有后续部分,图中省略了这些图。
在这里插入图片描述在这里插入图片描述
注意 :并行端口配置寄存器 0x010-0x012寄存器值
在这里插入图片描述这1bit 设置为“0”时,使用DATA_CLK的双边沿;设置“1”时,使用DATA_CLK的单边沿。

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

2、单端口全双工模式 (CMOS) 代称 SFC

SINGLE PORT FULL DUPLEX MODE (CMOS)

SFC模式用于需要FDD操作且数据速率低于30.72 MHz的应用。

在这种模式下,总线被分成两半,其中 6 位专用于 Rx 数据,6 位专用于 Tx 数据。此模式可用于所有接收机-发射机配置。在此配置中,总线可以作为 SDR 或 DDR 运行。在此示例中,仅启用 P0,并将数据总线拆分为单独的子总线。每个子总线同时工作,允许BBP和AD9361之间实现发送和接收数据的全双工。由于总线必须完成两倍于全双工模式的数据传输,因此数据总线必须以两倍于 TDD 模式的速度运行,以实现相同的发送和接收数据速率(因为每个总线在全双工模式下同时运行)。
在这里插入图片描述

上图显示了AD9361与BBP在SFC工作模式下的连接

发送数据由BBP驱动P0_D[11:6],因此FB_CLK和P0_D之间的建立和保持时间[11:6]允许AD9361使用FB_CLK来捕获数据。接收数据由AD9361在P0_D[5:0]上驱动,因此DATA_CLK和到达BBP的P0_D[5:0]之间的建立和保持时间使BBP能够使用DATA_CLK来捕获数据。ENABLE引脚上的一个脉冲(或上升沿)触发数据传输的开始,另一个脉冲(或下降沿)表示数据传输的结束。

Rx_FRAME 和 Tx_FRAME 信号表示一组(帧)数据样本的开始。Rx_FRAME信号可以设置为在每次数据传输的突发开始时出现一次(仅一次高电变),或者在每帧开始时有一个上升沿,并以 50% 的占空比重复,直到数据传输完成。同样,Tx_FRAME接受 BBP 中的任一格式。

发送数据样本以二进制补码格式传输,第一个 6 位字节 (P0_D[11:6]) 包含 MSB,第二个 6 位字节 (P0_D[11:6]) 包含 LSB。 P0_D[11] 是数值最高有效位,P0_D[6] 是最低有效位。
接收数据样本也以二进制补码格式传输,第一个 6 位字节 (P0_D[5:0]) 包含 MSB,第二个 6 位字节 (P0_D[5:0]) 包含 LSB。P0_D[5] 是数值最高有效位,P0_D[0] 是最低有效位。
在这两种情况下,就是原来12bit拆分2次6bit,发送或接受,之后再还原恢复;

最大值是12‘b0111_1111_1111,即0x7FF;第一个字节是6‘b01_1111,即 0x1F,第二个字节是6’b11_1111 ,即0x3F。注意这里的“字节”不是8bit的标准字节。

最小值的数字量是12‘b0111_1111_1111,即 0x800;同理,第一个字节为 0x20,第二个字节为 0x00。

在这种模式下,I 和 Q 数据样本在数据总线上时间交错。对于每个方向的单个射频路径(1R1T 系统),数据以 4 路交错方式传输,如下所示:

I MSB` , Q MSB , ILSB , Q LSB , …

对于具有两个有源 Rx/Tx 通道的系统,来自 RF 通道 1 和通道 2 的 I 和 Q 样本以 8 路交错方式传输,如下所示:

I1MSB , Q 1MSB , I 1LSB , Q 1LSB , I2MSB ,Q 2MSB ,I2LSB ,Q2LSB , …

对于具有 2R1T 或 1R2T 配置的系统,时钟频率、采样周期和数据捕获时序与为 2R2T 系统配置的时钟频率相同。但是,在仅使用单个通道的路径中,每个数据组中禁用通道的 I-Q 数据对未使用。AD9361忽略这些未使用的通道。例如,对于使用发射通道 1 的 2R1T 系统,突发发射将有四个未使用的时隙,如下所示:

I1MSB ,Q1MSB,I1LSB,Q1LSB,X,X,X,X, X , …

BBP 可以用任意数据值填充未使用的 X 通道。这些值可以是常量值,也可以重复上述数据采样值,以降低总线开关系数,从而降低功耗。

单端口TDD 时序(CMOS)

下面的时序图说明了单端口FDD模式下总线信号之间的关系。请注意,由于 2R1T 和 1R2T 系统遵循 2R2T 时序图,因此省略了它们。
在这里插入图片描述
在这里插入图片描述

3、双端口半双工模式 (CMOS) 代称 DHC

DUAL PORT HALF DUPLEX MODE (CMOS)

DHC模式用于需要TDD操作和高达122.88 MHz数据速率的应用。

在此模式下,使用两个数据端口,P0分配给I数据,P1分配给Q数据。端口在此模式下双向运行,数据方向由哪个通道处于活动状态决定:发送或接收。在此配置中,每条总线都可以作为 SDR 或 DDR 运行。此模式可用于所有接收机-发射机配置。
下图显示了AD9361与BBP在这种工作模式下的连接。
在这里插入图片描述

在Rx突发期间,两个端口均由AD9361驱动,因此DATA_CLK与到达BBP的每个数据样本之间的建立和保持时间使BBP能够使用DATA_CLK捕获数据。当ENABLE信号脉冲(或变为高电平)时,数据传输开始,数据传输结束被标记为ENABLE线路上的另一个脉冲(或当它返回低电平时)。

数据传输的方向由TXNRX信号决定。当该信号为低电平且AD9361处于FDD状态或Rx状态时,ENSM在接收方向上配置总线(数据从AD9361传输到BBP)。所有其他状态都会导致总线设置为高阻抗。当TXNRX被驱动为高电平时,ENSM将总线更改为发送方向(数据从BBP传输到AD9361)。在发射突发期间,两个端口(P0_D[11:0]和P1_D[11:0])均由BBP驱动,因此FB_CLK和每个D[11:0]之间的建立和保持时间允许AD9361使用FB_CLK捕获数据。

Rx_FRAME 和 Tx_FRAME 信号表示一组(帧)数据样本的开始。Rx_FRAME信号可以设置为在突发开始时出现一次(仅一次高电平转换),或者在每帧开始时有一个上升沿,并具有 50% 的占空比。同样,Tx_FRAME接受 BBP 中的任一格式。

数据样本以二进制补码格式进行,其中D[11]为数值最高有效位,D[0]为最低有效位。

最大值是12‘b0111_1111_1111,即0x7FF,最小值的数字量是12‘b0111_1111_1111,即 0x800。

对于每个方向上的单个射频路径(即 1R1T 系统),I 和 Q 样本分别用 P0_D[11:0] 上的 I 数据和 P1_D[11:0] 上的 Q 数据分开,如下所示:
P0: I, I, I, …
P1: Q, Q, Q, …
对于具有两个有源 Rx 通道的系统,RF 路径 1 和 RF 路径 2 的 I 和 Q 采样与 P0 上的 I 采样和 P1 上的 Q 采样以 2 路交错方式传输。
P0: I1 , I2 , I1, I2, …
P1: Q1, Q2, Q1, Q2, …
对于配置为 2R1T 或 1R2T 的系统,时钟频率、采样周期和数据捕获时序与配置为 2R2T 系统配置的时钟频率相同。
但是,在仅使用单个通道的路径中,每个数据组中禁用通道的 I-Q 数据对未使用。例如,对于仅使用 Tx 通道 1 的 2R1T 系统,Tx 突发将有两个未使用的通道,如下所示:
AD9361捕获
P0: I1, X, I1, X , …
P1: Q1,X,Q1,X , …
BBP 可以用任意数据值填充未使用的 X通道。这些值可以是常量值,也可以重复前面的数据采样值,以降低总线开关系数,从而降低功耗。

双端口TDD时序(CMOS)

DUAL PORT TDD FUNCTIONAL TIMING (CMOS)

下图的时序图说明了双端口TDD模式下总线信号之间的关系。请注意,由于 2R1T 和 1R2T 系统遵循 2R2T 时序图,因此省略了它们。
在这里插入图片描述在这里插入图片描述

4、双端口全双工模式 (CMOS) 代称 DDC

DUAL PORT FULL DUPLEX MODE (CMOS)

DDC模式(全端口)用于需要FDD操作且数据速率低于61.44 MHz的应用。
在此模式下,使用两个数据端口,P0 用于接收数据,P1 用于传输数据。每条总线同时工作,允许在BBP和AD9361之间全双工传输Tx和Rx数据。对于此模式,每条数据总线必须以双端口TDD模式的两倍速度运行,才能实现相同的Tx和Rx数据速率(因为每个总线在全双工模式下同时运行)。在此配置中,每条总线都可以作为 SDR 或 DDR 运行。此模式可用于所有接收机-发射机配置。
下图显示了AD9361与BBP在这种工作模式下的连接。
在这里插入图片描述

发送数据由BBP以P1_D[11:0]驱动,因此FB_CLK和数据之间的建立和保持时间允许AD9361使用FB_CLK来捕获数据。接收数据由AD9361以P0_D[11:0]驱动,因此DATA_CLK与到达BBP的数据之间的建立和保持时间使BBP能够使用DATA_CLK捕获数据。ENABLE引脚上的一个脉冲(或上升沿)触发数据传输的开始,另一个脉冲(或下降沿)表示数据传输的结束。
Rx_FRAME 和 Tx_FRAME 信号表示一组(帧)采样数据的开始。Rx_FRAME可以设置为在每次数据传输的突发开始时发生一次(仅一次高电平转换),也可以设置为在每帧开始时有一个上升沿,并以 50% 的占空比重复,直到数据传输完成。同样,Tx_FRAME接受 BBP 中的任一格式。

Tx 采样数据以二进制补码格式进行。P1_D[11]是数值最高有效位,P1_D[0]是最低有效位。Rx 采样数据也以二进制补码格式进行。P0_D[11]是数值最高有效位,P0_D[0]是最低有效位。

最大值是12‘b0111_1111_1111,即0x7FF,最小值的数字量是12‘b0111_1111_1111,即 0x800。

I和Q采样数据在每个方向上都在同一数据总线上传输。对于每个方向的单个射频路径,数据传输如下:
Px: I, Q, I, Q, I, Q, …
对于具有两个 Rx/Tx 通道的系统,来自 RF 通道 1 和 2 的 I 和 Q 样本携带如下:
Px: I1 , Q1, I2, Q2, …

对于具有 2R1T 或 1R2T 配置的系统,时钟频率、采样周期和数据捕获时序与为 2R2T 系统配置时相同。但是,在仅使用单个通道的路径中,每个数据组中禁用通道的 I-Q 数据对未使用。AD9361忽略这些未使用的通道。例如,对于使用 Tx 通道 1 的 2R1T 系统,Tx 突发将有两个未使用的通道,如下所示:
AD9361捕获
P1:I1、Q1、X、X…
BBP 可能会用任意数据值填充未使用的 X 通道。这些值可以是常量值,也可以重复前面的数据采样值,以降低总线开关系数,从而降低功耗。

双端口FDD 时序(CMOS)

下图的时序图说明了双端口全双工模式下总线信号之间的关系。请注意,由于 2R1T 和 1R2T 系统遵循 2R2T 时序图,因此省略了它们。
在这里插入图片描述
在这里插入图片描述

这篇关于【AD9361 数字接口CMOS LVDSSPI】B 并行数据之CMOS的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

SpringBoot中4种数据水平分片策略

《SpringBoot中4种数据水平分片策略》数据水平分片作为一种水平扩展策略,通过将数据分散到多个物理节点上,有效解决了存储容量和性能瓶颈问题,下面小编就来和大家分享4种数据分片策略吧... 目录一、前言二、哈希分片2.1 原理2.2 SpringBoot实现2.3 优缺点分析2.4 适用场景三、范围分片

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

SpringBoot+Redis防止接口重复提交问题

《SpringBoot+Redis防止接口重复提交问题》:本文主要介绍SpringBoot+Redis防止接口重复提交问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录前言实现思路代码示例测试总结前言在项目的使用使用过程中,经常会出现某些操作在短时间内频繁提交。例

浅析如何保证MySQL与Redis数据一致性

《浅析如何保证MySQL与Redis数据一致性》在互联网应用中,MySQL作为持久化存储引擎,Redis作为高性能缓存层,两者的组合能有效提升系统性能,下面我们来看看如何保证两者的数据一致性吧... 目录一、数据不一致性的根源1.1 典型不一致场景1.2 关键矛盾点二、一致性保障策略2.1 基础策略:更新数

Oracle 数据库数据操作如何精通 INSERT, UPDATE, DELETE

《Oracle数据库数据操作如何精通INSERT,UPDATE,DELETE》在Oracle数据库中,对表内数据进行增加、修改和删除操作是通过数据操作语言来完成的,下面给大家介绍Oracle数... 目录思维导图一、插入数据 (INSERT)1.1 插入单行数据,指定所有列的值语法:1.2 插入单行数据,指