I/O連線埠

CPU與外部設備存儲器的連線和數據交換都需要通過接口設備來實現,前者被稱為I/O接口,而後者則被稱為存儲器接口。存儲器通常在CPU的同步控制下工作,接口電路比較簡單;而I/O設備品種繁多,其相應的接口電路也各不相同,因此,習慣上說到接口只是指I/O接口。

基本介紹

  • 中文名:I/O連線埠
  • 外文名:I/O port
  • 分類:I/O接口晶片 I/O接口控制卡
  • 功能:協調時序差異;
  • 控制方式程式查詢方式
接口的分類,接口的功能,接口的控制方式,I/O連線埠定址,直接連線埠定址,間接連線埠定址,

接口的分類

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設備存儲和處理信息的格式不同,例如可以分為串列和並行兩種;也可以分為二進制格式、ASCII編碼和BCD編碼等。
信息類型不匹配:不同I/O設備採用的信號類型不同,有些是數位訊號,而 有些是模擬信號,因此所採用的處理方式也不同。
基於以上原因,CPU與外設之間的數據交換必須通過接口來完成,通常接口有以下一些功能:
(1)設定數據的暫存、緩衝邏輯,以適應CPU與外設之間的速度差異,接口通常由一些暫存器或RAM晶片組成,如果晶片足夠大還可以實現批量數據的傳輸;
(2)能夠進行信息格式的轉換,例如串列和並行的轉換;
(3)能夠協調CPU和外設兩者在信息的類型和電平的差異,如電平轉換驅動器、數/模或模/數轉換器等;
(4)協調時序差異;
(5)地址解碼和設備選擇功能;
(6)設定中斷和DMA控制邏輯,以保證在中斷和DMA允許的情況下產生中斷和DMA請求信號,並在接受到中斷和DMA應答之後完成中斷處理和DMA傳輸。

接口的控制方式

CPU通過接口對外設進行控制的方式有以下幾種:
這種方式下,CPU通過I/O指令詢問指定外設當前的狀態,如果外設準備就緒,則進行數據的輸入或輸出,否則CPU等待,循環查詢。
這種方式的優點是結構簡單,只需要少量的硬體電路即可,缺點是由於CPU的速度遠遠高於外設,因此通常處於等待狀態,工作效率很低
(2)中斷處理方式
在這種方式下,CPU不再被動等待,而是可以執行其他程式,一旦外設為數據交換準備就緒,可以向CPU提出服務請求,CPU如果回響該請求,便暫時停止當前程式的執行,轉去執行與該請求對應的服務程式,完成後,再繼續執行原來被中斷的程式。
中斷處理方式的優點是顯而易見的,它不但為CPU省去了查詢外設狀態和等待外設就緒所花費的時間,提高了CPU的工作效率,還滿足了外設的實時要求。但需要為每個I/O設備分配一個中斷請求號和相應的中斷服務程式,此外還需要一個中斷控制器(I/O接口晶片)管理I/O設備提出的中斷請求,例如設定中斷禁止、中斷請求優先權等。
此外,中斷處理方式的缺點是每傳送一個字元都要進行中斷,啟動中斷控制器,還要保留和恢復現場以便能繼續原程式的執行,花費的工作量很大,這樣如果需要大量數據交換,系統的性能會很低。
(3)DMA(直接存儲器存取)傳送方式
DMA最明顯的一個特點是它不是用軟體而是採用一個專門的控制器來控制記憶體與外設之間的數據交流,無須CPU介入,大大提高CPU的工作效率。
在進行DMA數據傳送之前,DMA控制器會向CPU申請匯流排控制 權,CPU如果允許,則將控制權交出,因此,在數據交換時,匯流排控制權由DMA控制器掌握,在傳輸結束後,DMA控制器將匯流排控制權交還給CPU

I/O連線埠定址

以8086/8088為例,其I/O連線埠採用獨立編制方式,可有64K位元組連線埠或32K個位元組連線埠。指令系統中設有專門的輸入指令IN和輸出指令OUT來訪問連線埠。I/O連線埠的定址方式有直接連線埠定址和間接連線埠定址兩種。

直接連線埠定址

直接連線埠定址是在指令中直接給出要訪問的連線埠地址,連線埠地址用一個8位二進制數表示,則此時最多允許定址256個連線埠。
例如:IN AL, 40H 從連線埠地址為40H的連線埠中取出位元組送給暫存AL
OUT 50H, AL 將AL中的內容輸出到連線埠地址為50H的連線埠中

間接連線埠定址

當訪問的連線埠地址數大於等於256時,直接連線埠定址不能滿足要求,而要採用間接連線埠定址方式。此時,連線埠的地址必須由DX暫存器指定,允許定址64K(0~65535)個連線埠。
例如:MOV DX, 309H
IN AL,DX 從連線埠地址為309H的連線埠中取出位元組給AL
MOV DX,206H
OUT DX,AL

相關詞條

熱門詞條

聯絡我們