9.3. 一個(gè) I/O 端口例子

2018-02-24 15:50 更新

9.3.?一個(gè) I/O 端口例子

我們用來(lái)展示一個(gè)設(shè)備驅(qū)動(dòng)內(nèi)的端口 I/O 的例子代碼, 操作通用的數(shù)字 I/O 端口; 這樣的端口在大部分計(jì)算機(jī)系統(tǒng)中找到.

一個(gè)數(shù)字 I/O 端口, 在它的大部分的普通的化身中, 是一個(gè)字節(jié)寬的 I/O 位置, 或者內(nèi)存映射的或者端口映射的. 當(dāng)你寫一個(gè)值到一個(gè)輸出位置, 在輸出管腳上見(jiàn)到的電信號(hào)根據(jù)寫入的單個(gè)位而改變. 當(dāng)你從一個(gè)輸入位置讀取一個(gè)值, 輸入管腳上所見(jiàn)的當(dāng)前邏輯電平作為單個(gè)位的值被返回.

這樣的 I/O 端口的實(shí)際實(shí)現(xiàn)和軟件接口各個(gè)系統(tǒng)不同. 大部分時(shí)間, I/O 管腳由 2 個(gè) I/O 位置控制: 一個(gè)允許選擇使用那些位作為輸入, 哪些位作為輸出, 以及一個(gè)可以實(shí)際讀或?qū)戇壿嬰娖降? 有時(shí), 但是, 事情可能更簡(jiǎn)單, 并且這些位是硬連線為輸入或輸出(但是, 在這個(gè)情況下, 它們不再是所謂的"通用 I/O"); 在所有個(gè)人計(jì)算機(jī)上出現(xiàn)的并口是這樣一個(gè)非通用 I/O 端口. 任一方式, I/O 管腳對(duì)我們馬上介紹的例子代碼是可用的.

9.3.1.?并口縱覽

因?yàn)槲覀兤谕蟛糠肿x者以所謂的"個(gè)人計(jì)算機(jī)"的形式使用一個(gè) x86 平臺(tái), 我們覺(jué)得值得解釋一下 PC 并口如何設(shè)計(jì)的. 并口是在個(gè)人計(jì)算機(jī)上運(yùn)行數(shù)字 I/O 例子代碼的外設(shè)接口選擇. 盡管大部分讀者可能有并口規(guī)范用, 為你的方便, 我們?cè)谶@里總結(jié)一下它們.

并口, 在它的最小配置中 ( 我們?yōu)g覽一下 ECP 和 EPP 模式) 由 3 個(gè) 8-位端口組成. PC 標(biāo)準(zhǔn)在 0x378 開始第一個(gè)并口的 I/O 端口并且第 2 個(gè)在 0x278. 第一個(gè)端口是一個(gè)雙向數(shù)據(jù)寄存器; 它直接連接到物理連接器的管腳 2 - 9. 第 2 個(gè)端口是一個(gè)只讀狀態(tài)寄存器; 當(dāng)并口為打印機(jī)使用, 這個(gè)寄存器報(bào)告打印機(jī)狀態(tài)的幾個(gè)方面, 例如正在線, 缺紙, 或者忙. 第 3 個(gè)端口是一個(gè)只出控制寄存器, 它, 在其他東西中, 控制是否中斷使能.

并口通訊中使用的信號(hào)電平是標(biāo)準(zhǔn)的 TTL 電平: 0 和 5 伏特, 邏輯門限在大概 1.2 伏特. 你可依靠端口至少符合標(biāo)準(zhǔn) TTL LS 電流規(guī)格, 盡管大部分現(xiàn)代并口在電流和電壓額定值都工作的好.

并口連接器和計(jì)算機(jī)內(nèi)部電路不隔離, 當(dāng)你想直接連接邏輯門到這個(gè)端口是有用的. 但是你不得不小心地正確連接線; 并口電路當(dāng)你使用你自己的定制電路時(shí)容易損壞, 除非你給你的電路增加絕緣. 你可以選擇使用插座并口如果你害怕會(huì)損壞你的主板.

位的規(guī)范在圖 并口的管腳 中概述. 你可以存取 12 個(gè)輸出位和 5 個(gè)輸入位, 有些是在它們地信號(hào)路徑上邏輯地翻轉(zhuǎn)了. 唯一的沒(méi)有關(guān)聯(lián)信號(hào)管腳的位是端口 2 的位 4 (0x10), 它使能來(lái)自并口的中斷. 我們使用這個(gè)位作為我們的在第 10 章中的中斷處理的實(shí)現(xiàn)的一部分.

圖?9.1.?并口的管腳

以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)