當(dāng)前位置:首頁 > EDA > 電子設(shè)計(jì)自動(dòng)化
[導(dǎo)讀]本文采用FPGA來設(shè)計(jì)一款廣泛應(yīng)用于計(jì)算機(jī)、Modem、數(shù)據(jù)終端以及許多其他數(shù)字設(shè)備之間的數(shù)據(jù)傳輸?shù)膶S卯惒讲⑿型ㄐ沤涌谛酒?,?shí)現(xiàn)了某一時(shí)鐘域(如66 MHz)的8位并行數(shù)據(jù)到另一低時(shí)鐘域(如40 MHz)16位并行數(shù)據(jù)的異步轉(zhuǎn)換,并且客戶可以根據(jù)自己的要求進(jìn)行數(shù)據(jù)定義。完成數(shù)據(jù)在不同時(shí)鐘域間的正確傳遞的同時(shí)防止亞穩(wěn)態(tài)的出現(xiàn),保持系統(tǒng)的穩(wěn)定,是電路設(shè)計(jì)的關(guān)鍵。

隨著EDA技術(shù)的發(fā)展,由于其在電子系統(tǒng)設(shè)計(jì)領(lǐng)域中的明顯優(yōu)勢,F(xiàn)PGA已經(jīng)在許多方面得到了廣泛應(yīng)用,特別是在無線通信領(lǐng)域,F(xiàn)PGA以其極強(qiáng)的實(shí)時(shí)性,指令軟件編程的極大靈活性贏得了巨大的市場。本文采用FPGA來設(shè)計(jì)一款廣泛應(yīng)用于計(jì)算機(jī)、Modem、數(shù)據(jù)終端以及許多其他數(shù)字設(shè)備之間的數(shù)據(jù)傳輸?shù)膶S卯惒讲⑿型ㄐ沤涌谛酒瑢?shí)現(xiàn)了某一時(shí)鐘域(如66 MHz)的8位并行數(shù)據(jù)到另一低時(shí)鐘域(如40 MHz)16位并行數(shù)據(jù)的異步轉(zhuǎn)換,并且客戶可以根據(jù)自己的要求進(jìn)行數(shù)據(jù)定義。完成數(shù)據(jù)在不同時(shí)鐘域間的正確傳遞的同時(shí)防止亞穩(wěn)態(tài)的出現(xiàn),保持系統(tǒng)的穩(wěn)定,是電路設(shè)計(jì)的關(guān)鍵。

1 時(shí)鐘域轉(zhuǎn)換中亞穩(wěn)態(tài)的產(chǎn)生

觸發(fā)器是數(shù)字電路設(shè)計(jì)中的一個(gè)重要元件,而觸發(fā)器工作過程中存在數(shù)據(jù)建立與保持時(shí)間的約束,如果這種約束得不到滿足,觸發(fā)器就會(huì)進(jìn)入某個(gè)不確定狀態(tài)——亞穩(wěn)態(tài)。亞穩(wěn)態(tài)的存在可能導(dǎo)致連鎖反應(yīng),以致引起整個(gè)系統(tǒng)功能混亂。在單時(shí)鐘域電路設(shè)計(jì)中由于不存在時(shí)鐘之間的延遲和錯(cuò)位,所以建立條件和保持條件的時(shí)間約束容易滿足。而在多時(shí)鐘域里由于各個(gè)模塊的非同步性,則必須考慮亞穩(wěn)態(tài)的發(fā)生,如圖1所示。
 

2 多時(shí)鐘域數(shù)據(jù)傳遞方案

多時(shí)鐘域傳遞的信號有兩種,其一為控制信號,其二為數(shù)據(jù)流信號。針對這兩種不同的信號,分別采取不同方案遏制系統(tǒng)墮入亞穩(wěn)態(tài)。對控制信號采用同步器裝置,即在2個(gè)不同的時(shí)鐘域之間插入同步器;而對于不同獨(dú)立時(shí)鐘域之間的數(shù)據(jù)流傳遞,為了避免異步時(shí)鐘域產(chǎn)生錯(cuò)誤的采樣電平,采用FIFO存儲器作為其轉(zhuǎn)換接口,在輸入端口使用寫時(shí)鐘寫數(shù)據(jù),在輸出端口使用讀時(shí)鐘讀數(shù)據(jù),這樣就完成了異步時(shí)鐘域之間的數(shù)據(jù)交換。

芯片的總體邏輯框圖如圖2所示,圖中輸入輸出信號定義如表1所示。

從邏輯結(jié)構(gòu)上將芯片劃分為3塊:寫時(shí)鐘域I/OBUFFER、讀時(shí)鐘域I/O BUFFER及FIFO存儲器。I/O BUFFER的主要作用是對外部信號進(jìn)行預(yù)處理,消除外部信號的毛刺,保證信號可靠并使外部的信號與時(shí)鐘信號同步,消除不穩(wěn)定的因素。根據(jù)信號的數(shù)目,BUFFER由相應(yīng)數(shù)目的多個(gè)D觸發(fā)器構(gòu)成。
 

FIFO存儲器結(jié)構(gòu)框圖如圖3所示,他由雙端口存儲器(Dual Port RAM)、寫控制單元(Writc Control)和讀控制單元(Read Control)構(gòu)成。其中DUAL PORT RAM是由ISE6.0的一個(gè)編輯軟件CORE GENERATER自動(dòng)生成,使用者只需設(shè)定RAM的端口數(shù)、內(nèi)存大小和瀆寫控制便可以生成一個(gè)適合程序的子模塊。由于讀寫時(shí)鐘屬于不同的時(shí)鐘域,滿幀信號Frame從寫控制單元向讀控制單元傳遞時(shí)必須采取同步器(Synchronizer)同步。
 

2.1 寫控制單元設(shè)計(jì)

寫控制單元主要的功能是根據(jù)寫數(shù)據(jù)有效信號wdataen判斷輸入數(shù)據(jù)是否正確,在檢測到寫入數(shù)據(jù)幀的開始標(biāo)志位wsof后開始計(jì)數(shù)控制寫指針waddr的移動(dòng),將正確的數(shù)據(jù)寫入DUAL PORT RAM中,并在一幀數(shù)據(jù)寫滿后向讀控制單元發(fā)出寫數(shù)據(jù)滿幀信號wframe。為防止亞穩(wěn)態(tài)的出現(xiàn),設(shè)計(jì)中采取了兩個(gè)措施:一是采用鎖存器將幀頭信號wsof拉長,確保其被穩(wěn)定的采集;二是采用Gray編碼計(jì)數(shù)器替代普通二進(jìn)制編碼計(jì)數(shù)器來控制寫指針waddr的移動(dòng),因?yàn)镚ray碼相鄰兩個(gè)編碼之間有且只有1位發(fā)生變化從而抑制了競爭冒險(xiǎn)的出現(xiàn)。

2.2 同步器設(shè)計(jì)

寫控制單元發(fā)出的寫數(shù)據(jù)滿幀信號wframe屬于控制信號,他從寫時(shí)域進(jìn)入讀時(shí)域必須采用同步器實(shí)現(xiàn)信號同步,將寫時(shí)域的滿幀信號wframe變換為讀時(shí)域的滿幀信號rframe。由于信號是從高時(shí)鐘域(66 MHz)流向低時(shí)鐘域(40 MHz),因此采用如圖4所示的同步器。
 

同步器時(shí)序圖如圖5所示,可見在寫時(shí)域的滿幀信號wframe經(jīng)過3個(gè)clka周期延后跨越到讀時(shí)鐘域。
 

2.3 讀控制單元設(shè)計(jì)

數(shù)據(jù)從寫時(shí)域傳遞到讀時(shí)域,時(shí)鐘發(fā)生了變化,而且讀控制單元的行為受到寫控制單元及Dual Port RAM中數(shù)據(jù)的存儲情況的雙重制約,因此他的設(shè)計(jì)是整個(gè)芯片設(shè)計(jì)成功的關(guān)鍵。

由于當(dāng)Dual Port RAM中寫入一幀完整的正確數(shù)據(jù)后才能輸出,所以讀控制首先必須判斷Dual Port RAM一幀是否寫滿。榆測到滿幀信號rframe后,在等待輸出數(shù)據(jù)幀頭信號rfp到來后控制讀指針waddr移動(dòng)讀出數(shù)據(jù),并置位rvalid表征輸出數(shù)據(jù)的可靠性。

部分程序沒計(jì)如下:



 

3 多時(shí)鐘域數(shù)據(jù)傳遞的FPGA實(shí)現(xiàn)

設(shè)計(jì)方案完成后選用Xilinx Spartan-II FPGA實(shí)現(xiàn)電路,并在Xilinx ISE6.0集成環(huán)境下用Modelsim5.7進(jìn)行了電路仿真。

圖6為寫使能信號dataen恒為有效值“1”的仿真結(jié)果截圖。
 

可見,在寫使能信號dataen恒為有效值“1”的情況下,在寫時(shí)鐘clka控制下當(dāng)寫數(shù)據(jù)幀頭信號sof有效時(shí),寫控制器開始寫入數(shù)據(jù),接收到連續(xù)8個(gè)數(shù)據(jù)后,寫控制器發(fā)出一個(gè)幀滿信號wframe。wframe信號經(jīng)過異步轉(zhuǎn)換后轉(zhuǎn)換成clkb時(shí)鐘域的信號。在讀控制器的控制下,當(dāng)clkb時(shí)鐘處于上升沿,并且檢測到讀出數(shù)據(jù)幀頭fp時(shí),開始從outdata向外發(fā)送數(shù)據(jù),并將valid置為有效。

圖7為當(dāng)寫使能信號dataen變化時(shí)的仿真結(jié)果截圖。

可見,將dataen置低后,系統(tǒng)不再接受寫入數(shù)據(jù),所以也不再輸出數(shù)據(jù),valid被置為低電平,輸出數(shù)據(jù)無效。寫控制的使能端控制達(dá)到要求。
 

4 結(jié) 語

針對異步并行通信接口芯片設(shè)計(jì)中涉及的多時(shí)鐘域的數(shù)據(jù)傳遞問題,本文采用FIFO存儲器來完成不同時(shí)鐘域之間數(shù)據(jù)流傳遞、同步器來完成控制信號傳遞的方案。仿真驗(yàn)證結(jié)果表明,數(shù)據(jù)傳遞準(zhǔn)確、穩(wěn)定、可靠,沒有出現(xiàn)競爭冒險(xiǎn)和亞穩(wěn)態(tài),完全達(dá)到了設(shè)計(jì)要求。

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉