PCI總線(xiàn)I/O時(shí)序波形觀(guān)測及分析

發(fā)布時(shí)間:2010-9-20 10:59    發(fā)布者:conniede
關(guān)鍵詞: I/O , PCI總線(xiàn) , 時(shí)序波形
1 引 言

PCI總線(xiàn)(Peripheral Component Interconnect)即外設部件互連,是一種新型的、同步的、高帶寬的、獨立于處理器的總線(xiàn)。從1992年創(chuàng )立規范到如今,PCI總線(xiàn)已成為了事實(shí)上計算機的標準總線(xiàn)。其所以能在各類(lèi)總線(xiàn)中脫穎而出,是因為其具有傳輸速度快、支持無(wú)限猝發(fā)讀寫(xiě)方式、支持并行工作方式、獨立于處理器、提供4種規格、數據線(xiàn)和地址線(xiàn)采用了多路復用結構、支持即插即用功能等特點(diǎn)。本文重點(diǎn)介紹了PCI總線(xiàn)的寫(xiě)周期的時(shí)序波形的測量技術(shù)及分析方法,給出了時(shí)序波形的分析結果。

2 PCI總線(xiàn)的功能

2.1 連接到PCI總線(xiàn)上的設備

連接到PCI總線(xiàn)上的設備分為兩類(lèi):

(1)主控設備(master):PCI支持多主控設備,主控設備可以控制總線(xiàn)、驅動(dòng)地址、數據及控制信號;

(2)目標設備(target):不能啟動(dòng)總線(xiàn)操作,只能依賴(lài)于主控設備向他進(jìn)行傳遞或從中讀取數據。

2.2 有關(guān)PCI引腳信號

有關(guān)PCI引腳信號說(shuō)明如下:

AD[31~0]:地址、數據信號復用線(xiàn)。PCI總線(xiàn)支持寫(xiě)猝發(fā)和讀猝發(fā)。一個(gè)總線(xiàn)傳輸分為一個(gè)地址傳送階段和一個(gè)或多個(gè)數據傳送階段。有效,表示地址傳送階段開(kāi)始,此時(shí)AD[31~0]包含一個(gè)32位的物理地址,選中I/O的一個(gè)字節單元或主存的一個(gè)雙字單元。接下來(lái)為數據傳送階段(IRTY和TRDY同時(shí)有效),此時(shí)AD[7~0]包含最低字節數據,AD[31~24]包含最高字節數據。

C/BE[3~0]:總線(xiàn)指令和字節允許信號的復用線(xiàn)。在地址傳送階段,C/BE[3~0]上傳送的是4位編碼的總線(xiàn)指令。在數據傳送階段,C/BE[3~0]用作字節允許標志,以決定數據線(xiàn)上的哪些字節數據為有效數據,C/BE[3~0]可依次對應于字節3,2,1,0。
FRAME:周期幀信號。由當前總線(xiàn)控制者產(chǎn)生,表示一個(gè)總線(xiàn)傳輸的開(kāi)始和延續。

FRAME從無(wú)效變?yōu)橛行В砻骺偩(xiàn)傳輸開(kāi)始;保持有效,表明總線(xiàn)傳輸繼續進(jìn)行(1個(gè)或n個(gè)數據節拍正在繼續);FRAME從有效變?yōu)闊o(wú)效,表明進(jìn)入數據傳輸的最后一個(gè)數據傳送階段。

2.3 總線(xiàn)指令定義

在地址傳送階段,C/BE[3~0]線(xiàn)上送出總線(xiàn)指令的編碼信息?偩(xiàn)指令用于對目標設備說(shuō)明當前總線(xiàn)控制者正在進(jìn)行的總線(xiàn)傳輸類(lèi)型。表1給出了總線(xiàn)指令的定義。



I/O讀:用于從一個(gè)被選中的I/O單元中讀取數據。

I/O寫(xiě):用于寫(xiě)數據到一個(gè)被選中的I/O單元中。

3 測量PCI總線(xiàn)的I/O寫(xiě)時(shí)序波形的技術(shù)及分析方法

測量PCI總線(xiàn)的I/O寫(xiě)時(shí)序波形共分3個(gè)部分,如圖1所示。



具體的實(shí)現測量的過(guò)程及分析方法介紹如下

3.1 編寫(xiě)測試程序

用匯編語(yǔ)言編寫(xiě)測試程序,該程序如下:



3.2 制作測試板

PCI波形采用廈門(mén)廈華三寶計算機有限公司狀元一族主板,執行標準號:Q/FSl0938-1999。

取一塊該PCI總線(xiàn)實(shí)驗板,根據引腳說(shuō)明,將要測試的各點(diǎn)用焊接的方法引出,并標明引腳名稱(chēng),各測試點(diǎn)對應關(guān)系如下:


3.3 建立泰克示波器與PC機2通信連接

利用泰克TDS210型存儲示波器的RS 232通信接口與pc機2相連,該PC機用來(lái)將示波器測出的波形轉換為.CSV文件,過(guò)程如下:

PC機2與泰克示波器通信連接的操作步驟:

(1)TDS一210型存儲示波器RS 232通信接口用專(zhuān)用電纜與PC機相連。

(2)打開(kāi)存儲示波器電源,啟動(dòng)PC機2。

(3)在PC機2窗口中點(diǎn)擊Wavestar for Oscillose。

(4)點(diǎn)擊Instrument manater(檢測通信連接)→Responding(檢測完成,關(guān)閉"×")。

3.4 數據采集、數據轉換的過(guò)程(操作步驟)

(1)檢查焊接無(wú)誤后,將該實(shí)驗板插入具有PCI插槽的被測計算機上,將軟盤(pán)插入被測計算機,該軟盤(pán)已存入用匯編語(yǔ)言寫(xiě)成的測試程序(TESTPCI),通電啟動(dòng)被測計算機,即PC機1。

(2)接通示波器的電源,設置好示波器兩通道的值,將CH1通道接FRAME,將CH2通道接AD0,在PC機1計算機狀態(tài)提示符A:下,輸入TESTPCI后回車(chē),在泰克示波器面板上按下AUTORUN,調整頻率,使FRAME的周期在4個(gè)以上,再按下RUN/STOP,使顯示的波形穩定。

(3)將泰克示波器按上述方法與PC機2計算機相連,以便他們之間通信,這臺計算機用來(lái)對泰克示波器測試下來(lái)的波形進(jìn)行數據轉換,該計算機必須安裝Wavestrafor Oscillose軟件,該軟件用來(lái)將泰克示波器測試的波形轉換為.CSV數據文件。

(4)測完FRM/AD0波形之后,將CH2通道改接AD8,在被測計算機的鍵盤(pán)上按下F3后回車(chē),執行測試程序,再按下泰克示波器的RUNysT()P,必須注意的是在第一次按下AUTORUN后,接下來(lái)只要按RUN/STOP,不能按AUTORUN,否則時(shí)序會(huì )不一樣。按同樣的方法測量FRAME與CBE3,FRAME與CBE2,FRAME與CBE1,FRAME與CBE0,FRAME與AD16,FRAME與AD24,AD0與AD8,AD0與CBE0,AD0與CBE1,AD0與C13E2,AD0與CBE3各組的波形,并分別將測試的波形轉換為.CSV數據文件后存盤(pán)。

(5)將獲得的數據進(jìn)行分析。在PC機3計算機上安裝ORIGIN6.0 PROFESSIONAL軟件,利用該軟件對.CSV數據文件進(jìn)行分析。

(6)分析得到的PCI寫(xiě)周期的時(shí)序波形詳見(jiàn)第五部分實(shí)測PCI總線(xiàn)I/O寫(xiě)周期的時(shí)序波形。

4 實(shí)測夏華狀元一族主板PCI寫(xiě)周期的時(shí)序波形及分析

通過(guò)用Origin 6.0 Professional軟件對采集來(lái)的數據的分析,得知FRAME的四個(gè)周期對應AD0的一個(gè)周期,因此分析時(shí)就對AD0的一個(gè)周期進(jìn)行分析,然后找到與AD0對應的

AD8的波形與AD0塒應的CBE3的波形、與AD0對應的CBE2D的波形、與AD0對應的CBE1的波形、與AD0對應的CBE0的波形、與AD0對應的AD16的波形與AD0對應的AD24的波形。

圖2的寫(xiě)時(shí)序波形分析如下:

當程序中向6018H單元寫(xiě)進(jìn)00H,向6019H單元寫(xiě)進(jìn)01H時(shí),測得的波形如圖2所示。在圖2波形中,6018H單元的最低位地址線(xiàn)A0為"O",6019H單元的最低位地址線(xiàn)A0為"l",在地址傳送階段,C/BE[3~0]上傳送的是4位編碼的總線(xiàn)指令,從波形中可看出C/BE[3~0]在FRAME的四個(gè)周期中全為"0011",根據總線(xiàn)指令定義,該指令類(lèi)型為I/O寫(xiě)。在FRAME的前兩個(gè)周期中,A0為"0",在FRAME的后兩個(gè)周期中,A0為"1",A8在FRAME的四個(gè)周期中全為"0",這符合程序中6018H,6019H的地址。在數據傳送階段,C/BE[3~O]用作字節允許標志,以決定數據線(xiàn)上的哪些字節數據為有效數據,C/BE[3~0]依次對應于字節3,2,1,0。從圖中可看出,D0在FRAME的四個(gè)周期中全為"0",D8在FRAME的前兩個(gè)周期中為"0",后兩個(gè)周期中為"1",從波形中可看出在FRAME的前兩個(gè)周期中c/BE[3~0]為"1110",根據字節允許標志定義,第0字節的數據為有效數據,因此D0的數據有效,為"0",與程序中向6018H單元寫(xiě)進(jìn)00H相一致。在FRAME的后兩個(gè)周期中C/BE[3~0]為"0101",根據字節允許標志定義,第1、3字節的數據為有效數據,因此D8,D24的數據有效,D8為"1",而D24無(wú)數據,與程序中向6019H單元寫(xiě)進(jìn)01H相一致。

圖3的寫(xiě)時(shí)序波形分析如下:

將程序稍改,即向6018H單元寫(xiě)進(jìn)0lH,向6019H單元寫(xiě)進(jìn)00H。測得的波形如圖3。從圖3中可看出C/BE[3~0]在FRAME的4個(gè)周期中全為"0011",根據總線(xiàn)指令定義,該指令類(lèi)型為I/O寫(xiě)。在FRAME的前兩個(gè)周期中,A0為"0",在FRAME的后兩個(gè)周期中,A0為"1",A8在FRAME的四個(gè)周期中全為"0",這符合程序中6018H,6019H的地址。在數據傳送階段,從圖中可看出,D0在FRAME的四個(gè)周期中全為"0",D8在FRAME的四個(gè)周期中全為"1",從波形中可看出在FRAME的前兩個(gè)周期中C/BE[3~0]為"1101",根據字節允許標志定義,第1字節的數據為有效數據,因此D8的數據有效,為"1",與程序中向6018H單元寫(xiě)進(jìn)01H相一致。在FRAME的后兩個(gè)周期中c/BE[3~0]為"1110",根據字節允許標志定義,第0字節的數據為有效數據,因此D0的數據有效,為"0",與程序中向6019H單元寫(xiě)進(jìn)00H相一致。說(shuō)明數據是由寫(xiě)進(jìn)6018H,6019H的數據決定。

5 結 語(yǔ)

從以上的分析可看出I/O寫(xiě)的時(shí)序波形是正確的,因此采用這種測試I/O寫(xiě)時(shí)序的方法是可行的。采用類(lèi)似方法還可測試I/O讀時(shí)序波形。對于研究PCI總線(xiàn)的時(shí)序提供了一種可行有效的方法。
本文地址:http://selenalain.com/thread-28125-1-1.html     【打印本頁(yè)】

本站部分文章為轉載或網(wǎng)友發(fā)布,目的在于傳遞和分享信息,并不代表本網(wǎng)贊同其觀(guān)點(diǎn)和對其真實(shí)性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問(wèn)題,我們將根據著(zhù)作權人的要求,第一時(shí)間更正或刪除。
您需要登錄后才可以發(fā)表評論 登錄 | 立即注冊

關(guān)于我們  -  服務(wù)條款  -  使用指南  -  站點(diǎn)地圖  -  友情鏈接  -  聯(lián)系我們
電子工程網(wǎng) © 版權所有   京ICP備16069177號 | 京公網(wǎng)安備11010502021702
快速回復 返回頂部 返回列表
午夜高清国产拍精品福利|亚洲色精品88色婷婷七月丁香|91久久精品无码一区|99久久国语露脸精品|动漫卡通亚洲综合专区48页