4733|4

3

帖子

0

TA的资源

一粒金砂(中级)

楼主
 

高速数据并串转换,上升沿下降沿采样问题 [复制链接]

小弟碰到一个FPGA中的设计问题,如下所述:

需要实现500MSPS的高速DA转换,所选的DA器件AD9734中给出了在FPGA中的数据源的参考设计:


即在FPGA中实现一个并串转换功能,将两路250MSPS的数据(DATA1和DATA2)合成一路500MSPS数据(DB)输出给DA。图中给出的并串转换电路要求在时钟上升沿对DATA1采样,在下降沿对DATA2采样,小弟以前从未涉及过如此高频的时钟设计,不知该如何编写代码实现这段逻辑电路?

这是小弟写的verilog代码,从仿真的结果(附件中所示)来看,感觉数据的时序问题很严重,不知各位大哥有何建议?



module data_change(clk, reset, data1, data2, logic0, logic1, DB, dataclk, D1, D2, D1_temp, D2_temp);
        input clk, reset;
        input [7:0]data1, data2;
        input logic0, logic1;
        output [7:0]DB;
        output dataclk;
       
        output [7:0]D1, D2;
        output [7:0]D1_temp, D2_temp;
       
        reg [7:0]DB;
        reg dataclk;

       
        reg [7:0]data1_temp, data2_temp;
        reg [7:0]D1, D2;
        reg [7:0]D1_temp, D2_temp;
//        wire clk_neg;
       
//        assign clk_neg = ~clk;
       
        always @(posedge clk or negedge reset) begin
                if(~reset) begin
                        data1_temp <= 8'b00000000;
                        data2_temp <= 8'b00000000;
                end
                else begin
                        data1_temp <= data1;
                        data2_temp <= data2;
                end
        end

        always @(posedge clk or negedge reset) begin
                if(~reset) begin
                        D1 <= 8'b00000000;
                        D1_temp <= 8'b00000000;
                end
                else begin
                        D1 <= data1_temp;
                        D1_temp <= D1;
                end               
        end

        always @(negedge clk or negedge reset) begin
                if(~reset) begin
                        D2 <= 8'b00000000;
                        D2_temp <= 8'b00000000;
                end
                else begin
                        D2 <= data2_temp;
                        D2_temp <= D2;
                end       
        end
       
        always @(clk, D1, D2)
                if(~clk)
                        DB = D1;
                else
                        DB = D2;
                       
        always @(clk)
                if(~clk)
                        dataclk = logic0;
                else
                        dataclk = logic1;

endmodule
此帖出自FPGA/CPLD论坛

最新回复

kdy
FPGA内部有DDR的模块,必须用原语调用或者megacore里生成。不是HDL语言的功能  详情 回复 发表于 2013-11-9 21:29
点赞 关注
 

回复
举报

387

帖子

0

TA的资源

纯净的硅(初级)

沙发
 
可以去看看ADI的Demo板的程序。
此帖出自FPGA/CPLD论坛

点评

谢谢你的回复,不过貌似公司给出的参考程序都是C语言程序,而且主要是SPI接口的控制那块,打算四处问问。。  详情 回复 发表于 2013-11-7 10:13
 
 

回复

3

帖子

0

TA的资源

一粒金砂(中级)

板凳
 

回复 沙发hjf2002 的帖子

谢谢你的回复,不过貌似公司给出的参考程序都是C语言程序,而且主要是SPI接口的控制那块,打算四处问问。。
此帖出自FPGA/CPLD论坛
 
 
 

回复

447

帖子

30

TA的资源

五彩晶圆(初级)

4
 
同是新手, 希望有助

assign dataclk = clk;

always @(clk)
                if(~clk)
                        DB <=  data2;
                else
                        DB <=  data1;
此帖出自FPGA/CPLD论坛
个人签名www.ctdisk.com/u/1283024
个人书库,持续更新中。
 
 
 

回复

581

帖子

0

TA的资源

五彩晶圆(初级)

5
 
FPGA内部有DDR的模块,必须用原语调用或者megacore里生成。不是HDL语言的功能
此帖出自FPGA/CPLD论坛
个人签名Net:Wxeda.taobao.com
QQ:1035868547
Blog:https://home.eeworld.com.cn/space-uid-390804.html
 
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

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

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

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

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

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

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