完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
大家好
我是硕士论文的学生,我对FPGA编程没有太多经验,所以请耐心等待。 我正在使用Opal Kelly的XEM6010 spartan 6模块作为我的论文项目。 我所要做的就是在主机(FPGA)和从机(ADC)之间建立SPI通信,相对较低的频率为80MHz(带串行接口的1MSps ADC,实现最大采样率所需的80MHz时钟) ¯¯¯¯¯ _____ /¯¯¯¯¯ _____ /¯¯¯¯¯_____ /¯¯¯¯¯ _____ /¯¯¯¯¯¯ _____ / int_clk ¯¯¯¯¯ _________________________________________________ ser_start_end(master) _____________________ /¯¯¯¯¯ _____ /¯¯¯¯¯ _____ /¯¯¯¯¯ _____ / ser_clk(master) --------- XXXXXX ¯¯X¯¯¯¯Xser_adc_output(奴隶) 我必须得到上面描绘的内容。 所以基本上我必须将内部时钟输出到从器件,我还必须启用或禁用它(由于ADC的时序问题,这是必要的)。 我在这个论坛中发现,在spartan 6中转发时钟的最佳方法是使用ODDR2缓冲器,D0 = 1且D1 = 0 DDR_ALIGNMENT = 0来锁定时钟到输出,所以我做了。 我的内部时钟由外部PLL生成,由BUFG全局缓冲。 问题是,当我执行Post map时序分析时,我发现int_clk的上升沿和ser_clk之间存在很大的延迟(8.5ns)。 因为我需要80MHz时钟(12.5ns周期)8.5ns延迟不可接受。 ser_clk启用计时实际上不是问题购买我需要ser_clk不要与int_clk不同步。 我试图约束ser_clk,以便它从int_clk的延迟足够小 net“ser_clk”tnm_net =“ser_clk_out”; timegrp“ser_clk_out”offset =在“int_clk”上升后5 ns; 但那不行。 我获得的是静态时序报告称时序约束不受尊重。 我哪里错了? 感谢帮助 以上来自于谷歌翻译 以下为原文 Hello everybody I'm a master thesis student and I haven't got much experience on FPGA programming so please be patient with me. I'm using XEM6010 spartan 6 module by Opal Kelly for my thesis project. What I've got to do after all is just to set up SPI communication between master (FPGA) and slave (ADC), at the relatively low frequency of 80MHz (1MSps ADC with serial interface, 80MHz clock required to achieve maximum sampling rate) ¯¯¯¯¯_____/¯¯¯¯¯_____/¯¯¯¯¯_____/¯¯¯¯¯_____/¯¯¯¯¯_____/ int_clk ¯¯¯¯¯_________________________________________________ ser_start_end (master) _____________________/¯¯¯¯¯_____/¯¯¯¯¯_____/¯¯¯¯¯_____/ ser_clk (master) ---------X¯¯¯¯¯¯¯¯¯¯¯¯¯¯X¯¯¯¯¯X¯¯¯¯X¯¯¯¯¯X¯¯¯¯X¯¯¯¯¯X¯¯¯¯X ser_adc_output (slave) I have to obtain what I've sketched above. So basically I have to take internal clock out to the slave and I also have to enable or disable it (that's necessary because of ADC's timing issues). I found in this forum that the best way to forward clock in spartan 6 is to use ODDR2 buffer with D0 = 1 and D1 = 0 DDR_ALIGNMENT = 0 to latch the clock to the output and so I did. My internal clock is generated by an external PLL, global buffered by BUFG. The problem is that when I performed Post map timing analysis I found out a big delay (8.5ns) between int_clk's rising edge and ser_clk's. As I need 80MHz clock (12.5ns period) 8.5ns delay's not accettable. ser_clk enable timing's actually's not an issue buy I need ser_clk not to be out of phase with int_clk. I tryied to constraint ser_clk so that its delay from int_clk would be small enough net "ser_clk" tnm_net = "ser_clk_out"; timegrp "ser_clk_out" offset = out 5 ns after "int_clk" rising; but that's not work. What I gained was that static timing report said timing constraints were not respected. Where am I wrong? thanks for help |
|
相关推荐
2个回答
|
|
b,
使用DCM来对齐时钟(使用从IO驱动的CLKFB路径,以便您发送的内容对齐)。 或者使用DCM提供移位时钟或其他相位。 或者,反转D输入值以发送反相时钟。 许多选择,最简单的是最后一个。 全局时钟树的延迟是由设计固定的,并且不会受到约束的影响。 Austin Lesea主要工程师Xilinx San Jose 以上来自于谷歌翻译 以下为原文 b, Use the DCM to either align the clock (use the CLKFB path driven from IO so what you send is aligned). Or use DCM to provide a shifted clock, or another phase. Or, reverse D input values to send an inverted clock. Many choices, simplest is the last one. The delay of the global clock tree is fixed by design, and is not going to chaqnge with constraints. Austin Lesea Principal Engineer Xilinx San Jose |
|
|
|
|
|
|
|
只有小组成员才能发言,加入小组>>
2446 浏览 7 评论
2845 浏览 4 评论
Spartan 3-AN时钟和VHDL让ISE合成时出现错误该怎么办?
2308 浏览 9 评论
3390 浏览 0 评论
如何在RTL或xilinx spartan fpga的约束文件中插入1.56ns延迟缓冲区?
2485 浏览 15 评论
有输入,但是LVDS_25的FPGA内部接收不到数据,为什么?
1750浏览 1评论
请问vc707的电源线是如何连接的,我这边可能出现了缺失元件的情况导致无法供电
621浏览 1评论
求一块XILINX开发板KC705,VC707,KC105和KCU1500
483浏览 1评论
2036浏览 0评论
760浏览 0评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-12 05:21 , Processed in 1.227461 second(s), Total 79, Slave 63 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号