《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于FPGA的跨時鐘域信號處理——同步設計的重要
基于FPGA的跨時鐘域信號處理——同步設計的重要
摘要: 上次提出了一個處于異步時鐘域的MCU與FPGA直接通信的實現方式,其實在這之前,特權同學想列舉一個異步時鐘域中出現的很典型的問題。也就是要用一個反例來說明沒有足夠重視異步通信會給整個設計帶來什么樣的危害。
Abstract:
Key words :

上次提出了一個處于異步時鐘域的MCU與FPGA直接通信的實現方式,其實在這之前,特權同學想列舉一個異步時鐘域中出現的很典型的問題。也就是要用一個反例來說明沒有足夠重視異步通信會給整個設計帶來什么樣的危害。

特權同學要舉的這個反例是真真切切的在某個項目上發生過的,很具有代表性。它不僅會涉及使用組合邏輯和時序邏輯在異步通信中的優劣、而且能把亞穩態的危害活生生的展現在你面前。

從這個模塊要實現的功能說起吧,如圖1所示,實現的功能其實很簡單的,就是一個頻率計,只不過FPGA除了脈沖采集進行計數外,還要響應CPU的控制。

圖1 功能模塊
圖1 功能模塊

 

 

CPU的控制總線是指一個片選信號和一個讀選通信號,當二者都有效時,FPGA需要對CPU的地址總線進行譯碼,然后把采樣脈沖值送到CPU的數據總線上。

圖2 CPU讀時序
圖2 CPU讀時序

 

對于這樣“簡單”的功能,不少人可能會給出類似下面的以組合邏輯為主的實現方式:

 

input clk;

 

input rst_n;

 

 

 

input pulse;

 

input cs_n;

 

input rd_n;

 

input[3:0] addr_bus;

 

output reg[15:0] data_bus;

 

 

 

reg[15:0] counter;

 

 

 

always @(posedge pulse or negedge rst_n)

 

if(!rst_n) counter <= 16'd0;

 

else if(pulse) counter <= counter+1'b1;

 

 

 

 

 

wire dsp_cs = cs_n & rd_n;

 

 

 

always @(dsp_cs or addr_bus)

 

if(dsp_cs) data_bus <= 16'hzzzz;

 

else begin

 

case(addr_bus)

 

4'h0: data_bus <= counter;

 

4'h1: ……;

 

……

 

default: ;

 

endcase

 

end

 

咋一看,可能你會覺得這個代碼也沒什么問題,功能似乎都實現了。而且你會覺得這個代碼簡潔,也不需要耗費多少邏輯就能實現。但是,對于這種時鐘滿天飛的設計,存在著諸多亞穩態危害爆發的可能。脈沖信號和由CPU控制總線產生的選通信號是來自兩個異步時鐘域的信號。它們作為內部的時鐘信號時,一個寫寄存器counter,一個讀寄存器counter。那么,很明顯的,存在著發生沖突的可能。換句話說,如果寄存器正處于改變狀態(被寫)時被讀取了,問題就隨著而來,如圖3所示。

 

 

圖3 數據沖突
圖3 數據沖突

 

脈沖信號pulse和CPU讀選通信號cpu_cs是異步信號,pulse什么時候出現上升沿和cpu_cs什么時候出現下降沿是不可控的。所以,如果它們很不幸的一起觸發了,那么,結果可想而知。計數器counter[15:0]正在加一,這個自增的過程還在進行中,CPU數據總線data_bus[15:0]來讀取counter[15:0],那么到底讀取的值是自增之前的值還是自增之后的值呢?或者是其它的值呢?

 

 

所示,它是一個計數器的近似模型。當計數器自增一的時候,如果最低位為0,那么自增的結果只會使最低位翻轉;當最低位為1,那么自增一的后果除了使最低位翻轉,還有可能使其它任何位翻轉,比如4’b1111自增一的后果會使4個位都翻轉。由于每個位之間從發生翻轉到翻轉完成都需要經過一段邏輯延時和走線延時,對于一個16位的計數器,要想使這16位寄存器的翻轉時間一致,那是不可能做到的。所以,對于之前的設計中出現了如圖3的沖突時,被讀取的脈沖值很可能是完全錯誤的。

 

 

 

圖4 計數器模型
圖4 計數器模型

 

 

上面的代碼是最典型的組合邏輯實現方式,是很不可行的。也許很多朋友會提出異議,也許還會提出很多類似的組合邏輯方案。但是,如果沒有同步設計的思想,不把這兩個異步時鐘域的信號同步到一個時鐘域里進行處理,沖突的問題在無法得到有效解決的。

 

那么,這個設計該如果同步呢?實現的方案其實上一次提到FPGA與MCU通信的博文里已經給出了答案。它的設計思想可以如圖5所示。圖5先是使用脈沖檢測法把脈沖信號與系統時鐘信號clk同步,然后依然使用脈沖檢測法得到一個系統時鐘寬度的使能脈沖作為數據鎖存信號,也將CPU的控制信號和系統時鐘信號clk同步了。如此處理后,兩個異步時鐘域的信號就不存在任何讀寫沖突的情況了。

 

 

 

圖5 同步處理
圖5 同步處理

 

 

這里提出來的解決方案就是使用了脈沖檢測法進行同步,還有一些其它的同步方式,譬如專用握手信號同步、異步FIFO等等。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美乱在线观看| 欧美亚洲午夜视频在线观看| 亚洲久久一区| 在线观看精品一区| 另类天堂av| 99视频精品免费观看| 亚洲人成人77777线观看| 欧美日韩国产片| 亚洲一区二区三区四区在线观看| 一区二区三区四区五区精品视频| 国产精品日本精品| 久久久精品999| 亚洲日本欧美在线| 一区二区91| 国内成+人亚洲| 欧美日本在线视频| 欧美高清免费| 午夜精品一区二区三区在线| 久久精品亚洲精品| 一本色道久久综合亚洲精品小说 | 尤物在线精品| 在线观看91精品国产麻豆| 怡红院精品视频在线观看极品| 狠狠色综合网| 欧美三级在线播放| 久久久久久尹人网香蕉| 99精品国产福利在线观看免费| 亚洲精品久久久一区二区三区| 亚洲日本激情| 一区二区免费在线视频| 欧美一区二区三区在| 亚洲精品视频在线看| 国产日韩综合一区二区性色av| 欧美成人精精品一区二区频| 午夜在线成人av| 亚洲狼人综合| 一本色道久久| 亚洲综合国产激情另类一区| 亚洲欧洲视频在线| 亚洲欧美一区二区激情| 亚洲精品久久7777| 一本色道久久综合狠狠躁篇怎么玩| 一区二区日韩欧美| 午夜精品美女久久久久av福利| 亚洲欧洲日产国产网站| 亚洲伦理久久| 在线国产日韩| 亚洲人成免费| 亚洲一区免费网站| 亚洲免费大片| 亚洲一二三四区| 亚洲每日在线| 亚洲一区二区三区视频播放| 先锋资源久久| 亚洲人永久免费| 亚洲宅男天堂在线观看无病毒| 欧美一区二区三区成人| 9久草视频在线视频精品| 亚洲淫性视频| 久久视频一区| 欧美在线观看天堂一区二区三区| 亚洲视频一区二区在线观看| 亚洲精品一二三| 亚洲欧美成人综合| 美女久久一区| 久久久免费观看视频| 欧美国产在线视频| 国产精品丝袜白浆摸在线| 在线观看亚洲精品| 亚洲资源av| 日韩午夜黄色| 亚洲毛片av在线| 小处雏高清一区二区三区| 免费观看日韩av| 国产九九精品视频| 国产精品色在线| 亚洲第一二三四五区| 在线免费观看日本欧美| 一区二区精品国产| 亚洲国产天堂久久综合网| 久久精品国亚洲| 亚洲天堂黄色| 午夜精品美女自拍福到在线| 免费观看一区| 国产亚洲欧美另类中文 | 国产精品黄视频| 欧美特黄a级高清免费大片a级| 国产日韩欧美综合| 99re成人精品视频| 99视频精品在线| 久久精品国产亚洲a| 亚洲欧美一区二区三区在线| 欧美国产亚洲视频| 精品av久久707| 亚洲成人影音| 午夜在线不卡| 亚洲欧美日韩视频二区| 欧美精品日韩一区| 欧美三级电影一区| 亚洲第一福利在线观看| 欧美在线观看天堂一区二区三区| 亚洲欧美成aⅴ人在线观看| 欧美日韩精品免费观看视频| 在线观看一区欧美| 久久精品一区二区国产| 久久国产加勒比精品无码| 卡通动漫国产精品| 国产乱子伦一区二区三区国色天香| 亚洲精品乱码久久久久久按摩观| 亚洲国产精品第一区二区| 亚洲精品在线观看免费| 久久久夜精品| 国产一区二区精品在线观看| 亚洲欧美日韩国产一区二区三区| 亚洲一二三区在线观看| 欧美劲爆第一页| 亚洲国产综合在线| 亚洲午夜精品久久久久久浪潮| aⅴ色国产欧美| 欧美精品一区二区三区高清aⅴ| 在线观看成人av电影| 久久精品国语| 美女啪啪无遮挡免费久久网站| 国内久久精品| 亚洲成人资源| 宅男66日本亚洲欧美视频| 欧美va亚洲va日韩∨a综合色| 欧美视频在线观看| 91久久久久久国产精品| 亚洲精品久久久久中文字幕欢迎你 | 在线亚洲免费视频| 亚洲男同1069视频| 国产精品日日做人人爱| 亚洲自拍另类| 久久久久久久久久久久久久一区| 国模精品一区二区三区| 亚洲第一成人在线| 欧美成人在线免费观看| 亚洲人成人一区二区三区| 9色精品在线| 国产精品久久久久影院亚瑟| 国产一区二区三区直播精品电影| 欧美一级大片在线免费观看| 久久久久久久久久久久久久一区 | 国产精品美女久久久久久免费| 亚洲免费视频中文字幕| 久久久久久有精品国产| 亚洲国产精品成人| 午夜精品av| 久久久久久伊人| 亚洲风情亚aⅴ在线发布| 99在线精品视频在线观看| 欧美色网在线| 午夜日韩福利| 免费观看日韩| 亚洲视频高清| 亚洲日本国产| 欧美日韩一卡二卡| 亚洲国产精品99久久久久久久久| 日韩午夜精品| 国产精品乱人伦一区二区| 久久av资源网站| 午夜精品亚洲| 狠狠色2019综合网| 一区二区三区视频免费在线观看| 国产精品高精视频免费| 欧美中在线观看| 欧美激情一二三区| 亚洲综合999| 欧美xxxx在线观看| 亚洲一区影院| 欧美va天堂| 亚洲欧美国产精品桃花| 免费在线亚洲| 亚洲午夜免费福利视频| 另类激情亚洲| 亚洲淫性视频| 欧美好吊妞视频| 午夜日韩福利| 欧美日韩在线观看视频| 久久成人免费| 欧美精品三级日韩久久| 欧美一区二区视频免费观看| 欧美精品成人| 欧美在现视频| 国产精品白丝av嫩草影院| 日韩亚洲国产精品| 久久精品久久综合| 日韩小视频在线观看专区| 老色批av在线精品| 亚洲欧美国产日韩天堂区| 欧美激情二区三区| 欧美一区二区成人| 欧美午夜精品理论片a级按摩| 亚洲第一中文字幕在线观看| 国产精品久久久久久久久久妞妞 | 99精品热视频| 狠狠综合久久| 香蕉久久夜色精品| 亚洲久久一区|