搜索
bottom↓
回复: 9

使用高速时钟检测低速时钟信号时丢失边沿问题

[复制链接]

出0入0汤圆

发表于 2014-12-2 15:12:50 | 显示全部楼层 |阅读模式
本帖最后由 渭水清风1 于 2014-12-2 15:14 编辑

在用VHDL写模块处理SPI时,由于需要响应双边沿,因此模块时钟采用了高速时钟(比如16MHz),SPI_SCLK(600kHz)当一般信号处理,靠clk触发来判断spi_sclk的边沿。

类似这样:


process(n_reset,clk)
begin
        if n_reset = '1' then
                if rising_edge(clk) then
                        previous_spi_sclk <= spi_sclk;                       
                        if previous_spi_sclk = '0' and spi_sclk= '1' then       
                                -- DO SOMETHING
                        end if;
                end if;
        else
                -- RESET REGISTERS
        end if;
end process;

不过发现在使用中,会发生SPI_SCLK边沿偶尔丢失的问题,导致移位错位,把波形输出观察,发现previous_spi_sclk 信号并没有什么问题。不知道是否有人遇到过?

阿莫论坛20周年了!感谢大家的支持与爱护!!

知道什么是神吗?其实神本来也是人,只不过神做了人做不到的事情 所以才成了神。 (头文字D, 杜汶泽)

出0入0汤圆

 楼主| 发表于 2014-12-2 15:28:27 | 显示全部楼层
抓了一下波形,问题如下图黄圈所示。
发现在有的时候prev_spi_sclk的值并没有严格比spi_sclk晚一拍。
图中clk为2.048MHz,spi_sclk为600kHz
不知道是什么原因。器件是altera的cyclone3,资源只用了30%而已。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

出0入442汤圆

发表于 2014-12-2 17:45:14 | 显示全部楼层
我遇到过类似的,用100M时钟去采16M的信号,边沿丢失率极高。后来将速度提高到200M,也有一定丢边沿率。最后只能提到300M了。事实证明,有些地方用异步比用同步要可靠得多。

出0入0汤圆

发表于 2014-12-2 17:57:38 | 显示全部楼层
渭水清风1 发表于 2014-12-2 15:28
抓了一下波形,问题如下图黄圈所示。
发现在有的时候prev_spi_sclk的值并没有严格比spi_sclk晚一拍。
图中c ...

既然clk是16M,仿真时为啥不用16M呢?

出0入0汤圆

 楼主| 发表于 2014-12-2 18:15:10 | 显示全部楼层
huangiggw 发表于 2014-12-2 17:57
既然clk是16M,仿真时为啥不用16M呢?

这是逻辑分析仪抓的,仪器采样率有限太快的话抓不到。
现象和16M时是一样的。

出0入0汤圆

发表于 2014-12-2 19:19:42 | 显示全部楼层
reg sclk;
process(n_reset,clk)
begin
        if n_reset = '1' then
                if rising_edge(clk) then
                sclk<=spi_sclk;       
                        previous_spi_sclk <= sclk;                        
                        if previous_spi_sclk = '0' and sclk= '1' then        
                                -- DO SOMETHING
                        end if;
                end if;
        else
                -- RESET REGISTERS
        end if;
end process;

楼主可先用clk采下spi_clk,再做边沿检测,

出0入0汤圆

发表于 2014-12-2 19:24:23 来自手机 | 显示全部楼层
有没有打两拍然后采样

出0入0汤圆

发表于 2014-12-2 19:44:20 | 显示全部楼层
spi_clk 和你用的 16MHz clock 之間的關係是不知道,要視為非同步訊好,需作同步電路處理。

出0入0汤圆

 楼主| 发表于 2014-12-2 22:47:51 | 显示全部楼层
多谢楼上几位,加了一级同步确实好了,类似这样
process(n_reset,clk)
begin
        if n_reset = '1' then
                if rising_edge(clk) then
                        previous_spi_sclk <= spi_sclk;   
                        previous_spi_sclk2 <= previous_spi_sclk;                       
                        if previous_spi_sclk2 = '0' and previous_spi_sclk= '1' then        
                                -- DO SOMETHING
                        end if;
                end if;
        else
                -- RESET REGISTERS
        end if;
end process;

看来确实是因为spi_sclk不是由clk同步导致的,不过这样的话就要求clk频率至少为spi_sclk的四倍,好在spi_sclk频率比较低。

出0入0汤圆

发表于 2014-12-4 13:37:17 | 显示全部楼层
检测边沿的话,至少采样两个信号.否则必定会因为亚稳态导致丢失的.想再保险点,就采样三次.clk频率比spicclk高2倍即可.
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-7-24 01:29

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表