關(guān) 閉

新聞中心

EEPW首頁 > 工控自動化 > 設(shè)計應(yīng)用 > 一種異步FIFO的設(shè)計方法

一種異步FIFO的設(shè)計方法

作者: 時間:2011-08-01 來源:網(wǎng)絡(luò) 收藏

摘要:使用同步源自不同時鐘域的數(shù)據(jù)是在數(shù)字IC中經(jīng)常使用的,功能正確的FUFO會遇到很多問題,探討了兩種不同的思路。兩種思路都能夠?qū)崿F(xiàn)功能正確的PIFO。

本文引用地址:http://butianyuan.cn/article/161677.htm

本文所研究的,從硬件的觀點(diǎn)來看,就是一塊數(shù)據(jù)內(nèi)存。它有兩個端口,一個用來寫數(shù)據(jù),就是將數(shù)據(jù)存入FIFO;另一個用來讀數(shù)據(jù),也就是將數(shù)據(jù)從FIFO當(dāng)中取出。與FIFO操作相關(guān)的有兩個指針,寫指針指向要寫的內(nèi)存部分,讀指針指向要讀的內(nèi)存部分。FIFO控制器通過外部的讀寫信號控制這兩個指針移動,并由此產(chǎn)生FIFO空信號或滿信號。

對于FIFO而言,數(shù)據(jù)是由某一個時鐘域的控制信號寫入FIFO,而由另一個時鐘域的控制信號將數(shù)據(jù)讀出FIFO。也就是說,讀寫指針的變化動作是由不同的時鐘產(chǎn)生的。因此,對FIFO空或滿的判斷是跨時鐘域的。如何根據(jù)的指針信號對FIFO的滿狀態(tài)或空狀態(tài)進(jìn)行正確的判斷是本文研究的重點(diǎn)。此外,設(shè)計過程中的一些細(xì)節(jié)問題也將在文中涉及到。

1 指針以及滿空信號的產(chǎn)生

為了更好地說明問題,先探討一下同步FIFO指針移動以及滿空信號的產(chǎn)生過程。對于同步FIFO,讀寫指針都指向一個內(nèi)存的初始位置,每進(jìn)行一次讀寫操作,相應(yīng)的指針就遞增一次,指向下一個內(nèi)存位置。當(dāng)指針移動到了內(nèi)存的最后一個位置時,它又重新跳回初始位置。在FIFO非滿或非空的情況下,這個過程將隨著讀寫控制信號的變化一直進(jìn)行下去。如果FIFO處于空的狀態(tài),下一個讀動作將會導(dǎo)致向下溢出(underflow),一個無效的數(shù)據(jù)被讀人;同樣,對于一個滿了的FIFO,進(jìn)行寫動作將會導(dǎo)致向上溢出(overflow),一個有用的數(shù)據(jù)被新寫入的數(shù)據(jù)覆蓋。這兩種情況都屬于誤動作,因此需要設(shè)置滿和空兩個信號,對滿信號置位表示FIFO處于滿狀態(tài),對滿信號復(fù)位表示FIFO非滿,還有空間可以寫入數(shù)據(jù);對空信號置位表示FIFO處于空狀態(tài),對空信號復(fù)位表示FIFO非空,還有有效的數(shù)據(jù)可以讀出。

當(dāng)讀指針和寫指針相等也就是指向同一個內(nèi)存位置的時候,F(xiàn)IFO可能處于滿或空兩種狀態(tài)??梢酝ㄟ^不同的判斷或區(qū)分FIFO究竟是處于滿狀態(tài)還是空狀態(tài),也就是究竟是寫指針從后趕上了讀指針,還是讀指針從后趕上了寫指針。本文所應(yīng)用的是設(shè)置一個額外的狀態(tài)位,指針由它的地址位以及狀態(tài)位組成。地址位隨著相應(yīng)的操作遞增,指針由內(nèi)存的最后位置返回到初始位置的時候狀態(tài)位取反。因此,當(dāng)讀寫指針的地址位和狀態(tài)位全部吻合的時候,讀寫指針經(jīng)歷了相同次數(shù)的循環(huán)移動,也就是說,F(xiàn)IFO處于空狀態(tài)(圖1(a));如果讀寫指針的地址位相同而狀態(tài)位相反,寫指針比讀指針多循環(huán)一次,標(biāo)志FIFO處于滿狀態(tài)(圖1(b))。 (2)二進(jìn)制指針可以用于任意大小的FIFO;格雷碼指針只能用于大小為2的冪的FIFO。

2 二進(jìn)制指針和格雷碼指針的同步

二進(jìn)制指針是由一位狀態(tài)位和若干位二進(jìn)制編碼的地址位組成的(例如由三位地址和一位狀態(tài)位構(gòu)成的指針的變化:0000→0001→0010→0011→0100→0101→0110→0111→1000→1001→1010→1011→1100→1101→1110→1111)。如果在不同的時鐘域內(nèi)直接同步二進(jìn)制指針,有可能產(chǎn)生問題。例如,當(dāng)讀指針從0111向1000變化的時侯,指針?biāo)械奈欢家兓?,如果寫時鐘恰好在讀指針的變化時刻采樣,寫者得到的讀指針值有可能是從0000到1111中的任何一個。所以二進(jìn)制指針不宜被直接同步,但可以通過一對握手信號同步二進(jìn)制指針。

例如,讀指針被讀者存人一個寄存器時,讀者就發(fā)出一個就緒信號。當(dāng)寫者看到就緒信號時,讀取讀指針,發(fā)出一個收到數(shù)據(jù)的確認(rèn)信號。當(dāng)讀者看到確認(rèn)信號時,就收回就緒信號,然后用當(dāng)前的讀指針值刷新寄存器(圖2)。在收到確認(rèn)信號前,存放讀指針的寄存器內(nèi)容保持不變,確保了被讀取的指針的正確性。

為了能夠在不同的時鐘域內(nèi)直接同步指針,可以對指針使用格雷碼的編碼方式,也就是指針每次移動只變化一位,這樣就避免了由于指針多位同時變化而無法直接同步的問題。圖3表示了一個三位地址的內(nèi)存用于格雷碼編碼的FIFO。n位地址的內(nèi)存需要n+1位的格雷碼。使用最高位(也就是第n-1位)作為狀態(tài)位,從第n—2到第0位作為地址的第n-2位到第0位;對狀態(tài)位(也就是第n-1位)和第n-2位進(jìn)行位異或運(yùn)算產(chǎn)生地址的第n-2位(也就是地址的最高位)。通過對圖3的觀察可以得知,四位格雷碼編碼的指針和三位二進(jìn)制加狀態(tài)位編碼的指針具有同樣的功能:指針產(chǎn)生的地址循環(huán)遍歷8個內(nèi)存地址,每一次遍歷后狀態(tài)位取反。值得注意的一點(diǎn),是當(dāng)指針從0100變化到1100的時候,相應(yīng)的地址由100變?yōu)?00,狀態(tài)位和一位地址同時發(fā)生了變化,所以不能同步由另一個時鐘域格雷碼指針產(chǎn)生的狀態(tài)位和地址位,此時應(yīng)該直接由另一個時鐘域同步指針來完成,由同步后的指針產(chǎn)生相應(yīng)的狀態(tài)位和地址位。


上一頁 1 2 下一頁

關(guān)鍵詞: 方法 設(shè)計 FIFO 異步

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉