0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

以高速AD9361芯片为例进行数据接口逻辑代码的编写

FPGA之家 来源:时沿科技 作者:ShownSun 2021-06-07 14:34 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

本文通过以高速AD9361芯片为例进行数据接口逻辑代码的编写,利用SelectIO IP快速高效完成芯片驱动的生成。

2 AD93612.1 芯片简介

AD9361是一款面向3G和4G基站应用的高性能、高集成度的射频RF)Agile Transceiver捷变收发器。该器件的可编程性和宽带能力使其成为多种收发器应用的理想选择。该器件集RF前端与灵活的混合信号基带部分为一体,集成频率合成器,为处理器提供可配置数字接口,从而简化设计导入。

AD9361接收器LO工作频率范围为70 MHz至6.0 GHz,发射器LO工作频率范围为47 MHz至6.0 GHz,涵盖大部分特许执照和免执照频段,支持的通道带宽范围为200 kHz以下至56 MHz,整体结构图如图 1 AD9361整体结构图所示。

43a3fe12-c69f-11eb-9e57-12bb97331649.png

图 1 AD9361整体结构图

• 集成12位DACADC的RF 2 × 2收发器

• TX频段:47 MHz至6.0 GHz

• RX频段:70 MHz至6.0 GHz

• 支持TDD和FDD操作

• 可调谐通道带宽:《200 kHz至56 MHz

• 双通道接收器:6路差分或12路单端输入

• 出色的接收器灵敏度,噪声系数为2 dB (800 MHz LO)

• RX增益控制

o 实时监控和控制信号用于手动增益

o 独立的自动增益控制

• 双发射器:4路差分输出

• 高线性度宽带发射器

o TX EVM:≤−40 dB

o TX噪声:≤−157 dBm/Hz本底噪声

o TX监控器:动态范围≥66 dB,精度=1 dB

• 集成式小数N分频频率合成器

• 2.4 Hz最大本振(LO)步长

• 多器件同步

• CMOS/LVDS数字接口

2.2 参数配置

用户可以根据自己的需求将数据接口通过SPI配置成LVDS或CMOS接口,也可以还可以选择FDD或TDD工作方式,以及数据速率可以选择SDR或DDR。只需要通过配置软件设置即可,如图 2 AD9361数据接口配置参数所示,详细的配置教程见AD936x Evaluation Software 详细配置。

在进行数据验证时,也可以使用测试模式,对收发数据进行验证以保证系统的正确性。另外,还可以对输入时钟进行延时调节或者通过SelectIO的delay、delayctrl功能对时钟信号进行微调,以满足时序要求。

芯片数据时钟与数据之间的时序可靠性也可以通过芯片内部的延时寄存器0x006、0x007进行条件,以此达到要求,具体的SPI配置寄存器时序如图 3 AD9361 寄存器配置接口SPI时序所示。此方面不是本文重点,不做展开,更多内容参考官方data sheet。

本小节使用的数据接口参数:LVDS、FDD、DDR,对应的时序逻辑也是根据该参数进行设计。

2.3 引脚

RX数据时序接口如下:

43f14bae-c69f-11eb-9e57-12bb97331649.png

43fc1e62-c69f-11eb-9e57-12bb97331649.png

443c27c8-c69f-11eb-9e57-12bb97331649.png

4466a57a-c69f-11eb-9e57-12bb97331649.png

TX数据时序接口如下:

447336be-c69f-11eb-9e57-12bb97331649.png

448b42a4-c69f-11eb-9e57-12bb97331649.png

44991082-c69f-11eb-9e57-12bb97331649.png

44a3d8c8-c69f-11eb-9e57-12bb97331649.png

2.4 接口时序

以下使用的数据接口参数:LVDS、FDD、DDR,根据不同的通道数可以得到不同的数据时序,用户在解析数据时只要按照对应的结构进行拼接即可。

3 参考代码3.1 SelectIO配置

根据以上对AD9361的了解,就可以轻松的配置SelectIO IP的GUI界面了。芯片既包括发射模块TX又包括接收模块RX,所以IO类型选择chip to chip。

根据上述参数配置部分,自然就选择DDR。数据接口包括时钟CLK、Frame对齐信号与差分数据端Data[05:0],要同时对Frame与Data信号进行时序解析,所以端口宽度设置为7.

由于芯片内部寄存器0x006、0x007可以确保时钟与数据满足时序要求,所以不需要延时模块,以节约FPGA逻辑资源。

3.2 数据解析

//-------------------------------------------------------------------

// 用于将接收时钟与数据进行单端与差分的变换

//-------------------------------------------------------------------

selectio_ip u_selectio_ip (

// From the system into the device

.DATA_IN_FROM_PINS_P (ad_rx_data_in_p),

//从AD接收端接收到的单端数据与标志

.DATA_IN_FROM_PINS_N (ad_rx_data_in_n),

//从AD接收端接收到的单端数据与标志

.DATA_IN_TO_DEVICE (ad_rx_data),

//将AD接收端接收到的数据与标志转换为单端数据

// From the device out to the system

.DATA_OUT_FROM_DEVICE (ad_tx_data),

//将要发送的DA数据与标志转换为单端数据

.DATA_OUT_TO_PINS_P (ad_tx_data_out_p),

//发送端的单端DA数据与标志

.DATA_OUT_TO_PINS_N (ad_tx_data_out_n),

//发送端的单端DA数据与标志

.CLK_TO_PINS_P (ad_fb_clk_p),

//将AD接收端的输入时钟用于发射时钟

.CLK_TO_PINS_N (ad_fb_clk_n),

//将AD接收端的输入时钟用于发射时钟

.CLK_IN_P (ad_data_clk_p),

//AD接收端的单端输入时钟

.CLK_IN_N (ad_data_clk_n),

//AD接收端的单端输入时钟

.CLK_OUT (ad9361_data_clk),

//将AD接收端的差分输入时钟转变为单端时钟

.CLK_RESET (reset),

//用于AD输入时钟的复位,高有效

.IO_RESET (reset)

//用于单端、差分变换的复位,高有效

);

//-------------------------------------------------------------------

//发送数据的生成

//-------------------------------------------------------------------

assign ad_tx0_msb_q=ad_tx0_data[23:18];

assign ad_tx0_lsb_q=ad_tx0_data[17:12];

assign ad_tx0_msb_i=ad_tx0_data[11:06];

assign ad_tx0_lsb_i=ad_tx0_data[05:00];

assign ad_tx1_msb_q=ad_tx1_data[23:18];

assign ad_tx1_lsb_q=ad_tx1_data[17:12];

assign ad_tx1_msb_i=ad_tx1_data[11:06];

assign ad_tx1_lsb_i=ad_tx1_data[05:00];

reg [13:0] ad_tx_data;

//-------------------------------------------------------------------

//选择要发送的I与Q数据

//-------------------------------------------------------------------

always @(posedge ad9361_data_clk or posedge reset) begin

if(reset)

ad_tx_data《=0;

else if((ad_tx_frame_reg==0)&&(ad_tx_frame==1))

ad_tx_data《={ad_tx_frame,ad_tx0_msb_q,ad_tx_frame,ad_tx0_msb_i};

else if((ad_tx_frame_reg==1)&&(ad_tx_frame==1))

ad_tx_data《={ad_tx_frame,ad_tx0_lsb_q,ad_tx_frame,ad_tx0_lsb_i};

else if((ad_tx_frame_reg==1)&&(ad_tx_frame==0))

ad_tx_data《={ad_tx_frame,ad_tx1_msb_q,ad_tx_frame,ad_tx1_msb_i};

else if((ad_tx_frame_reg==0)&&(ad_tx_frame==0))

ad_tx_data《={ad_tx_frame,ad_tx1_lsb_q,ad_tx_frame,ad_tx1_lsb_i};

end

//-------------------------------------------------------------------

//选择接收的I与Q数据

//-------------------------------------------------------------------

always @(posedge ad9361_data_clk or posedge reset) begin

if(reset) begin

ad_rx0_msb_i《=0;

ad_rx0_msb_q《=0;

ad_rx0_lsb_i《=0;

ad_rx0_lsb_q《=0;

ad_rx1_msb_i《=0;

ad_rx1_msb_q《=0;

ad_rx1_lsb_i《=0;

ad_rx1_lsb_q《=0;

end

else if((ad_rx_frame_reg==0)&&(ad_rx_frame==1)) begin

ad_rx0_msb_i《=ad_rx_data[05:0];

ad_rx0_msb_q《=ad_rx_data[12:7];

end

else if((ad_rx_frame_reg==1)&&(ad_rx_frame==1)) begin

ad_rx0_lsb_i《=ad_rx_data[05:0];

ad_rx0_lsb_q《=ad_rx_data[12:7];

end

else if((ad_rx_frame_reg==1)&&(ad_rx_frame==0)) begin

ad_rx1_msb_i《=ad_rx_data[05:0];

ad_rx1_msb_q《=ad_rx_data[12:7];

end

else if((ad_rx_frame_reg==0)&&(ad_rx_frame==0)) begin

ad_rx1_lsb_i《=ad_rx_data[05:0];

ad_rx1_lsb_q《=ad_rx_data[12:7];

end

end

wire [23:0] ad_rx0_fifo_data;

wire [23:0] ad_rx1_fifo_data;

assign ad_rx0_fifo_data={ad_rx0_msb_q,ad_rx0_lsb_q,ad_rx0_msb_i,ad_rx0_lsb_i};

assign ad_rx1_fifo_data={ad_rx1_msb_q,ad_rx1_lsb_q,ad_rx1_msb_i,ad_rx1_lsb_i};

编辑:jq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 芯片
    +关注

    关注

    463

    文章

    54632

    浏览量

    470935
  • 发射器
    +关注

    关注

    7

    文章

    921

    浏览量

    55502

原文标题:FPGA实现AD9361数据接口逻辑

文章出处:【微信号:zhuyandz,微信公众号:FPGA之家】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    AD9361高低温循环测试时,中心频点出现偏重漂移如何矫正?

    使用AD9361进行LTE产品开发,在进行产品的高低温循环测试时,发现射频的中心频点出现严重漂移导致无线链路中断,详见附件图片(1795M正常.jpg 和 1795M异常.jpg,中心频点偏移大于
    发表于 05-22 06:28

    AD9361接收时延不稳定,如何才能让接收时延固定?

    我用ZYNQ+AD9361的架构进行直扩信号自收发(外部将AD9361发射的信号环回至接收端),AD9361的配置在PS侧,参考时钟40M
    发表于 05-13 07:17

    HMC725LC3C高速逻辑芯片:特性、应用与设计要点

    HMC725LC3C高速逻辑芯片:特性、应用与设计要点 在高速电子设计领域,对于高性能逻辑芯片
    的头像 发表于 05-12 15:45 117次阅读

    高速逻辑芯片 HMC723LC3C:设计利器与技术解析

    和丰富的特性,成为众多工程师在高速数据传输和数字逻辑系统设计中的理想选择。今天,我们就来深入了解一下这款芯片。 文件下载: HMC723LC3C.pdf 应用场景与特性亮点 应用场景广
    的头像 发表于 05-12 14:20 173次阅读

    高速逻辑芯片HMC721LP3E:14 Gbps XOR/XNOR门的技术剖析

    高速逻辑芯片HMC721LP3E:14 Gbps XOR/XNOR门的技术剖析 在高速逻辑电路设计领域,对
    的头像 发表于 05-12 14:20 159次阅读

    AD9361 RF Agile Transceiver:高性能射频收发器的技术剖析

    Transceiver,以其卓越的性能和广泛的应用场景,成为了众多工程师的首选。本文将深入剖析AD9361的特性、应用、工作原理等方面,电子工程师们提供全面的技术参考。 文件下载
    的头像 发表于 05-11 14:45 195次阅读

    AD9361 的LO频率偏移是什么原因导致的?如何解决?

    我最近在做卫星接收机 我在测试1561.098MHz的频点的时候,发现频偏,使用了官方的No os和官方的SPI寄存器纯PL端配置 都有频偏,频偏大小在不同使用AD9361的设备上 同一个配置文件
    发表于 05-09 14:40

    关于AD9361接收链路的几何疑问求解

    各位大佬们好!关于AD9361接收链路我有几个个问题: ①其接收端能够接收通过中心频率在70MHz,带宽约为10M的信号吗?我在数据手册中看到关于其模拟(低通)滤波器带宽的限制“ The RX
    发表于 05-09 12:29

    AD9361接收的IQ路数据随机反向如何解决?

    两块AD9361开发板通信,发送板的I路和Q路发同样的信号,接收板收到的I路和Q路数据会出现随机的反向,即有时I路和Q路波形相同,有时I路和Q路波形反向。这种问题该如何解决呢? 谢谢!
    发表于 05-09 07:04

    请问AD9361的DATA_CLK和ADC COLCK RATE的关系是什么?如何配置?

    最近在调试AD9361的BBPLL,目前BB PLL 已经锁定。但不知道DATA_CLK这个时钟怎么配置?和ADC 的采样率有什么关系? 参考时钟40MHz,配置的ADC CLK
    发表于 05-08 07:42

    NICE协处理器接口信号解读--demo

    valid-ready握手协议。 详细说明 在这一部分,我们会结合demo中的具体代码接口信号的行为进行分析。 1.系统信号 nice_clk是系统的时钟信号,nice_rst_n是系统
    发表于 10-31 08:01

    软件无线电-AD9361 璞致 PZSDR 软件无线电系列板卡之PZ-FL9361(FMCOMMS3)使用说明

    是基于AD9361的评估板,通过FMC接口与FPGA连接,支持宽带收发功能。实验部分详细介绍了在璞致FPGA板卡上运行FMCOMMS3系统的步骤,包括固件烧录、网络配置以及使用SDR#和ADIIIOOscilloscope软件进行
    的头像 发表于 09-13 11:07 5070次阅读
    软件无线电-<b class='flag-5'>AD9361</b> 璞致 PZSDR 软件无线电系列板卡之PZ-FL<b class='flag-5'>9361</b>(FMCOMMS3)使用说明

    PZSDR 软件无线电 开发板系列板卡之P201Pro P203Pro 硬件说明—AD9361 AD9363

    璞致PZSDR系列中的P201Pro/P203Pro板卡采用Xilinx ZYNQ7020主控搭配ADI AD9361/AD9363射频芯片(区别在于带宽),板卡提供三种供电方式(XH2.54
    的头像 发表于 08-27 10:18 1959次阅读
    PZSDR 软件无线电 开发板系列板卡之P201Pro P203Pro 硬件说明—<b class='flag-5'>AD9361</b> AD9363

    【PZSDR AD9361】——璞致PZ-FL9361 软件无线电模块:工业级射频解决方案的技术标杆

    璞致电子推出PZ-FL9361软件无线电模块,搭载ADI AD9361射频芯片,实现70MHz-6GHz宽频覆盖与56MHz可调带宽,支持2T2R架构与工业级环境应用。模块兼容主流FPGA平台与开源
    的头像 发表于 07-31 13:50 1186次阅读
    【PZSDR <b class='flag-5'>AD9361</b>】——璞致PZ-FL<b class='flag-5'>9361</b> 软件无线电模块:工业级射频解决方案的技术标杆

    AD9361

    我使用AD9361芯片,参考时钟10MHz,鉴相频率20MHz,设置BBPLL频率800MHz,ADC_CLOCK
    发表于 06-25 15:02