版主: 51FPGA |
Jason_Zhang
![]()
最后登陆时间:2015-01-20 09:30:43 |
一般找不到100M或200M的晶振,高频晶振通过管脚输入质量也不好。 |
![]() 哥研究的不是寂寞,是DPD。 |
|
heiyux
![]()
最后登陆时间:2015-01-22 10:54:26 |
Xilinx的ML506板卡上的设计就是通过外部供给的,用25M晶振由一个内置VCO的时钟芯片产生200MHz时钟供给FPGA。 不过我想,由FPGA内部产生的200MHz应该也可以吧。。。 |
heiyux
![]()
最后登陆时间:2015-01-22 10:54:26 |
becoll的原帖 heiyux的原帖恩,是的。用的是v4的 xc4vlx40。系统时钟用的是100M,高频部分加DCM就可以了吧。频率高了时序和功耗都是问题,而且板子也不能就只是个ddr接口的,一般其他模块都不会要求这么高的系统时钟。 我的这个模块近期内还不能调,也许以后还要向你这个先行者请教呢,呵呵 呵呵,到时候一起讨论 我刚开始做XILINX,以前做的是ALTERA的 你的意思是DDRII模块两个系统时钟在外围硬件上只设计了模块操作频率的那个系统时钟,而供到idelay_ctrl的那个高频系统时钟硬件上不设计,在程序里使用DCM供给是么? 是的。系统时钟一般情况有一个就够了,而且最好不要太高。ddr需要的时钟较多,都通过dcm产生好了。而且万一你的设计代码跑不到200M,还要把系统时钟往下降,多麻烦。 主要我担心的是: 在MIG中选了使用DCM和PLL了,所以其他很多DDRII核用到的时钟都在内部直接使用DCM产生,所以生成的核在外部接口上就没有他们,但惟独这两个系统时钟是要外部输入的,在MIG的datasheet上的时钟部分说,用户必须提供这两个时钟,如果在MIG里没有选使用DCM和PLL,那么用户需要提供所有DDRII用到得时钟, 所以我就想,如果它能直接用DCM的话,那么为什么还要单单列出来呢。。。 |
becoll
![]()
最后登陆时间:2013-07-26 21:02:47 |
becoll的原帖 heiyux的原帖恩,是的。用的是v4的 xc4vlx40。系统时钟用的是100M,高频部分加DCM就可以了吧。频率高了时序和功耗都是问题,而且板子也不能就只是个ddr接口的,一般其他模块都不会要求这么高的系统时钟。 我的这个模块近期内还不能调,也许以后还要向你这个先行者请教呢,呵呵 呵呵,到时候一起讨论 我刚开始做XILINX,以前做的是ALTERA的 你的意思是DDRII模块两个系统时钟在外围硬件上只设计了模块操作频率的那个系统时钟,而供到idelay_ctrl的那个高频系统时钟硬件上不设计,在程序里使用DCM供给是么? 是的。系统时钟一般情况有一个就够了,而且最好不要太高。ddr需要的时钟较多,都通过dcm产生好了。而且万一你的设计代码跑不到200M,还要把系统时钟往下降,多麻烦。 主要我担心的是: 在MIG中选了使用DCM和PLL了,所以其他很多DDRII核用到的时钟都在内部直接使用DCM产生,所以生成的核在外部接口上就没有他们,但惟独这两个系统时钟是要外部输入的,在MIG的datasheet上的时钟部分说,用户必须提供这两个时钟,如果在MIG里没有选使用DCM和PLL,那么用户需要提供所有DDRII用到得时钟, 所以我就想,如果它能直接用DCM的话,那么为什么还要单单列出来呢。。。 MIG的datasheet我还没看过。不过我的理解是,mig中应该只使用了单级dcm,而dcm的频率生成范围是有限的,对低频的系统时钟,单级dcm还不能产生200M的输出,而mig中使用多个dcm来产生200M的时钟的话,对资源会是一种巨大的浪费,所以就将200M的时钟交给外部来供给。 再换一个角度,对生成的mig核,200M的时钟不管是专用时钟芯片提供的还是由FPGA内其它dcm提供的,对它来说不都是一个外部输入么,没什么区别 个人见解,仅供参考 |
![]() 酒舞至尊。 |
|
becoll
![]()
最后登陆时间:2013-07-26 21:02:47 |
100M的晶振是有的,我使用的系统时钟就是100M的有源晶振提供的 200M的没查过,也该有吧 |
![]() 酒舞至尊。 |
|
heiyux
![]()
最后登陆时间:2015-01-22 10:54:26 |
becoll的原帖 heiyux的原帖恩,是的。用的是v4的 xc4vlx40。系统时钟用的是100M,高频部分加DCM就可以了吧。频率高了时序和功耗都是问题,而且板子也不能就只是个ddr接口的,一般其他模块都不会要求这么高的系统时钟。 我的这个模块近期内还不能调,也许以后还要向你这个先行者请教呢,呵呵 呵呵,到时候一起讨论 我刚开始做XILINX,以前做的是ALTERA的 你的意思是DDRII模块两个系统时钟在外围硬件上只设计了模块操作频率的那个系统时钟,而供到idelay_ctrl的那个高频系统时钟硬件上不设计,在程序里使用DCM供给是么? 是的。系统时钟一般情况有一个就够了,而且最好不要太高。ddr需要的时钟较多,都通过dcm产生好了。而且万一你的设计代码跑不到200M,还要把系统时钟往下降,多麻烦。 主要我担心的是: 在MIG中选了使用DCM和PLL了,所以其他很多DDRII核用到的时钟都在内部直接使用DCM产生,所以生成的核在外部接口上就没有他们,但惟独这两个系统时钟是要外部输入的,在MIG的datasheet上的时钟部分说,用户必须提供这两个时钟,如果在MIG里没有选使用DCM和PLL,那么用户需要提供所有DDRII用到得时钟, 所以我就想,如果它能直接用DCM的话,那么为什么还要单单列出来呢。。。 MIG的datasheet我还没看过。不过我的理解是,mig中应该只使用了单级dcm,而dcm的频率生成范围是有限的,对低频的系统时钟,单级dcm还不能产生200M的输出,而mig中使用多个dcm来产生200M的时钟的话,对资源会是一种巨大的浪费,所以就将200M的时钟交给外部来供给。 再换一个角度,对生成的mig核,200M的时钟不管是专用时钟芯片提供的还是由FPGA内其它dcm提供的,对它来说不都是一个外部输入么,没什么区别 个人见解,仅供参考 哦~,DCM有这个区别,刚开始接触xilinx,我没有实际用过它 |
xie0jing0
![]()
最后登陆时间:2014-11-14 00:56:50 |
becoll的原帖 heiyux的原帖恩,是的。用的是v4的 xc4vlx40。系统时钟用的是100M,高频部分加DCM就可以了吧。频率高了时序和功耗都是问题,而且板子也不能就只是个ddr接口的,一般其他模块都不会要求这么高的系统时钟。 我的这个模块近期内还不能调,也许以后还要向你这个先行者请教呢,呵呵 呵呵,到时候一起讨论 我刚开始做XILINX,以前做的是ALTERA的 你的意思是DDRII模块两个系统时钟在外围硬件上只设计了模块操作频率的那个系统时钟,而供到idelay_ctrl的那个高频系统时钟硬件上不设计,在程序里使用DCM供给是么? 是的。系统时钟一般情况有一个就够了,而且最好不要太高。ddr需要的时钟较多,都通过dcm产生好了。而且万一你的设计代码跑不到200M,还要把系统时钟往下降,多麻烦。 主要我担心的是: 在MIG中选了使用DCM和PLL了,所以其他很多DDRII核用到的时钟都在内部直接使用DCM产生,所以生成的核在外部接口上就没有他们,但惟独这两个系统时钟是要外部输入的,在MIG的datasheet上的时钟部分说,用户必须提供这两个时钟,如果在MIG里没有选使用DCM和PLL,那么用户需要提供所有DDRII用到得时钟, 所以我就想,如果它能直接用DCM的话,那么为什么还要单单列出来呢。。。 MIG的datasheet我还没看过。不过我的理解是,mig中应该只使用了单级dcm,而dcm的频率生成范围是有限的,对低频的系统时钟,单级dcm还不能产生200M的输出,而mig中使用多个dcm来产生200M的时钟的话,对资源会是一种巨大的浪费,所以就将200M的时钟交给外部来供给。 再换一个角度,对生成的mig核,200M的时钟不管是专用时钟芯片提供的还是由FPGA内其它dcm提供的,对它来说不都是一个外部输入么,没什么区别 个人见解,仅供参考 哦~,DCM有这个区别,刚开始接触xilinx,我没有实际用过它 呵呵,我是用pll的,代替DCM,可以对晶振直接倍频上去。另外再用一个pll产生那个200MHz的时钟,比较节省硬件资源,得到的效果也不错。 |
heiyux
![]()
最后登陆时间:2015-01-22 10:54:26 |
becoll的原帖 heiyux的原帖恩,是的。用的是v4的 xc4vlx40。系统时钟用的是100M,高频部分加DCM就可以了吧。频率高了时序和功耗都是问题,而且板子也不能就只是个ddr接口的,一般其他模块都不会要求这么高的系统时钟。 我的这个模块近期内还不能调,也许以后还要向你这个先行者请教呢,呵呵 呵呵,到时候一起讨论 我刚开始做XILINX,以前做的是ALTERA的 你的意思是DDRII模块两个系统时钟在外围硬件上只设计了模块操作频率的那个系统时钟,而供到idelay_ctrl的那个高频系统时钟硬件上不设计,在程序里使用DCM供给是么? 是的。系统时钟一般情况有一个就够了,而且最好不要太高。ddr需要的时钟较多,都通过dcm产生好了。而且万一你的设计代码跑不到200M,还要把系统时钟往下降,多麻烦。 主要我担心的是: 在MIG中选了使用DCM和PLL了,所以其他很多DDRII核用到的时钟都在内部直接使用DCM产生,所以生成的核在外部接口上就没有他们,但惟独这两个系统时钟是要外部输入的,在MIG的datasheet上的时钟部分说,用户必须提供这两个时钟,如果在MIG里没有选使用DCM和PLL,那么用户需要提供所有DDRII用到得时钟, 所以我就想,如果它能直接用DCM的话,那么为什么还要单单列出来呢。。。 MIG的datasheet我还没看过。不过我的理解是,mig中应该只使用了单级dcm,而dcm的频率生成范围是有限的,对低频的系统时钟,单级dcm还不能产生200M的输出,而mig中使用多个dcm来产生200M的时钟的话,对资源会是一种巨大的浪费,所以就将200M的时钟交给外部来供给。 再换一个角度,对生成的mig核,200M的时钟不管是专用时钟芯片提供的还是由FPGA内其它dcm提供的,对它来说不都是一个外部输入么,没什么区别 个人见解,仅供参考 哦~,DCM有这个区别,刚开始接触xilinx,我没有实际用过它 呵呵,我是用pll的,代替DCM,可以对晶振直接倍频上去。另外再用一个pll产生那个200MHz的时钟,比较节省硬件资源,得到的效果也不错。 哦~ 那就是只用设计一个50MHz左右的晶振供个时钟就可以了 MIG还有update管脚功能的啊,这个好,我去找找去,谢谢啊,以后有问题还要请教一下你 |
lijinling33
![]()
最后登陆时间:2011-02-13 14:23:21 |
是有两个差分时钟
|
![]() lijinling33。 |
|
besomeone
![]()
最后登陆时间:2010-10-07 00:13:01 |
请教一下,ddr2的MIG如果不使用DCM是不是必须提供DDR2的控制器的四个时钟信号,我记得有175MHz,90°相位的175MHz,还有一个200MHz的;是通过V5板上系统时钟100MHz提供的,再经过两级DCM级联得到175的不同相位的时钟和一个350MHz的时钟,还有第一级的200MHz,然后作为DDR2控制器的时钟输入。
input clk0, input clk90, input clkdiv0, 这三个时钟的功能能解释一下吗?有点盲目,因为是在别人设计初始化完成下继续设计接口的,但是读写不正确就只好对原来的初始化设计进行研究,谢谢! 不管输入的时钟频率多高,都可以完成初始化的吧?我现在理解应该是这样的,但是我原来在别人基础上设计一个接口(读写错误,只好把原来的设计进行检查),就局限于原来的设计了,当然刚开始也不明白! 但是要求设计的存储的数据只有50MHz,所以刚开始在原来设计的175MHz的输入时钟下进行调试,还没有考虑到不同时钟下的转换。现在看来应该可以根据设计来改变输入的时钟频率了,是不是这样子? Interface Parameters : Frequency : 300 Data Width : 72 Depth : 1 Row Address : 14 Column Address : 10 Bank Address : 2 Data Mask : 1 ECC : ECC Disabled 对于DCM内部提供的,也就是只需要提供一个200MHz的时钟和操作时钟吧? |