IO接口擴展電路設(shè)計_第1頁
IO接口擴展電路設(shè)計_第2頁
IO接口擴展電路設(shè)計_第3頁
IO接口擴展電路設(shè)計_第4頁
IO接口擴展電路設(shè)計_第5頁
已閱讀5頁,還剩5頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

-.z.I/O接口擴展電路設(shè)計

8051系列單片機如果系統(tǒng)不做任何擴展,P0~P3接口可做I/O接口使用。只要稍微擴展系統(tǒng),P0、P2接口則被用為地址線。P0接口還兼做數(shù)據(jù)線,P3接口常被專用線占用,只有Pl接口可做I/O接口。一個實際系統(tǒng),只有8位I/O接口往往是不夠用的,所以I/O接口也需要擴展。本節(jié)重點介紹I/O接口擴展方法及應(yīng)用實例。

I/O接口擴展方式主要有兩種:總線擴展法和串行口擴展法??偩€擴展又可分為簡單I/O接口擴展和可編程I/O接口擴展。

擴展I/O接口常用芯片有TTL、CMOS鎖存器、三態(tài)門芯片,如74系列的373、244、

273、367等,這些常用來擴展簡單I/O接口。可編程芯片常用8255、8155等,利用程序?qū)π酒M展設(shè)置,軟硬件結(jié)合實現(xiàn)對I/O接口的擴展。簡單I/O接口擴展

在單片機應(yīng)用系統(tǒng)中,利用TTL芯片、S鎖存器、三態(tài)門等接口芯片把P0接口

擴展,常選用74LS273、74LS373、74LS244等芯片。這些芯片價格低,構(gòu)造簡單,使擴展靈活方便。

如圖6-7所示是一個利用74LS273和74LS244,將8位P0接口擴展成簡單的輸入、輸出口的電路。74LS273是8D鎖存器擴展輸出口,輸出端接8個LED發(fā)光二極管,以顯示開關(guān)狀態(tài),*位低電平時二極管發(fā)光。74LS244是緩沖驅(qū)動器,擴展輸入口,它的8個輸入端分別接8個按鈕開關(guān)。74LS273與74LS244的工作受P2.0、RD、WR三條控制線控制。

其工作原理如下。

當(dāng)P2.0=0,WR=0(RD=1)選中74LS273芯片,CPU通過P0接口輸出數(shù)據(jù)鎖存到74LS273,74LS273的輸出端低電平位對應(yīng)的LED發(fā)光二極管點亮;當(dāng)P2.0=0,RD=0(WR=1)時選中74LS244,此時假設(shè)無鍵按下,輸入全為高電平,當(dāng)*鍵按下時則對應(yīng)位輸入為"0〞,74LS244的輸入端不全為"1〞,其輸入狀態(tài)通過P0接口數(shù)據(jù)線被CPU讀入機內(nèi)。

總之,在圖6-7中只要保證P2.0端低電平就有可能使擴展輸入口或輸出口工作。至于哪一個口工作受WR和RD控制線控制,二者不會同時為"0〞,故在圖6-7中,兩個擴展芯片可共用一個地址。

擴展口地址確定原則,只要保證P2.0為"0〞。其他地址位或"0〞或"1〞即可。如地址用FEFFH(無效位全為"1〞),用0000H(無效位全為"0〞)。輸出程序段:

MOV

A,

#data

;數(shù)據(jù)→A

MOV

DPTR,#0FEFFH

;I/O地址→DPTR

MOV*

DPTR,A

;WR為低電平,數(shù)據(jù)74LS273口輸出

輸入程序段:

MOV

DPTR,#OFEFFH

;I/O地址→DPTR

MOV*

A,DPTR

;RD為低電平,74LS244接口數(shù)據(jù)讀入內(nèi)部RAM

例要求編程把按鍵狀態(tài)通過圖6-7中的發(fā)光二極管顯示出來。

程序

LP:

MOV

DPTR,#0FEFFH

;輸入口地址→DPTR

MOV

A,DPTR

;鍵狀態(tài)送A

MOV*

DPTR,A

;A數(shù)據(jù)送顯示輸出口

SJMP

LP

;〔輸入、輸出公用一個地址〕反復(fù)連續(xù)執(zhí)行8255可編程并行I/O接口擴展與電路設(shè)計8255是一個單片機系統(tǒng)常用的可編程芯片,利用指令設(shè)置各口的工作方式。為了對8255合理設(shè)置,靈活應(yīng)用,有必要了解他的內(nèi)部構(gòu)造及工作原理。

1.8255內(nèi)部構(gòu)造及引腳功能

8255是一個有40引腳雙列支插型可編程芯片,內(nèi)部及引腳如圖6-8所示。

由圖6-8可見,8255內(nèi)部有3個并行的8位I/O接口,分別稱為A口、B口、C口。擴展一片8255則可擴展24位并行端口。引腳功能介紹如下:

(1)接口線

A、B、C3個I/O接口的引線端分別為:

PA0~PA7、PB0~PB7、PC0~PC7共24條端線。3個口皆為鎖存/緩沖存放器,A口、B口有鎖存功能,C口無鎖存功能。A、B、C3口的工作方式由程序設(shè)置。

A口可設(shè)置為輸入或輸出或雙向方式工作。

B口只能設(shè)置為輸入或輸出,不能雙向方式工作。

C口可設(shè)置為輸入或輸出口。它的特點是可分成高、低兩個4位使用。上半部PC4~PC7與A口組成一組叫A組;下半部PC0~PC3與B口組成一組為B組,便于控制。

(2)數(shù)據(jù)線

8255是8位芯片,有8位數(shù)據(jù)線D0~D7。數(shù)據(jù)線接于8051的P0接口,用以實現(xiàn)8255與CPU之間的數(shù)據(jù)傳送。

(3)控制線

控制線控制8255的讀、寫、復(fù)位及片選等。

RD:讀入控制線,低電平有效,當(dāng)其為低電平時CPU對8255進展讀操作,此時8255相應(yīng)口為輸入口。

WR:輸出控制線,低電平有效,當(dāng)WR為低電平時,CPU輸出數(shù)據(jù)或命令到8255端口,此時8255相應(yīng)口為輸出口。

RESET:復(fù)位端,高電平有效,8255內(nèi)部存放器全清0,24條I/O口線為高阻狀態(tài)。

CS:片選線,當(dāng)CS為低電平時,CPU選中此8255芯片。

(4)地址線

8255共占用4個口地址,為A、B、C口及控制口地址。這4個地址之間的選擇由A0、A1兩端口線控制。A0、A1通常接于單片機的地址線最低兩位P0.O、P0.1,二者組合決定了4個端口地址,口地址選擇方式如下:

A1A0=00,選擇A口;

A1A0=01,選擇B口;

A1A0=10,選擇C口;

A1A0=11,選擇控制口。

除這兩位外,其他位狀態(tài)還與硬件接線有關(guān),各口具體地址,結(jié)合實際電路才能確定。

2.方式選擇及方式控制字

(1)8255工作方式

8255有3種工作方式:方式0、方式1,方式2。方式0時,A、B、C三口都可作根本的輸入或輸出口;方式1時,A、B口可作選通輸入或輸出,C口局部作專用聯(lián)絡(luò)線;方式2時,A口為雙向口,C口局部為專用聯(lián)絡(luò)線,B口無此方式。8255的C口專用功能如表6-3所列。

(2)方式選擇

8255的方式選擇由方式控制字決定。方式控制字是8255內(nèi)部方式控制存放器的狀態(tài)字,它由指令寫入

控制存放器中A、B、C口控制位為"1〞,對應(yīng)口為輸入方式,假設(shè)為"0〞則為輸出方式。例如,控制字狀態(tài)為10010101B,表示A組為方式0(D6D5=00),A口為輸入方式(D4=1),C口上半部為輸出方式(D3=0);B組方式1(D2=1)中,B口為輸出(D1=0),C口下半部為輸入方式(D0=1)。D7=0只能對C口位操作,位操作內(nèi)容由控制存放器相應(yīng)位狀態(tài)決定。

例如,假設(shè)控制字為01H,即控制存放器格式為00000001B,表示C口位操作(D7=0),將PC0位置"1〞(D3D2D1=000,DO=l置"1〞),同理假設(shè)控制字為0EH則把C口最高位PC7

置"0〞即復(fù)位。8255擴展電路及地址設(shè)置

如圖6-9所示是8051單片機擴展一片8255的電路圖。圖中,74LS373是地址鎖存器。8255的地址線AI、A0經(jīng)74LS373接于P0.1、P0.0;片選端CS經(jīng)74LS373與P0.7接通,其他地址線懸空;8255的控制線RD、WR直接接于8051的RD和WR端;數(shù)據(jù)線DB接于P0口。

1.8255地址口確定

圖6-9中8255只有3根線接于地址線。片選CS、地址選擇端A1、A0。分別接于P0.7,P0.1、P0.0其他地址線全懸空。顯然只要保證P0.7為低電平時,選中該8255,假設(shè)P0.1、P0.0再為"00〞選中8255的A口,同理P0.1、P0.0為"01〞、"10〞、"11〞分別選中B口、C口及控制口。假設(shè)地址口用16位表示,其他無用端全設(shè)為"1〞,則8255的A、B、C及控制口地址分別可為FF7CH、FF7DH、FF7EH、FF7FH,無用位為"0〞則4個地址為0000H、0001H、0002H、0003H,只要保證CS、A1、A0的狀態(tài),無用位設(shè)為"0〞或"1〞無關(guān)。掌握了確定地址的方法,使用者可靈活選擇地址。

2.8255初始化

使用8255芯片時,首先要對它初始化。所謂初始化,也就是對8255的3個端口的工作方式預(yù)先設(shè)置。設(shè)置控制字經(jīng)控制口寫入。

例如圖6-9電路,欲設(shè)置8255的A、B、C口全為輸出狀態(tài),控制字為80H。程序:

MOV

DPTR,#0003H

;8255控制口地址→DPTR

MOV

A,#80H

;控制字送A

MOV*

DPTR,A

;控制字寫入控制存放器

利用這幾條指令對8255初始化后,A、B、C3個口才能作為輸出口使用。當(dāng)然改變控制字,則可改變3個端口的工作方式。8155可編程I/O接口擴展設(shè)計8155可編程接口芯片與8255的使用方法類似,只是二者在構(gòu)造與功能上有所不同。

1.8155構(gòu)造及引腳

8155內(nèi)部也有3個I/O接口A、B、C口,與8255的主要區(qū)別是C口只有6位,I/O接口共22位,比8255多一個14位可編程定時/計數(shù)器,還多256B的靜態(tài)RAM。8155共40引腳,雙列直插式封裝,如圖6-10所示。

(1)I/O接口線

PA0~PA7,PB0~PB7,PC0~PC5分別為A、B、C3個I/O接口引線端。

A、B、C口多用于與外設(shè)之間的數(shù)據(jù)傳送;C口還可以作為A、B口的控制線。

(2)地址數(shù)據(jù)線

8155的低8位地址線和數(shù)據(jù)線共用AD0~AD7,故稱為地址數(shù)據(jù)線。當(dāng)ALE=1時,輸入的是地址信息,否則是數(shù)據(jù)信息。當(dāng)與8051單片機連接時,ALE下降沿到,將P0接口輸出的低8位地址信息及CE、IO/M狀態(tài)都鎖存到8155內(nèi)部存放器。因此8155的AD0~AD7直接與P0接口相聯(lián),低8位地址不需要外接鎖存器,這點與8255不同。

(3)控制線

ALE:地址鎖存線。ALE=1表示給8155輸入的是地址信息,當(dāng)ALE下降沿時,把地址鎖存到8155中。

IO/M:RAM與I/O接口的選擇線。IO/M=0選中8155內(nèi)部RAM區(qū),IO/M=1選擇3個I/O接口、定時/計數(shù)器和命令存放器。

CE:片選線,RD:讀控制線,WR:寫控制線。

TIMERIN:定時/計數(shù)器外部脈沖輸入端。

TIMEROUT:定時/計數(shù)器輸出端。

2.8155功能及操作

8155具有3種功能,下面介紹具體操作。

(1)作I/O接口使用

IO/M=1時8155作I/O接口使用。各口的工作方式通過內(nèi)部控制存放器設(shè)置。

8155工作于I/O口時,各方式具體功能如表6-4所列。

表6-4

8155I/O接口工作方式及功能

PC2PC1

方式

0

0

方式1

A、B口定義為根本輸入/輸出口;C口為輸入口

1

1

方式2

A、B口定義為根本輸入/輸出口;C口為輸入口

0

1

方式3

A口為選通輸出,B口根本輸入/輸出

PC3~PC5輸出,PC0~PC2作A口選通控制

PC0;AINTR,PC1,ABF,PC2,ASTB

1

0

方式4

A口、B口都作為選通輸入/輸出方式

PC0~PC2控制A口,同方式3

PC3~PC5控制B口,PC3;BINTR,PC4:BBF

PC5:BSTB

2〕狀態(tài)存放器格式

8155有一個狀態(tài)存放器,它鎖存I/O接口和定時器當(dāng)前狀態(tài)供單片機查詢。

狀態(tài)存放器和控制存放器共用一個地址,所不同的是狀態(tài)存放器只能讀出不能寫入而控制存放器只能寫入不能讀出。

標(biāo)志存放器皆為高電平有效。

(2)作擴展RAM

8155作為單片機擴展RAM256B,操作很簡單,只要使IO/M控制端為低電平即可。通常IO/M端、CE端與P2接口兩位相連,二者皆為低電平?jīng)Q定了RAM的高8位地址,P0接口與AD0~AD7相接決定RAM的低8位地址。注意與其他數(shù)據(jù)存儲器統(tǒng)一編址。

(3)作定時器使用

當(dāng)IO/M=1時,8155也可作定時器使用。8155內(nèi)的可編程定時/計數(shù)器實際是一個14位的減法計數(shù)器。它共有兩個8位存放器組成,低8位和高6位存放計數(shù)初值,最高2位控制定時器的工作方式。

M2M1決定的定時方式及波形,8155的定時計數(shù)器為計數(shù)方式時。由引腳TIMERIN(3)從外部輸入計數(shù)脈沖;為定時方式時,則接單片機系統(tǒng)時鐘。無論定時或計數(shù)方式都從TIMEROUT端輸出脈沖或方波。

注意:如果寫入定時器的計數(shù)初值為奇數(shù),方波輸出將不對稱。例如計數(shù)初值為9,單方波方式輸出方波在5個脈沖周期為高電平,4個脈沖周期內(nèi)為低電平。

8155任何時候都可以置定時初值和工作方式,只要重新啟動即可。計數(shù)初值為2~3FFFH之間,終值為2。

8155計數(shù)方式一般作信號發(fā)生器使用,輸入連續(xù)脈沖后,由編程控制輸出不同波形。

3.8155的I/O接口及RAM地址分配

8155和其他芯片一樣統(tǒng)一按16位地址。它的地址范圍分兩種情況。

當(dāng)RAM方式,IO/M=0、CE=0(二者接P2口),其RAM中數(shù)據(jù)地址范圍可為0000H-00FFH(無關(guān)位取為0)。RAM應(yīng)與系統(tǒng)中其他數(shù)據(jù)存儲器統(tǒng)一編址。

表6-5I/O接口及定時器地址編碼

AD2AD1AD0

選中I/O接口或定時存放器

低8位地址編碼

0

0

0

控制〔命令〕/狀態(tài)存放器

00H

0

0

1

PA口

01H

0

1

0

PB口

02H

0

1

1

PC口

03H

1

0

0

定時器低8位

04H

1

0

1

定時器高8位

05H

當(dāng)IO/M=1、CE=0時工作在I/O接口或定時器方式,這種情況8155共需要占6個地址,6個地址由地址低8位中最低3位AD2、ADl、ADO編碼決定,編碼格式如表6-5所列。

4.8051單片機與8155接口電路舉例

如圖6-11所示是8051單片機與8155芯片接口電路之一。結(jié)合硬件電路著重說明8155地址口確實定及初始化程序。

(1)8051與8155連接特點及地址分配

MCS-51系列單片機可以直接和8155連接,低8位地址可不加鎖存器。ADO~AD7直接接于P0口,8155的ALE直接與8051ALE相接,這點優(yōu)于8255。

圖中8155的IO/M接8051的P2.0端,CE接P2.1端。

IO/M=0,CE=0工作在RAM方式,其地址范圍為0000H~00FFH(無用位設(shè)為0)。

IO/M=1,CE=08155工作在I/O接口或定時方式,其地址確定方法:高位保證P2.1=0,P2.0=1其他無用位設(shè)為0,這樣高位地址為01H,再考慮低位AD2、AD1、AD0三位編碼可確定8155的以下6個地址:

控制/狀態(tài)字地址

0100H

A口地址

0101H

B口地址

0102H

C口地址

0103H

定時器低8位地址

0104H

定時器高8位地址

0105H

(2)8155初始化

用指令把8155設(shè)置成各種工作方式:

1〕設(shè)置I/O口工作方式

例1

設(shè)A口為根本輸出,B口為根本輸入,C口輸出。

分析:根據(jù)題目要求,控制存放器狀態(tài)為00001101B〔0DH〕,編程把控制字送入即可。程序為:

MOV

DPTR,#0100H

;控制存放器→DPTR

MOV

A,#0DH

;控制字A

MOV*

DPTR,A

;控制字送控制存放器

無論控制字為何值,都必須通過上述方式,把控制字送入控制存放器,才能正確設(shè)置8155中I/O口工作方式。

2〕設(shè)置RAM方式。

例2

編程使CPU往8155RAM30H單元送立即數(shù)88H。

程序為:

MOV

DPTR,#0030H

;RAM數(shù)據(jù)單元地址→DPTR

MOV

A,#88H

;立即數(shù)送入A

MOV*

DPTR,A

;立即數(shù)送入0030H中

使用RAM時必在IO/M=0條件下。

3〕設(shè)置為定時方式。

例3設(shè)8155的定時/計數(shù)器為方波發(fā)生器,輸出方波頻率為輸入時鐘頻率的24分頻。初始化程序如下:

MOV

DPTR,#0104H

;定時器低8位地址→DFTR

MOV

A,#18H

;18H-24D分頻系數(shù)→A

MOV*

DPTR,A

;定時初值送入定時器低8位

INC

DPTR

;0105H是定時高8位地址

MOV

A,#40H

;定時器方式1

MOV*

DPTR,A

;A→定時器高位地址

MOV

DPTR,#0100H

;控制口地址→DPTR

MOV

A,#0C2H

;啟動計數(shù)器,B口輸出,A、C口輸入

MOV*

DPTR,A

與8155芯片類似芯片如8156,除選片端CE高電平有效外,其他功能及引腳與8155完全一樣。8755內(nèi)部有2KBEPROM和兩個I/O接口,詳細參數(shù)可查閱有關(guān)資料。串行口擴展I/O接口

單片機控制系統(tǒng)中,串行口常用來擴展I/O接口,使用移位存放器作為鎖存或輸入信號的接口,可以方便地擴展并行輸入、輸出口。這種方法不占用片外RAM地址,簡單易行,便于操作,適用于速度較慢、實時性要求不高的場合。

1.串行口擴展并行輸入口

74LS165芯片是8位并行輸入和串行移位輸出存放器。原則上利用n片74LS165與8051的3根端口線相連,可擴展8n根并行輸入口線。

圖6-12所示利用2片74LSl65與串行口配合,擴展16根并行輸入線的電路。由圖可見,8051僅用了3根線,分別為串行口輸入線R*D(P3.0)、串行口輸出線T*D(P3.1)和1根控制線P1.0引出。

74LSl65是一個8位存放器,其S/L端是串行移位控制端接于P1.0端;CK是移位時鐘輸入端,接于P3.1(T*D)端;QH是串行移位輸出端接于P3.0(R*D)端。串行口置為方式0。兩個165芯片是串聯(lián)方式,首尾相接,低位QH接于高位SER端,高位QH端接8051的R*D端。假設(shè)16位并行輸入數(shù)據(jù)已送到兩個74LSl65的輸入端,當(dāng)Pl.0=0時。16位數(shù)據(jù)被同時接收,置入對應(yīng)的74LSl65的存放器中。當(dāng)P1.0=1時,移位存放器開場串

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論