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

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

3天内不再提示

采用FPGA器件实现低时域数据异步转换

电子设计 来源:郭婷 作者:电子设计 2019-05-20 08:00 次阅读

随着EDA技术的发展,由于其在电子系统设计领域中的明显优势,FPGA已经在许多方面得到了广泛应用,特别是在无线通信领域,FPGA以其极强的实时性,指令软件编程的极大灵活性赢得了巨大的市场。本文采用FPGA来设计一款广泛应用于计算机、Modem、数据终端以及许多其他数字设备之间的数据传输的专用异步并行通信接口芯片,实现了某一时钟域(如66 MHz)的8位并行数据到另一低时钟域(如40 MHz)16位并行数据的异步转换,并且客户可以根据自己的要求进行数据定义。完成数据在不同时钟域间的正确传递的同时防止亚稳态的出现,保持系统的稳定,是电路设计的关键。

1 时钟域转换中亚稳态的产生

触发器是数字电路设计中的一个重要元件,而触发器工作过程中存在数据建立与保持时间的约束,如果这种约束得不到满足,触发器就会进入某个不确定状态——亚稳态。亚稳态的存在可能导致连锁反应,以致引起整个系统功能混乱。在单时钟域电路设计中由于不存在时钟之间的延迟和错位,所以建立条件和保持条件的时间约束容易满足。而在多时钟域里由于各个模块的异步性,则必须考虑亚稳态的发生,如图1所示。

采用FPGA器件实现低时域数据异步转换

2 多时钟域数据传递方案

多时钟域传递的信号有两种,其一为控制信号,其二为数据流信号。针对这两种不同的信号,分别采取不同方案遏制系统堕入亚稳态。对控制信号采用同步器装置,即在2个不同的时钟域之间插入同步器;而对于不同独立时钟域之间的数据流传递,为了避免异步时钟域产生错误的采样电平,采用FIFO存储器作为其转换接口,在输入端口使用写时钟写数据,在输出端口使用读时钟读数据,这样就完成了异步时钟域之间的数据交换。

芯片的总体逻辑框图如图2所示,图中输入输出信号定义如表1所示。

从逻辑结构上将芯片划分为3块:写时钟域I/OBUFFER、读时钟域I/O BUFFER及FIFO存储器。I/O BUFFER的主要作用是对外部信号进行预处理,消除外部信号的毛刺,保证信号可靠并使外部的信号与时钟信号同步,消除不稳定的因素。根据信号的数目,BUFFER由相应数目的多个D触发器构成。

采用FPGA器件实现低时域数据异步转换

FIFO存储器结构框图如图3所示,他由双端口存储器(Dual Port RAM)、写控制单元(Writc Control)和读控制单元(Read Control)构成。其中DUAL PORT RAM是由ISE6.0的一个编辑软件CORE GENERATER自动生成,使用者只需设定RAM的端口数、内存大小和渎写控制便可以生成一个适合程序的子模块。由于读写时钟属于不同的时钟域,满帧信号Frame从写控制单元向读控制单元传递时必须采取同步器(Synchronizer)同步。

采用FPGA器件实现低时域数据异步转换

2.1 写控制单元设计

写控制单元主要的功能是根据写数据有效信号wdataen判断输入数据是否正确,在检测到写入数据帧的开始标志位wsof后开始计数控制写指针waddr的移动,将正确的数据写入DUAL PORT RAM中,并在一帧数据写满后向读控制单元发出写数据满帧信号wframe。为防止亚稳态的出现,设计中采取了两个措施:一是采用锁存器将帧头信号wsof拉长,确保其被稳定的采集;二是采用Gray编码计数器替代普通二进制编码计数器来控制写指针waddr的移动,因为Gray码相邻两个编码之间有且只有1位发生变化从而抑制了竞争冒险的出现。

2.2 同步器设计

写控制单元发出的写数据满帧信号wframe属于控制信号,他从写时域进入读时域必须采用同步器实现信号同步,将写时域的满帧信号wframe变换为读时域的满帧信号rframe。由于信号是从高时钟域(66 MHz)流向低时钟域(40 MHz),因此采用如图4所示的同步器。

采用FPGA器件实现低时域数据异步转换

同步器时序图如图5所示,可见在写时域的满帧信号wframe经过3个clka周期延后跨越到读时钟域。

采用FPGA器件实现低时域数据异步转换

2.3 读控制单元设计

数据从写时域传递到读时域,时钟发生了变化,而且读控制单元的行为受到写控制单元及Dual Port RAM中数据的存储情况的双重制约,因此他的设计是整个芯片设计成功的关键。

由于当Dual Port RAM中写入一帧完整的正确数据后才能输出,所以读控制首先必须判断Dual Port RAM一帧是否写满。榆测到满帧信号rframe后,在等待输出数据帧头信号rfp到来后控制读指针waddr移动读出数据,并置位rvalid表征输出数据的可靠性。

部分程序没计如下:

采用FPGA器件实现低时域数据异步转换

采用FPGA器件实现低时域数据异步转换

3 多时钟域数据传递的FPGA实现

设计方案完成后选用Xilinx Spartan.II FPGA实现电路,并在XilinxISE6.0集成环境下用Modelsim5.7进行了电路仿真

图6为写使能信号dataen恒为有效值“1”的仿真结果截图。

采用FPGA器件实现低时域数据异步转换

可见,在写使能信号dataen恒为有效值“1”的情况下,在写时钟clka控制下当写数据帧头信号sof有效时,写控制器开始写入数据,接收到连续8个数据后,写控制器发出一个帧满信号wframe。wframe信号经过异步转换后转换成clkb时钟域的信号。在读控制器的控制下,当clkb时钟处于上升沿,并且检测到读出数据帧头fp时,开始从outdata向外发送数据,并将valid置为有效。

图7为当写使能信号dataen变化时的仿真结果截图。

可见,将dataen置低后,系统不再接受写入数据,所以也不再输出数据,valid被置为低电平,输出数据无效。写控制的使能端控制达到要求。

采用FPGA器件实现低时域数据异步转换

4 结 语

针对异步并行通信接口芯片设计中涉及的多时钟域的数据传递问题,本文采用FIFO存储器来完成不同时钟域之间数据流传递、同步器来完成控制信号传递的方案。仿真验证结果表明,数据传递准确、稳定、可靠,没有出现竞争冒险和亚稳态,完全达到了设计要求。


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

    关注

    1629

    文章

    21753

    浏览量

    604193
  • 存储器
    +关注

    关注

    38

    文章

    7512

    浏览量

    163980
  • 触发器
    +关注

    关注

    14

    文章

    2000

    浏览量

    61212
收藏 人收藏

    评论

    相关推荐

    基于FPGA异步FIFO的实现

    大家好,又到了每日学习的时间了,今天我们来聊一聊基于FPGA异步FIFO的实现。 一、FIFO简介 FIFO是英文First In First Out 的缩写,是一种先进先出的数据
    的头像 发表于 06-21 11:15 6530次阅读
    基于<b class='flag-5'>FPGA</b>的<b class='flag-5'>异步</b>FIFO的<b class='flag-5'>实现</b>

    基于FPGA器件实现异步FIFO读写系统的设计

    异步 FIFO 读写分别采用相互异步的不同时钟。在现代集成电路芯片中,随着设计规模的不断扩大,一个系统中往往含有数个时钟,多时钟域带来的一个问题就是,如何设计异步时钟之间的接口电路。
    发表于 07-16 17:41 1247次阅读
    基于<b class='flag-5'>FPGA</b><b class='flag-5'>器件</b><b class='flag-5'>实现</b><b class='flag-5'>异步</b>FIFO读写系统的设计

    多时钟域数据传递的Spartan-II FPGA实现

    FPGA来设计一款广泛应用于计算机、Modem、数据终端以及许多其他数字设备之间的数据传输的专用异步并行通信接口芯片,实现了某一时钟域(如6
    发表于 09-07 09:16

    FPGA参赛作品】生理电信号同步多通道数据采集系统的设...

    【背景】针对当前生理电信号采集设备多为异步数据采集设备,高速模拟复用开关无法实现理想开、关状态,各信号通道串扰较大,开关的开启、关闭无法实现时域同步;依据数字信号处理理论:
    发表于 06-14 00:11

    采用FPGA的数字视频接口转换设备设计

    引言  本文从实际应用的角度出发,采用FPGA作为主控芯片,设计了一款数字视频接口转换设备,该设备针对于MT9M111这款数字图像传感器产生的ITU-R BT.656格式数据进行采集、
    发表于 04-17 07:00

    采用FPGA的数字视频接口转换设备

    作者:武汉大学物理科学与技术学院 赵东方 李雄 于心亮 程方敏引言本文从实际应用的角度出发,采用FPGA作为主控芯片,设计了一款数字视频接口转换设备,该设备针对于MT9M111这款数字图像传感器产生
    发表于 04-23 07:00

    采用FT245BM和FPGA实现USB接口设计

    USB数据与并行I/O口数据的交换缓冲区。FIFO实现与外界(微控制器、FPGA或其它器件)的接口,主要通过8根
    发表于 04-26 07:00

    采用FPGA实现数字视频转换接口设计

    引言   本文从实际应用的角度出发,采用FPGA作为主控芯片,设计了一款数字视频接口转换设备。 该设备针对于MT9M111这款数字图像传感器产生的ITU-R BT.656格式数据进行采
    发表于 05-05 09:29

    采用FPGA的数字视频接口转换设备设计

    引言本文从实际应用的角度出发,采用FPGA作为主控芯片,设计了一款数字视频接口转换设备,该设备针对于MT9M111这款数字图像传感器产生的ITU-R BT.656格式数据进行采集、色彩
    发表于 05-29 05:00

    等效时间采样技术的原理作用及采用FPGA器件实现系统的设计

    的频率,但是由于系统的ADC 器件时钟速率并不能达到要求的高频速率或者存储处理速度等不能满足要求因此我们可以采用低速ADC 器件通过等效时间采样来对宽带模拟信号进行数据采集从而使系统易
    发表于 10-21 16:43

    请问怎么采用FPGA和集成器件实现IJF编码?

    IJF编码是什么原理?如何实现IJF编码?采用FPGA和集成器件实现IJF编码
    发表于 04-13 06:56

    如何实现时域数据异步转换

    时钟域转换中亚稳态是怎样产生的?多时钟域数据传递的FPGA实现
    发表于 04-30 06:06

    同步异步通信转换的CPLD_FPGA设计

    同步异步通信转换的CPLD_FPGA设计,有需要的下来看看
    发表于 12-16 22:13 8次下载

    采用FPGA器件和模数转换实现A/D数据采集卡的设计

    可编程逻辑器件(又称FPGA)EPM7128SQC100-7和AD公司的高速模数转换器(A/D)AD9054BST-135来实现
    的头像 发表于 03-04 08:10 3558次阅读
    <b class='flag-5'>采用</b><b class='flag-5'>FPGA</b><b class='flag-5'>器件</b>和模数<b class='flag-5'>转换</b>器<b class='flag-5'>实现</b>A/D<b class='flag-5'>数据</b>采集卡的设计

    采用StratixⅡ FPGA器件提高加法树性能并实现设计

    图2列出了和传统的4输入LUT结构的FPGA相比较,采用ALM的StratixⅡFPGA器件例化3输入加法器的优势。从图2中可以清楚地看出,对于同样3个2 b
    发表于 03-03 10:45 1284次阅读
    <b class='flag-5'>采用</b>StratixⅡ <b class='flag-5'>FPGA</b><b class='flag-5'>器件</b>提高加法树性能并<b class='flag-5'>实现</b>设计