PCI總線從設(shè)備接口的CPLD實(shí)現(xiàn)
2.1 狀態(tài)機(jī)
狀態(tài)機(jī)是整個PCI從設(shè)備接口設(shè)計的控制核心,它控制著PCI總線交易時序和控制信號的產(chǎn)生,文中結(jié)合PCI規(guī)范的要求,使用Verilog HDL語言、采用One—hot編碼方式設(shè)計了全同步狀態(tài)機(jī),狀態(tài)機(jī)由表3所列的8個狀態(tài)組成,狀態(tài)機(jī)狀態(tài)轉(zhuǎn)移圖如圖2所示。本文引用地址:http://www.ex-cimer.com/article/190766.htm
PCI目標(biāo)狀態(tài)機(jī)狀態(tài)轉(zhuǎn)移有以下幾種情形:
(1)Idle→B_busy→Idle,地址譯碼設(shè)備未被選中,則處于B_busy總線忙狀態(tài)等待總線交易結(jié)束,直到FRAME#失效當(dāng)前總線交易結(jié)束才返回Idle。
(2)Idle→B_busy→Wait→Backoff→Turn_ar→Idle,設(shè)備未能在16個時鐘周期內(nèi)準(zhǔn)備好第一個傳輸數(shù)據(jù),超時重試(RETRY)斷開連接,總線停留在Backoff等待總線撤消FRAME#,然后總線釋放返回空閑態(tài)。
(3)Idle→B_busy→Wait→(R_wait)→L_data→(Backoff)→Turn_ar→Idle,從設(shè)備同時有效Ready和Term信號,表明從設(shè)備不支持突發(fā)傳輸或者沒有更多的數(shù)據(jù)存儲空間進(jìn)行突發(fā)傳輸,只能進(jìn)行最后一個數(shù)據(jù)交易。如果是讀交易,則插入讀等待狀態(tài)R_wait。
若訪問為突發(fā)訪問,當(dāng)惟一的數(shù)據(jù)期完成以后,總線停留在Backoff狀態(tài)等待主設(shè)備無效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è)備斷開連接;若是主設(shè)備提出終止則正常的結(jié)束總線交易。
在設(shè)計中,配置訪問不支持突發(fā)傳輸,總線時序和情形(3)一致;而內(nèi)存訪問支持突發(fā)傳輸,情形(3)和(4)的時序均會出現(xiàn)。用戶應(yīng)用可以通過Ready和Term信號不同的輸入組合來控制狀態(tài)機(jī)的狀態(tài)轉(zhuǎn)移,如表4所示。但是在本設(shè)計中的順序要么是先等待,然后正常數(shù)據(jù)交易、正常結(jié)束或者提出斷開連接;要么是先等待,然后重試直接斷開連接,只有這兩種順序,用戶應(yīng)用不能在正常數(shù)據(jù)交易期中再插入等待狀態(tài),這是不允許的。
評論