2954|2

6892

帖子

0

TA的资源

五彩晶圆(高级)

楼主
 

基于FPGA的跨时钟域信号处理——专用握手信号 [复制链接]

 在逻辑设计领域,只涉及单个时钟域的设计并不多。尤其对于一些复杂的应用,FPGA往往需要和多个时钟域的信号进行通信。异步时钟域所涉及的两个时钟之间可能存在相位差,也可能没有任何频率关系,即通常所说的不同频不同相。

    1是一个跨时钟域的异步通信实例,发送域和接收域的时钟分别是clk_aclk_b。这两个时钟频率不同,并且存在一定的相位差。对于接收时钟域而言,来自发送时钟域的信号data_a2b有可能在任何时刻变化。



点击看大图


1 跨时钟域通信


    对于上述的异步时钟域通信,设计者需要做特殊的处理以确保数据可靠的传输。由于两个异步时钟域的频率关系不确定,触发器之间的建立时间和保持时间要求也无法得到保证。如果出现建立时间或者保持时间违规,接收域将会采样到处于亚稳态数据,那么后果可想而知。


    如何有效的进行跨时钟域的信号传输呢?最基本的思想是同步,在这个基础上设计者可以利用各种协议约定进行通信。单向控制信号检测方式(前面提到过的脉冲信号检测方法,这里为了和握手方式相区别,所以如此称呼)、握手协议的方式或者借助存储器的方式都是比较常用的处理手段。


    本文将重点介绍握手方式进行异步时钟域的通信。


    2是一个基本的握手通信方式。所谓握手,意即通信双方使用了专用控制信号进行状态指示。这个控制信号既有发送域给接收域的,也有接收域给发送域的,有别于前面的单向控制信号检测方式。



点击看大图


2 握手通信原理


    使用握手协议方式处理跨时钟域数据传输,只需要对双方的握手信号(reqack)分别使用脉冲检测方法进行同步。在具体实现中,假设reqackdata总线在初始化时都处于无效状态,发送域先把数据放入总线,随后发送有效的req信号给接收域。接收域在检测到有效的req信号后锁存数据总线,然后回送一个有效的ack信号表示读取完成应答。发送域在检测到有效ack信号后撤销当前的req信号,接收域在检测到req撤销后也相应撤销ack信号,此时完成一次正常握手通信。此后,发送域可以继续开始下一次握手通信,如此循环。该方式能够使接收到的数据稳定可靠,有效的避免了亚稳态的出现,但控制信号握手检测会消耗通信双方较多的时间。以上所述的通信流程如图3所示。



点击看大图


3 握手通信流程


    下面通过一个简单的工程代码及其仿真测试进一步加深大家对基本握手协议的认识。


module handshack(


                clk,rst_n,


                req,datain,ack,dataout


            );


 


input clk;      //50MHz系统时钟


input rst_n;    //低电平复位信号


 


input req;      //请求信号,高电平有效


input[7:0] datain;  //输入数据


output ack;     //应答信号,高电平有效


output[7:0] dataout;//输出数据,主要用于观察是否和输入一致


 


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


//req上升沿检测


reg reqr1,reqr2,reqr3;


 


always @(posedge clk or negedge rst_n)


    if(!rst_n) begin


            reqr1 <= 1'b1;


            reqr2 <= 1'b1;


            reqr3 <= 1'b1;


        end


    else begin


            reqr1 <= req;


            reqr2 <= reqr1;


            reqr3 <= reqr2;


        end


       


    //pos_req2pos_req1延后一个时钟周期,确保数据被稳定锁存


wire pos_req1 = reqr1 & ~reqr2; //req上升沿标志位,高有效一个时钟周期


wire pos_req2 = reqr2 & ~reqr3; //req上升沿标志位,高有效一个时钟周期


 


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


//数据锁存


reg[7:0] dataoutr;


 


always @(posedge clk or negedge rst_n)


    if(!rst_n) dataoutr <= 8'h00;


    else if(pos_req1) dataoutr <= datain;   //检测到req有效后锁存输入数据


   


assign dataout = dataoutr; 


   


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


//产生应答信号ack


reg ackr;


 


always @(posedge clk or negedge rst_n)


    if(!rst_n) ackr <= 1'b0;


    else if(pos_req2) ackr <= 1'b1;


    else if(!req) ackr <= 1'b0;


 


assign ack = ackr;


 


endmodule


 


    该实例的verilog代码模拟了握手通信的接收域,其仿真波形如图4所示。在发送域请求信号(req)有效的若干个时钟周期后,先是数据(datain)被有效锁存了(dataout),然后接收域的应答信号(ack)也处于有效状态,此后发送域撤销请求信号,接收域也跟着撤销了应答信号,由此完成一次通信。



点击看大图


4 握手通信仿真波形

此帖出自FPGA/CPLD论坛

最新回复

学习一下  详情 回复 发表于 2012-9-18 23:34
点赞 关注
 

回复
举报

4

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
学习一下
此帖出自FPGA/CPLD论坛
 
 

回复

6892

帖子

0

TA的资源

五彩晶圆(高级)

板凳
 
大家相互学习!
此帖出自FPGA/CPLD论坛
个人签名一个为理想不懈前进的人,一个永不言败人!
http://shop57496282.taobao.com/
欢迎光临网上店铺!
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表