接口分類
I/O接口的功能是負責實現CPU通過
系統匯流排把I/O電路和
外圍設備聯繫在一起,按照電路和設備的複雜程度,I/O接口的硬體主要分為兩大類:
(1)I/O接口晶片
這些晶片大都是
積體電路,通過CPU輸入不同的命令和參數,並控制相關的I/O電路和簡單的外設作相應的操作,常見的接口晶片如定時計數器、中斷控制器、
DMA控制器、
並行接口等。
(2)I/O接口控制卡
由若干個積體電路按一定的邏輯組成為一個部件,或者直接與CPU同在主機板上,或是一個
外掛程式插在系統匯流排插槽上。
按照接口的連線對象來分,又可以將他們分為
串列接口、並行接口、
鍵盤接口和磁碟接口等。
接口功能
由於計算機的
外圍設備品種繁多,幾乎都採用了機電傳動設備,因此,
CPU在與I/O設備進行數據交換時存在以下問題:
速度不匹配:I/O設備的工作速度要比CPU慢許多,而且由於種類的不同,他們之間的速度差異也很大,例如硬碟的傳輸速度就要比印表機快出很多。
時序不匹配:各個I/O設備都有自己的定時控制電路,以自己的速度傳輸數據,無法與CPU的時序取得統一。
信息類型不匹配:不同I/O設備採用的信號類型不同,有些是數位訊號,而有些是
模擬信號,因此所採用的處理方式也不同。
基於以上原因,CPU與外設之間的數據交換必須通過接口來完成,通常接口有以下一些功能:
(1)設定數據的暫存、緩衝邏輯,以適應
CPU與外設之間的速度差異,接口通常由一些
暫存器或RAM晶片組成,如果晶片足夠大還可以實現批量數據的傳輸;
(2)能夠進行信息格式的轉換,例如
串列和
並行的轉換;
(4)協調時序差異;
(5)地址解碼和設備選擇功能;
(6)設定中斷和
DMA控制邏輯,以保證在中斷和DMA允許的情況下產生中斷和DMA請求信號,並在接受到中斷和DMA應答之後完成
中斷處理和DMA傳輸。
控制方式
這種方式下,CPU通過I/O指令詢問指定外設當前的狀態,如果外設準備就緒,則進行數據的輸入或輸出,否則CPU等待,循環查詢。
這種方式的優點是結構簡單,只需要少量的硬體電路即可,缺點是由於CPU的速度遠遠高於外設,因此通常處於等待狀態,工作效率很低
在這種方式下,CPU不再被動等待,而是可以執行其他程式,一旦外設為數據交換準備就緒,可以向CPU提出服務請求,CPU如果回響該請求,便暫時停止當前程式的執行,轉去執行與該請求對應的服務程式,完成後,再繼續執行原來被中斷的程式。
中斷處理方式的優點是顯而易見的,它不但為
CPU省去了查詢外設狀態和等待外設就緒所花費的時間,提高了CPU的工作效率,還滿足了外設的實時要求。但需要為每個I/O設備分配一個
中斷請求號和相應的
中斷服務程式,此外還需要一個中斷控制器(I/O接口晶片)管理I/O設備提出的中斷請求,例如設定
中斷禁止、中斷請求優先權等。
此外,
中斷處理方式的缺點是每傳送一個字元都要進行中斷,啟動中斷控制器,還要保留和恢復現場以便能繼續原程式的執行,花費的工作量很大,這樣如果需要大量數據交換,系統的性能會很低。
DMA最明顯的一個特點是它不是用軟體而是採用一個專門的控制器來控制記憶體與外設之間的數據交流,無須CPU介入,大大提高CPU的工作效率。
在進行DMA
數據傳送之前,DMA控制器會向CPU申請匯流排控制權,CPU如果允許,則將控制權交出,因此,在數據交換時,匯流排控制權由DMA控制器掌握,在傳輸結束後,
DMA控制器將匯流排控制權交還給
CPU。
(4) 通道方式
I/O設備故障
計算機中的I/O設備故障表現主要有以下三個方面:
I/O設備就無法正常使用了,包括各類外接接口、筆記本的鍵盤打不出字、
觸控屏不靈等現象。
電腦維修工具:
主機板診斷卡插在主機板上進行跑碼會顯示FF代碼、00代碼、DD代碼或無代碼及反覆跑C1~C5代碼的現象。
I/O設備短路等故障還會導致計算機連線外部設備的時候可能會受到靜電的衝擊或干擾以至於損壞其他
電容、
二極體等元器件。從而導致設備無法開機的嚴重後果。
防範I/O設備故障:I/O設備屬於精密的電子產品,使用過程中對環境要求嚴格,切莫在高溫,潮濕的環境下使用。
i/o進程上出現CPU瓶頸
在CPU性能受限制的大型機環境裡,i/o進程會影響到工作負載。
在cpu受到限制的系統中,批處理進程會使i/o的性能變得更糟。通常在系統優先權最低的情況下,當CPU受到瓶頸時,批處理進程因為要和線上進程進行資源爭奪而勉強運行i/o。每一次i/o,一個進程開始釋放CPU資源,並由更高優先權的進程接管。但即使i/o進程很快的完成,批處理進程也需要去爭奪已經完成任務的進程資源,並接受CPU的執行緒調度。
線上進程通常可以獲得必要的CPU資源。i/o進程不會減緩客戶信息控制系統(
CICS)或信息管理系統(IMS)的工作負荷,因為每個i/o並不同步。
然而,一些特別的進程與批處理一樣都受到CPU瓶頸的影響。在CICS,一旦i/o完成的事務處理,在i/o繼續工作前,i/o已經越過CICS的鏈式調度程式。在CICS工作負載中尤其明顯的是i/o有深調度佇列。
IMS事務中運行訊息處理區域(MPR’S)採取不同的路徑,但都是異曲同工。一旦資料庫i/o完成, IMS在它處理更多工作前會通知在和伺服器爭奪資源的MPR。
最快的i/o是不能實現的。因此, 儘可能利用數據輸入記憶體預防在cpu受限的環境中的瓶頸。i/o輸入記憶體的數據包括緩衝池,參考表,數據快取空間和其他方法。