新聞中心

EEPW首頁(yè) > EDA/PCB > 設(shè)計(jì)應(yīng)用 > PCI總線從設(shè)備接口的CPLD實(shí)現(xiàn)

PCI總線從設(shè)備接口的CPLD實(shí)現(xiàn)

作者: 時(shí)間:2012-02-17 來(lái)源:網(wǎng)絡(luò) 收藏

2.1 狀態(tài)機(jī)
狀態(tài)機(jī)是整個(gè)接口設(shè)計(jì)的控制核心,它控制著交易時(shí)序和控制信號(hào)的產(chǎn)生,文中結(jié)合規(guī)范的要求,使用Verilog HDL語(yǔ)言、采用One—hot編碼方式設(shè)計(jì)了全同步狀態(tài)機(jī),狀態(tài)機(jī)由表3所列的8個(gè)狀態(tài)組成,狀態(tài)機(jī)狀態(tài)轉(zhuǎn)移圖如圖2所示。

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

d.jpg


PCI目標(biāo)狀態(tài)機(jī)狀態(tài)轉(zhuǎn)移有以下幾種情形:
(1)Idle→B_busy→Idle,地址譯碼未被選中,則處于B_busy忙狀態(tài)等待交易結(jié)束,直到FRAME#失效當(dāng)前總線交易結(jié)束才返回Idle。
(2)Idle→B_busy→Wait→Backoff→Turn_ar→Idle,未能在16個(gè)時(shí)鐘周期內(nèi)準(zhǔn)備好第一個(gè)傳輸數(shù)據(jù),超時(shí)重試(RETRY)斷開(kāi)連接,總線停留在Backoff等待總線撤消FRAME#,然后總線釋放返回空閑態(tài)。
(3)Idle→B_busy→Wait→(R_wait)→L_data→(Backoff)→Turn_ar→Idle,從設(shè)備同時(shí)有效Ready和Term信號(hào),表明從設(shè)備不支持突發(fā)傳輸或者沒(méi)有更多的數(shù)據(jù)存儲(chǔ)空間進(jìn)行突發(fā)傳輸,只能進(jìn)行最后一個(gè)數(shù)據(jù)交易。如果是讀交易,則插入讀等待狀態(tài)R_wait。
若訪問(wèn)為突發(fā)訪問(wèn),當(dāng)惟一的數(shù)據(jù)期完成以后,總線停留在Backoff狀態(tài)等待主設(shè)備無(wú)效FRAME#,然后交易結(jié)束。
(4)Idle→B_busy→Wait→(R_wait)→Data→(L_data)→(Backoff)→Turn_ar→Idle,突發(fā)數(shù)據(jù)交易,讀交易則插入讀等待狀態(tài)R_wait。若從設(shè)備提出終止,則插入L_data和Backoff狀態(tài)與主設(shè)備斷開(kāi)連接;若是主設(shè)備提出終止則正常的結(jié)束總線交易。
在設(shè)計(jì)中,配置訪問(wèn)不支持突發(fā)傳輸,總線時(shí)序和情形(3)一致;而內(nèi)存訪問(wèn)支持突發(fā)傳輸,情形(3)和(4)的時(shí)序均會(huì)出現(xiàn)。用戶應(yīng)用可以通過(guò)Ready和Term信號(hào)不同的輸入組合來(lái)控制狀態(tài)機(jī)的狀態(tài)轉(zhuǎn)移,如表4所示。但是在本設(shè)計(jì)中的順序要么是先等待,然后正常數(shù)據(jù)交易、正常結(jié)束或者提出斷開(kāi)連接;要么是先等待,然后重試直接斷開(kāi)連接,只有這兩種順序,用戶應(yīng)用不能在正常數(shù)據(jù)交易期中再插入等待狀態(tài),這是不允許的。

e.jpg



關(guān)鍵詞: CPLD PCI 總線 設(shè)備

評(píng)論


相關(guān)推薦

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

關(guān)閉