跨越鴻溝:同步世界中的異步信號(hào)
握手與 FIFO
本文引用地址:http://cafeforensic.com/article/268638.htm在許多應(yīng)用中,跨時(shí)鐘域傳送的不只是簡(jiǎn)單的信號(hào),數(shù)據(jù)總線、地址總線和控制總線都會(huì)同時(shí)跨域傳輸。工程師們用一些其它的手段來(lái)處理這些情況,如握手協(xié)議和 FIFO 等。
當(dāng)幾個(gè)電路不能預(yù)知相互的響應(yīng)時(shí)間時(shí),握手方法能讓數(shù)字電路間實(shí)現(xiàn)有效的通信。例如,仲裁總線結(jié)構(gòu)可以讓一個(gè)以上的電路請(qǐng)求使用單個(gè)的總線,用仲裁方法來(lái)決定哪個(gè)電路可以獲得總線的訪問(wèn)權(quán),例如 PCI 或 AMBA(高級(jí)微控制器總線架構(gòu))。每個(gè)電路都發(fā)出一個(gè)請(qǐng)求信號(hào),由仲裁邏輯決定誰(shuí)是“贏家”。獲勝的電路會(huì)收到一個(gè)應(yīng)答,表示它可以訪問(wèn)總線。該電路于是中斷請(qǐng)求,開(kāi)始使用總線。
不同時(shí)鐘域電路使用的握手協(xié)議有兩種基本類(lèi)型:全握手(Full-handshake)和部分握手(partial-handshake)。每種類(lèi)型的握手都要用同步器,每種都各有自己的優(yōu)缺點(diǎn)。對(duì)全握手信號(hào),雙方電路在聲明或中止各自的握手信號(hào)前都要等待對(duì)方的響應(yīng)(圖 4)。首先,電路 A 聲明它的請(qǐng)求信號(hào),然后,電路 B 檢測(cè)到該請(qǐng)求信號(hào)有效后,聲明它的響應(yīng)信號(hào)。當(dāng)電路 A 檢測(cè)到響應(yīng)信號(hào)有效后,中止自己的請(qǐng)求信號(hào)。最后,當(dāng)電路 B 檢測(cè)到請(qǐng)求無(wú)效后,它中止自己的響應(yīng)信號(hào)。除非電路 A 檢測(cè)到無(wú)效的響應(yīng)信號(hào),否則它不會(huì)再聲明新的請(qǐng)求信號(hào)。
圖4,對(duì)全握手信號(hào),雙方電路在聲明或中止各自的握手信號(hào)前都要等待對(duì)方的響應(yīng)。
這種類(lèi)型的握手使用了電平同步器。設(shè)計(jì)人員將這種技術(shù)用在如下情況:響應(yīng)電路(電路 B)需要告知請(qǐng)求電路(電路 A)它可以處理請(qǐng)求。這種握手方法要求請(qǐng)求電路延遲它的下一個(gè)請(qǐng)求,直到它檢測(cè)到響應(yīng)信號(hào)無(wú)效。可以用經(jīng)驗(yàn)估算法判斷這個(gè)協(xié)議的時(shí)序:信號(hào)跨越一個(gè)時(shí)鐘域要花兩個(gè)時(shí)鐘周期的時(shí)間,信號(hào)在跨越多個(gè)時(shí)鐘域前被電路寄存。全部的時(shí)間序列是:A 時(shí)鐘域中最多五個(gè)周期加上 B 時(shí)鐘域最多六個(gè)周期。全握手類(lèi)型很強(qiáng)健,因?yàn)橥ㄟ^(guò)檢測(cè)請(qǐng)求與響應(yīng)信號(hào),每個(gè)電路都清楚地知道對(duì)方的狀態(tài)。這種方式的不足之處是完成所有交互的整個(gè)過(guò)程要花費(fèi)很多時(shí)鐘周期。
另一種類(lèi)型是部分握手,它可以縮短這些事件的過(guò)程。使用部分握手信號(hào)時(shí),通信雙方的電路都不等對(duì)方的響應(yīng)就中止各自的信號(hào),并繼續(xù)執(zhí)行握手命令序列。部分握手類(lèi)型比全握手類(lèi)型在健壯性方面稍弱,因?yàn)槲帐中盘?hào)并不指示各自電路的狀態(tài),每一電路都必須保存狀態(tài)信息(在全握手信號(hào)里這個(gè)信息被送出去)。但是,由于無(wú)需等待其它電路的響應(yīng),完整的事件序列花費(fèi)時(shí)間較少。
當(dāng)使用部
分握手信號(hào)方式時(shí),響應(yīng)的電路必須以正確的時(shí)序產(chǎn)生它的信號(hào)。如果響應(yīng)電路要
求先處理完一個(gè)請(qǐng)求,然后才能處理下一個(gè)請(qǐng)求,則響應(yīng)信號(hào)的時(shí)序就很重要。電路用它的響應(yīng)信號(hào)來(lái)指示它的處理任務(wù)何時(shí)完成。一種部分握手方法混合了電平與脈沖信號(hào),而其它的方法則只使用脈沖信號(hào)。
在第一種部分握手方法中,電路 A 以有效電平聲明其請(qǐng)求信號(hào),電路 B 則以一個(gè)單時(shí)鐘寬度脈沖作為響應(yīng)。此時(shí),電路 B 并不關(guān)心電路 A 何時(shí)中止它的請(qǐng)求信號(hào)。但為了使這種方法成立,電路 A 中止請(qǐng)求信號(hào)至少要有一個(gè)時(shí)鐘周期長(zhǎng),否則,電路 B 就不能區(qū)別前一個(gè)請(qǐng)求和新的請(qǐng)求。在這種握手方式下,電路 B 為請(qǐng)求信號(hào)使用一個(gè)電平同步器,電路 A 為響應(yīng)信號(hào)使用一個(gè)脈沖同步器。只有當(dāng)電路 B 檢測(cè)到請(qǐng)求信號(hào)時(shí)才發(fā)出響應(yīng)脈沖。這種情況可以使電路 A 通過(guò)控制其請(qǐng)求信號(hào)的時(shí)序,控制同步器接收到的脈沖間隔(圖 5)。同樣可以用經(jīng)驗(yàn)估算法確定時(shí)序,即信號(hào)跨越一個(gè)時(shí)鐘域要花兩個(gè)時(shí)鐘周期并且在跨越時(shí)鐘域前被電路寄存。
圖5,在一種部分握手方法中,電路 A 發(fā)出它的請(qǐng)求信號(hào),電路 B 則以一個(gè)單時(shí)鐘寬度脈沖作為響應(yīng)。
全部的序列為 A 時(shí)鐘域最多三個(gè)周期加上 B 時(shí)鐘域最多五個(gè)周期。這種部分握手方法比全握手方法在 A、B 兩個(gè)時(shí)鐘域分別少用了兩個(gè)和一個(gè)時(shí)鐘周期。如果采用第二種部分握手方法可以再減少一些時(shí)鐘周期,此時(shí)電路 A 用一個(gè)單時(shí)鐘寬度脈沖發(fā)出它的請(qǐng)求,而電路 B 也用一個(gè)單時(shí)鐘寬度脈沖響應(yīng)這個(gè)請(qǐng)求。這種情況下,兩個(gè)電路都需要保存狀態(tài),以指示請(qǐng)求正待處理。
圖6,這種握手類(lèi)型使用的是脈沖同步器,但如果其中一個(gè)電路時(shí)鐘比另一個(gè)電路時(shí)鐘快兩倍,則可以用邊沿檢測(cè)同步器來(lái)代替。
這種握手類(lèi)型使用的是脈沖同步器,但如果其中一個(gè)電路時(shí)鐘比另一個(gè)電路時(shí)鐘快兩倍,則可以用邊沿檢測(cè)同步器來(lái)代替(圖 6)。完整的時(shí)序是:A 時(shí)鐘域最多兩個(gè)周期加上 B 時(shí)鐘域最多三個(gè)周期。所以這種部分握手技術(shù)與全握手方法相比,在 A 時(shí)鐘域少用三個(gè)時(shí)鐘周期,在 B 時(shí)鐘域也少用三個(gè)時(shí)鐘周期。同時(shí),也比第一種部分握手方法分別在 A、B 時(shí)鐘域快了一個(gè)和兩個(gè)周期(表 2)。這些握手協(xié)議針對(duì)的都是跨越時(shí)鐘域的單一信號(hào)。但當(dāng)幾組信號(hào)要跨越時(shí)鐘域時(shí),設(shè)計(jì)人員就需要使用更加復(fù)雜的信號(hào)傳送方法。
表 2
數(shù)據(jù)路徑設(shè)計(jì)
在進(jìn)行信號(hào)同步時(shí)有一個(gè)重要的規(guī)則,那就是不應(yīng)當(dāng)在設(shè)計(jì)中的多個(gè)地方對(duì)同一信號(hào)進(jìn)行同步,即單個(gè)信號(hào)扇出至多個(gè)同步器。因?yàn)橥揭ㄒ坏絻蓚€(gè)時(shí)鐘周期,設(shè)計(jì)者不能確切地預(yù)測(cè)到每個(gè)信號(hào)何時(shí)跨越一個(gè)時(shí)鐘域。此外,在新時(shí)鐘域中一組經(jīng)同步后的信號(hào)其時(shí)序是不定的,因?yàn)橥窖舆t可以是一到兩個(gè)時(shí)鐘周期,這與輸入信號(hào)到達(dá)同步器的時(shí)間有關(guān)。這種情況會(huì)在各個(gè)同步信號(hào)間形成一種“競(jìng)爭(zhēng)狀況”。這種競(jìng)爭(zhēng)狀況在需要跨越時(shí)鐘域傳輸?shù)亩嘟M信號(hào)間也會(huì)發(fā)生,例如數(shù)據(jù)總線、地址總線和控制總線等。因此,不能對(duì)組中的每個(gè)信號(hào)單獨(dú)使用同步器,也不能對(duì)數(shù)據(jù)或地址總線的每一位單獨(dú)使用同步器,因?yàn)樵谛碌臅r(shí)鐘域中,要求每個(gè)信號(hào)同時(shí)有效。
一種解決總線同步問(wèn)題的方法是使用一個(gè)保持寄存器和握手信號(hào)。這種電路包括一個(gè)保持信號(hào)總線的寄存器,以及一個(gè)握手機(jī)制(圖 7)。握手信號(hào)指示新時(shí)鐘域的電路何時(shí)可以對(duì)總線采樣,以及源電路何時(shí)可以更換當(dāng)前寄存器中保存的內(nèi)容。
圖7,一種數(shù)據(jù)路徑同步器設(shè)計(jì)使用一個(gè)保持寄存器和握手信令。
在這種設(shè)計(jì)中,傳輸電路將數(shù)據(jù)(信號(hào)總線)存儲(chǔ)在保持寄存器,同時(shí)發(fā)出請(qǐng)求信號(hào)。這兩個(gè)動(dòng)作可以同時(shí)發(fā)生,因?yàn)檎?qǐng)求信號(hào)至少要花一個(gè)時(shí)鐘周期才能讓接收電路檢測(cè)到它(最小的握手-同步延遲)。當(dāng)接收電路采樣到數(shù)據(jù)(信號(hào)總線)時(shí),它發(fā)出一個(gè)響應(yīng)信號(hào)。這種設(shè)計(jì)使用了全握手方法,所以要花較長(zhǎng)時(shí)間才能完成整個(gè)傳輸。對(duì)接收電路而言,使用全握手信號(hào)的設(shè)計(jì)有較大的時(shí)間窗口用于對(duì)信號(hào)總線采樣,因而效率較低。如用部分握手方法代替全握手方法則可以加快傳輸速度。
用這種總線同步方式,你可以同步握手信號(hào),但不能同步信號(hào)總線。信號(hào)總線來(lái)自于保持寄存器,它在接收電路采樣前一直保持穩(wěn)定。注意,如果傳輸電路向接收電路提交數(shù)據(jù)太快以致來(lái)不及處理,則應(yīng)用中的總線同步可能不起作用。
高級(jí)數(shù)據(jù)路徑設(shè)計(jì)
在許多情況下,數(shù)據(jù)在跨越時(shí)鐘域時(shí)需要“堆積”起來(lái),因此使用單個(gè)保持寄存器無(wú)法完成工作。例如一種情況是某個(gè)傳輸電路猝發(fā)式發(fā)送數(shù)據(jù),接收電路來(lái)不及采樣。另一種情況是接收電路采樣速度超出傳輸電路發(fā)送數(shù)據(jù)的速度,但采樣的數(shù)據(jù)寬度不夠。這些情況就要使用 FIFO 了。
基本上,設(shè)計(jì)者使用 FIFO 有兩個(gè)目的:速度匹配或數(shù)據(jù)寬度匹配。在速度匹配時(shí),F(xiàn)IFO 較快的端口處理猝發(fā)的數(shù)據(jù)傳輸,而較慢的端口則維持恒定的數(shù)據(jù)流。但是,雖然訪問(wèn)方式和速度不同,但進(jìn)出 FIFO 的平均數(shù)據(jù)速率必須是相同的,否則 FIFO 就會(huì)出現(xiàn)上溢(overflow)或下溢(underflow)問(wèn)題。與單寄存器設(shè)計(jì)相同,F(xiàn)IFO 將數(shù)據(jù)保存在寄存器或存儲(chǔ)器中,同時(shí)同步狀態(tài)信號(hào),判斷何時(shí)可以把數(shù)據(jù)寫(xiě)入 FIFO 或從 FIFO 中讀出。
在速度匹配應(yīng)用中,每個(gè)端口(讀或?qū)?的時(shí)鐘不同。FIFO 中的寄存器使用寫(xiě)端口時(shí)鐘,就像保持寄存器使用電路時(shí)鐘來(lái)改變寄存器內(nèi)容一樣。信號(hào)同步發(fā)生在指針邏輯中,而且比握手信號(hào)要復(fù)雜得多。
模擬信號(hào)相關(guān)文章:什么是模擬信號(hào)
電路相關(guān)文章:電路分析基礎(chǔ)
脈沖點(diǎn)火器相關(guān)文章:脈沖點(diǎn)火器原理
評(píng)論