日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 通信技術(shù) > 通信技術(shù)
[導(dǎo)讀] 上次提出了一個(gè)處于異步時(shí)鐘域的MCU與FPGA直接通信的實(shí)現(xiàn)方式,其實(shí)在這之前,特權(quán)同學(xué)想列舉一個(gè)異步時(shí)鐘域中出現(xiàn)的很典型的問題。也就是要用一個(gè)反例來(lái)說(shuō)明沒有足夠重視異步通信會(huì)給整個(gè)設(shè)計(jì)帶來(lái)什么樣的危害。

 上次提出了一個(gè)處于異步時(shí)鐘域的MCU與FPGA直接通信的實(shí)現(xiàn)方式,其實(shí)在這之前,特權(quán)同學(xué)想列舉一個(gè)異步時(shí)鐘域中出現(xiàn)的很典型的問題。也就是要用一個(gè)反例來(lái)說(shuō)明沒有足夠重視異步通信會(huì)給整個(gè)設(shè)計(jì)帶來(lái)什么樣的危害。

要舉的這個(gè)反例是真真切切的在某個(gè)項(xiàng)目上發(fā)生過的,很具有代表性。它不僅會(huì)涉及使用組合邏輯和時(shí)序邏輯在異步通信中的優(yōu)劣、而且能把亞穩(wěn)態(tài)的危害活生生的展現(xiàn)在你面前。

從這個(gè)模塊要實(shí)現(xiàn)的功能說(shuō)起吧,如圖1所示,實(shí)現(xiàn)的功能其實(shí)很簡(jiǎn)單的,就是一個(gè)頻率計(jì),只不過FPGA除了脈沖采集進(jìn)行計(jì)數(shù)外,還要響應(yīng)CPU的控制。

 


 

圖1 功能模塊

CPU的控制總線是指一個(gè)片選信號(hào)和一個(gè)讀選通信號(hào),當(dāng)二者都有效時(shí),F(xiàn)PGA需要對(duì)CPU的地址總線進(jìn)行譯碼,然后把采樣脈沖值送到CPU的數(shù)據(jù)總線上。

 


 

圖2 CPU讀時(shí)序

對(duì)于這樣“簡(jiǎn)單”的功能,不少人可能會(huì)給出類似下面的以組合邏輯為主的實(shí)現(xiàn)方式:

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

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

 


 

圖3 數(shù)據(jù)沖突

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

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

 


 

圖4 計(jì)數(shù)器模型

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

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

 


 

圖5 同步處理

這里提出來(lái)的解決方案就是使用了脈沖檢測(cè)法進(jìn)行同步,還有一些其它的同步方式,譬如專用握手信號(hào)同步、異步FIFO等等。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來(lái)解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉