《微機(jī)原理與接口技術(shù)》課程設(shè)計---交通急救控制系統(tǒng)_第1頁
已閱讀1頁,還剩18頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p>  《微機(jī)原理與接口技術(shù)》課程設(shè)計</p><p>  課題:交通急救控制系統(tǒng) </p><p><b>  目錄</b></p><p>  設(shè)計要求…………………………………………………………….1</p><p>  系統(tǒng)結(jié)構(gòu)總圖……………………………………………………….2</p>

2、<p>  芯片簡介…………………………………………………………….3</p><p>  系統(tǒng)電路圖與模塊設(shè)……………………………………………….7</p><p>  流程圖與程序清單………………………………………………….8</p><p>  心得體會…………………………………………………………….15</p><p> 

3、 參考文獻(xiàn)…………………………………………………………….16</p><p><b>  一.設(shè)計要求</b></p><p>  本次我們需要利用微機(jī)原理試驗(yàn)箱設(shè)計一個交通急救燈系統(tǒng),在老師的要求下,我們的設(shè)計由五大模塊組成,分別為定時模塊、中斷模塊、主控CPU模塊、顯示模塊和小鍵盤模塊,所需用到的芯片有8253、8259、8088、8255和8279,利用這些我

4、們設(shè)計一個可控制時間的交通燈系統(tǒng),并可實(shí)現(xiàn)以下要求:</p><p> ?。?)允許按十字路口交通需求設(shè)置控制狀態(tài);</p><p> ?。?)允許修改各狀態(tài)下的通行時間;</p><p> ?。?)有剩余時間顯示;</p><p> ?。?)當(dāng)有事故發(fā)生時,東南西北方向全為紅燈,暫時不能通行;</p><p><

5、;b>  1</b></p><p><b>  二.系統(tǒng)結(jié)構(gòu)總圖</b></p><p>  2 </p><p><b>  三.芯片簡介</b></p><p>  根據(jù)上面的系統(tǒng)結(jié)構(gòu)總圖,此次設(shè)計需要用到的芯片有四種,分別是8253、8259、8088與

6、8279,下面我們分別來介紹一下這幾種芯片。</p><p><b>  1)8253芯片</b></p><p>  8253的功能用途是:</p><p>  (1)延時中斷 (2)可編程頻率發(fā)生器</p><p> ?。?)事件計數(shù)器 (4)二進(jìn)倍頻器<

7、/p><p> ?。?)實(shí)時時鐘 (6)數(shù)字單穩(wěn)</p><p>  (7)復(fù)雜的電機(jī)控制器</p><p>  8253有六種工作方式:</p><p> ?。?)方式0:計數(shù)結(jié)束中斷 (2)方式1:可編程頻率發(fā)生器</p><p> ?。?)方式2:頻率發(fā)生器

8、 (4)方式3:方波頻率發(fā)生器</p><p>  (5)方式4:軟件觸發(fā)的選通信號 (6)方式5:硬件觸發(fā)的選通信號</p><p>  8253引腳圖如圖所示,各引腳功能如下:</p><p>  D7~D0——八條雙向數(shù)據(jù)線;</p><p>  WR(低電平有效)——寫輸入信號;</p><p

9、>  RD(低電平有效)——讀輸入信號;</p><p>  CS(低電平有效)——片選輸入信號;</p><p>  A0、A1——片內(nèi)寄存器地址輸入信號;</p><p>  CLK——計數(shù)輸入,用于輸入定時基準(zhǔn)脈沖或計數(shù)脈沖;</p><p>  OUT——輸出信號,以相應(yīng)的電平指示計數(shù)的完成,或輸出脈沖波形;</p>

10、<p>  GATE——選通輸入,用于啟動或禁止計數(shù)器的操作,以使計數(shù)器和計測對象同步。</p><p><b>  3</b></p><p><b>  2)8259芯片</b></p><p>  8259引腳圖如圖所示,各引腳功能如下:</p><p>  D7~D0——八條雙

11、向數(shù)據(jù)線;</p><p>  WR(低電平有效)——寫輸入信號;</p><p>  RD(低電平有效)——讀輸入信號;</p><p>  CS(低電平有效)——片選輸入信號;</p><p><b>  A0——地址信號;</b></p><p>  INT——中斷請求信號;</p&g

12、t;<p>  INTA(低電平有效)——中斷響應(yīng)信號;</p><p>  CAS0~CAS2——級聯(lián)信號,形成一條專用8259A總線,以便多片8259A的級聯(lián);</p><p>  SP/EN——從編程/允許級聯(lián)。在緩沖方式中,可用做輸出信號以控制總線緩沖器的接收和發(fā)送。在非緩沖方式中,作為輸入信號用于表示主片還是從片;</p><p>  IR0

13、~IR7——外部中斷請求輸入線。要求輸入的中斷請求信號是由低電平到高電平的上升沿(并保持高電平到CPU響應(yīng)時為止)或者是高電平。</p><p><b>  4</b></p><p><b>  3)8088芯片</b></p><p>  8088引腳圖如圖所示,各引腳功能如下:</p><p>

14、; ?。?)AD7~AD0:地址/數(shù)據(jù)線復(fù)用,雙向三態(tài)。在每個總線周期T1狀態(tài)用作地址總線,輸出訪問存儲器或I/O口地址低8位A7~A0,T2~T4狀態(tài)傳送數(shù)據(jù)D7~D0?! 。?)A8~A15:地址線,輸出三態(tài)。在整個總線周期內(nèi)始終輸出地址信號。</p><p>  (3)A19/S6~A16/S3:地址/狀態(tài)線復(fù)用。在每個總線周期T1狀態(tài)用作地址總線高4位。在總線周期T2~T4期間,輸出狀態(tài)信息。</

15、p><p>  (4)ALE:地址鎖存允許信號,輸出高電平有效。</p><p>  (5)NMI:非屏蔽中斷請求,輸入上升沿有效。相應(yīng)的中斷類型碼為02H。   (6) INTR響應(yīng)信號,輸出三態(tài),低電平有效。當(dāng)CPU響應(yīng)中斷時,它變?yōu)橛行У碗娖?,通知中斷源送出中斷向量碼。</p><p>  (7) CLK:時鐘信號輸入。8088 CPU內(nèi)部沒有時鐘信號產(chǎn)生電路

16、,需外部提供。</p><p>  (8)RESET:復(fù)位信號,輸入高電平有效。</p><p>  (9)READY:準(zhǔn)備好信號,輸入高電平有效。READY用來使CPU和慢速存儲器或I/O設(shè)備之間速度實(shí)現(xiàn)匹配,完成數(shù)據(jù)傳送?!?</p><p>  (10) DEN:數(shù)據(jù)允許信號,輸出三態(tài),低電平有效?!?(11)DT/R:數(shù)據(jù)發(fā)送/接收控制,輸出三態(tài), D

17、T/R=1時,CPU發(fā)送數(shù)據(jù),DT/R=0時,CPU接收數(shù)據(jù)。在DMA方式時,它處于浮空狀態(tài)?! ?lt;/p><p>  (12)IO/M:外設(shè)/內(nèi)存訪問控制,輸出三態(tài)。輸出高電平時,表示總線周期為I/O訪問周期;輸出低電平時,表示總線周期為存儲器訪問周期。</p><p>  (13) WR:寫信號,低電平有效。在DMA方式時,它處于浮空狀態(tài)?!?(14) RD:讀信號,低電平有效。在

18、DMA方式時,它處于浮空狀態(tài)。  (15)HOLD:總線保持請求信號,輸入,高電平有效。當(dāng)DMA操作或外部處理器要求通過總線傳送數(shù)據(jù)時,HOLD信號為高電平。</p><p> ?。?6)HLDA:總線保持響應(yīng)信號,輸出,高電平有效。</p><p><b>  5</b></p><p><b>  4)8279芯片</b&

19、gt;</p><p>  8279引腳圖如圖所示,各引腳功能如下:</p><p>  DB0~DB7:雙向數(shù)據(jù)總線,用來傳送8279與CPU之間的數(shù)據(jù)和命令。 </p><p>  CLK:時鐘輸入線,用以產(chǎn)生內(nèi)部定時的時鐘脈沖。 </p><p>  RESET:復(fù)位輸入線,8279復(fù)位后被置為字符顯示左端輸入,二鍵閉鎖的觸點(diǎn)回彈型式,

20、程序時鐘前置分頻器被置為31,RESET信號為高電平有效。 </p><p>  CS:片選輸入線,低電平有效,單片機(jī)在CS端為低時可以對8279讀/寫操作。 </p><p>  A0:緩沖器低位地址,當(dāng)A0為高電平時,表示數(shù)據(jù)總線上為命令或狀態(tài), 當(dāng)為低電平時,表示數(shù)據(jù)總線上為命令或狀態(tài),當(dāng)為低電平時,表示數(shù)據(jù)總線上為數(shù)據(jù)。 </p><p>  RD

21、:讀信號輸入線,低電平有效,將緩沖器讀出,數(shù)據(jù)送往外部總線。 </p><p>  WR:寫信號輸入線,低電平有效,將緩立器讀出,將數(shù)據(jù)從外部數(shù)據(jù)總線寫入8279的緩沖器。 </p><p><b>  6</b></p><p>  四.系統(tǒng)電路圖與各模塊設(shè)計</p><p>  1.系統(tǒng)電路圖如上一頁所示;</

22、p><p><b>  2.各模塊設(shè)計</b></p><p><b>  1)定時模塊</b></p><p>  定時模塊是為8259提供中斷請求信號的。由一片8253實(shí)現(xiàn),選用定時器0#,工作在方式3,由于時鐘應(yīng)該1秒走動一次,所以輸出值應(yīng)為1S,其輸出信號可作為8259的中斷請求信號。</p><p

23、><b>  2)中斷模塊</b></p><p>  中斷模塊實(shí)現(xiàn)動態(tài)顯示的,硬件為一片8259,由于中斷請求信號為每秒一次,中斷程序該為時間按秒增加,并顯示,只要開中斷,便可實(shí)現(xiàn)每秒顯示時間增加一秒,從而達(dá)到動態(tài)顯示的效果。</p><p><b>  3)主控CPU模塊</b></p><p>  8088最小

24、工作模式,作為整個電子表的核心控制部分。</p><p>  在8088最小模式中,硬件連接上有如下特點(diǎn):</p><p>  MN/MX 端接+5V,決定了8088工作在最小模式。</p><p>  有1片8284A,作為時鐘發(fā)生器。</p><p>  有3片8282,用來作為地址鎖存器。8282是典型的鎖存器芯片,因?yàn)樗?位的,所以

25、需要3片8282作為鎖存器。</p><p>  當(dāng)系統(tǒng)中所連的存儲器和外設(shè)系統(tǒng)較多時,需要增加數(shù)據(jù)總線的驅(qū)動能力,這時,要用兩片8286作為總線收發(fā)器。</p><p><b>  4)顯示模塊</b></p><p>  顯示模塊是由一塊8255A芯片與LED紅綠黃顯示燈組成,由8255A來接收信號,從而控制紅綠黃燈亮滅的時間,實(shí)現(xiàn)交通燈得

26、控制。</p><p><b>  5)小鍵盤模塊</b></p><p>  小鍵盤模塊送入主控模塊的子功能模塊。由軟件和硬件實(shí)現(xiàn),硬件上由小鍵盤和8279互連,將小鍵值由8279送入主控模塊。軟件上使用行掃描法獲得鍵值并送回主控模塊。</p><p><b>  7</b></p><p>  

27、五.流程圖與程序清單</p><p><b>  1.流程圖</b></p><p><b>  8</b></p><p><b>  9</b></p><p><b>  2.程序清單:</b></p><p>  D8279

28、 equ 200H</p><p>  C8279 equ 202H</p><p>  C8253 equ 20bH</p><p>  D82530 equ 208H</p><p>  D82531 equ 209H</p><p>  C82590 equ 210H</p><p>

29、;  C82591 equ 211H</p><p>  data segment</p><p>  HOUR db 00</p><p>  MINUTE db 00</p><p>  STAT db 00</p><p>  LED db 3fH,06H,5bH,4fH,66H,6dH,7

30、dH,27H,7fH,6fH,00H,00H</p><p>  DISBUF db 8 dup(0)</p><p><b>  data ends</b></p><p>  stack segment stack</p><p>  dw 100 dup(?)</p><p>  stac

31、k ends</p><p>  code segment</p><p>  assume cs:code,ds:data</p><p>  start:MOV AX,DATA</p><p>  MOV DS,AX</p><p>  ;=========INIT 8253==========</p

32、><p>  MOV DX,C8253</p><p>  MOV AL,36H</p><p>  OUT DX,AL</p><p>  MOV DX,D82530</p><p>  MOV AX,10000</p><p>  OUT DX,AL</p>

33、<p>  MOV AL,AH</p><p>  OUT DX,AL</p><p>  MOV DX,C8253</p><p>  MOV AL,36H</p><p>  OUT DX,AL</p><p>  MOV DX,D82531</p><p&g

34、t;  MOV AX,100</p><p>  OUT DX,AL</p><p>  MOV AL,AH</p><p>  OUT DX,AL</p><p>  ;=========INIT 8259=============</p><p><b>  CLI</b>&l

35、t;/p><p>  MOV AL,13H</p><p>  MOV DX,C82590</p><p><b>  10 </b></p><p>  OUT DX,AL</p><p>  MOV AL,8</p><p>  MOV DX,C82

36、591</p><p>  OUT DX,AL</p><p>  MOV AL,1</p><p>  OUT DX,AL</p><p>  MOV AX,0</p><p>  MOV ES,AX</p><p>  LEA AX,INT0</p>&

37、lt;p>  MOV ES:[4*8],AX</p><p>  MOV AX,CS</p><p>  MOV ES:[4*8+2],AX</p><p>  MY8255_A EQU 1400H ;8255連接端口IOY0</p><p>  MY8255_B EQU 1401H</p>

38、<p>  MY8255_C EQU 1402H</p><p>  MY8255_MODE EQU 1403H</p><p>  MY8254_COUNT0 EQU 1440H ;8254連接端口IOY2</p><p>  MY8254_MODE EQU 1443H </p><p>  DATA SEGMENT

39、</p><p>  LEDDB 3FH,06H,5BH,4FH,66H,6DH,7DH,07H,7FH,6FH ;數(shù)碼管七段代碼表</p><p><b>  DATA ENDS</b></p><p>  CODE SEGMENT</p><p>  ASSUME CS:CODE,DS:DATA</p&g

40、t;<p>  START:MOV AX,DATA</p><p><b>  MOV DS,AX</b></p><p>  MOV DX,MY8255_MODE;8255初始化,連接端口IOY0</p><p>  MOV AL,10000001B ;A口輸出接LED,B口輸出接數(shù)碼管,C0~C3輸入,C4~C7輸出<

41、/p><p><b>  OUT DX,AL</b></p><p><b>  MOV CX,25</b></p><p>  A1: MOV DX,MY8255_A ;8255的A口接LED()</p><p>  MOV AL,01111011B ;東西紅,南北綠</p>

42、<p>  OUT DX,AL ;將燈狀態(tài)傳送給LED顯示</p><p>  CALL INITIAL_8254</p><p>  LOOP2:MOV AH,0BH ;判斷有無鍵按下 </p><p><b>  INT 21H</b></p><p>  C

43、MP AL,0 </p><p><b>  11 </b></p><p>  JNZ EXIT0 ;有鍵入則返回DOS </p><p><b>  JMP Y1</b></p><p>  EXIT0:MOV AH,4CH</p><

44、;p>  INT 21H </p><p>  Y1: MOV DX,MY8255_C</p><p><b>  IN AL,DX</b></p><p>  TEST AL,00001110B ;檢測是否有緊急鍵按下</p><p>  JZ L1 </p>

45、;<p>  CALL EMERGECY ;有緊急鍵則轉(zhuǎn)到緊急鍵處理</p><p><b>  JMP L2</b></p><p>  L1: CALL DISP</p><p>  L2: MOV DX,MY8255_C ;檢測1s是否計完</p><p><b>

46、;  IN AL,DX</b></p><p>  TEST AL,01H</p><p>  JE LOOP2 </p><p><b>  DEC CX</b></p><p><b>  CMP CX,5</b></p><p><b>

47、;  JA A1</b></p><p><b>  JMP A2</b></p><p>  A2: MOV DX,MY8255_A ;東西紅,南北黃 </p><p>  MOV AL,01111100B</p><p><b>  OUT DX,AL</b></

48、p><p>  CALL INITIAL_8254</p><p>  LOOP4:MOV AH,0BH ;判斷有無鍵按下 </p><p><b>  INT 21H</b></p><p>  CMP AL,0 </p><p>  JNZ

49、EXIT1 ;有鍵入則返回DOS </p><p><b>  JMP Y2</b></p><p>  EXIT1:MOV AH,4CH</p><p>  INT 21H </p><p>  Y2: MOV DX,MY8255_C</p><p>&l

50、t;b>  IN AL,DX</b></p><p>  TEST AL,00001110B ;檢測是否有緊急鍵按下</p><p>  JZ L3 </p><p>  CALL EMERGECY ;有緊急鍵則轉(zhuǎn)到緊急鍵處理</p><p><b>  JMP L4</b>

51、</p><p>  L3: CALL DISP</p><p>  L4: MOV DX,MY8255_C ;檢測1s是否計完</p><p><b>  IN AL,DX</b></p><p>  TEST AL,01H</p><p>  JE LOOP4

52、 ;若1s沒計數(shù)完,繼續(xù) </p><p><b>  12 </b></p><p><b>  DEC CX</b></p><p><b>  CMP CX,0</b></p><p><b>  JE P</b></p>&l

53、t;p>  JMP A2 ;20s或5s計數(shù)完全?若沒計數(shù)完,繼續(xù)</p><p>  P: MOV CX,25</p><p><b>  JMP A3</b></p><p>  A3: MOV DX,MY8255_A ;東西綠,南北紅 </p><p>  MOV AL,10110111B&l

54、t;/p><p>  OUT DX,AL </p><p>  CALL INITIAL_8254</p><p>  LOOP5:MOV AH,0BH ;判斷有無鍵按下 </p><p><b>  INT 21H</b></p><p>  CMP AL,

55、0 </p><p>  JNZ EXIT2 ;有鍵入則返回DOS </p><p><b>  JMP Y3</b></p><p>  EXIT2:MOV AH,4CH</p><p>  INT 21H </p><p>  Y

56、3: MOV DX,MY8255_C</p><p><b>  IN AL,DX</b></p><p>  TEST AL,00001110B ;檢測是否有緊急鍵按下</p><p>  JZ L6 </p><p>  CALL EMERGECY ;有緊急鍵則轉(zhuǎn)到緊急鍵處理<

57、/p><p><b>  JMP L7</b></p><p>  L6: CALL DISP</p><p>  L7: MOV DX,MY8255_C ;檢測1s是否計完</p><p><b>  IN AL,DX</b></p><p>  TEST AL,01

58、H</p><p>  JE LOOP5 </p><p><b>  DEC CX</b></p><p><b>  CMP CX,5</b></p><p><b>  JA A3</b></p><p><b>  JMP

59、 A4</b></p><p>  A4:MOV DX,MY8255_A ;東西黃,南北紅 </p><p>  MOV AL,11000111B</p><p><b>  OUT DX,AL</b></p><p>  CALL INITIAL_8254</p><p>

60、  LOOP6:MOV AH,0BH ;判斷有無鍵按下 </p><p><b>  INT 21H</b></p><p>  CMP AL,0 </p><p>  JNZ EXIT3 ;有鍵入則返回DOS </p><p><b>  J

61、MP Y4</b></p><p><b>  13</b></p><p>  EXIT3:MOV AH,4CH</p><p><b>  INT 21H </b></p><p>  Y4: MOV DX,MY8255_C</p><p><b>

62、;  IN AL,DX</b></p><p>  TEST AL,00001110B ;檢測是否有緊急鍵按下</p><p>  JZ L8 </p><p>  CALL EMERGECY ;有緊急鍵則轉(zhuǎn)到緊急鍵處理</p><p><b>  JMP L9</b></p

63、><p>  L8: CALL DISP</p><p>  L9: MOV DX,MY8255_C ;檢測1s是否計完</p><p><b>  IN AL,DX</b></p><p>  TEST AL,01H</p><p>  JE LOOP6

64、 ;若1s沒計數(shù)完,繼續(xù) </p><p><b>  DEC CX</b></p><p><b>  CMP CX,0</b></p><p><b>  JE PP</b></p><p>  JMP A4 ;20s或5s計數(shù)完全?若沒計數(shù)完,繼續(xù)</p&g

65、t;<p><b>  PP:</b></p><p>  MOV AH,0BH ;判斷有無鍵按下 </p><p><b>  INT 21H</b></p><p>  CMP AL,0 </p><p>  JNZ EXIT

66、 ;有鍵入則返回DOS</p><p><b>  JMP START</b></p><p>  EXIT:MOV AH,4CH</p><p>  INT 21H </p><p>  ;**------------------------------------ **</p>

67、<p>  INITIAL_8254 PROC ;8254初始化,1s</p><p><b>  PUSH AX</b></p><p><b>  PUSH DX</b></p><p>  MOV DX,MY8254_MODE ;初始化,計數(shù)器0工作在方式0,先寫低8位,

68、再寫高8位,BCD方式計數(shù)</p><p>  MOV AL,00110001B</p><p><b>  OUT DX,AL</b></p><p>  MOV DX,MY8254_COUNT0 </p><p>  MOV AL,00H ;寫低8位</p><p

69、><b>  OUT DX,AL</b></p><p>  MOV AL,10H ;寫高8位</p><p><b>  OUT DX,AL</b></p><p><b>  POP DX</b></p><p><b>  P

70、OP AX</b></p><p><b>  RET</b></p><p>  INITIAL_8254 ENDP </p><p><b>  14</b></p><p><b>  六.心得體會</b></p><p>

71、;  由于第一次做微機(jī)原理課程設(shè)計,想一次性把程序完成是非常難的,在調(diào)試中就出現(xiàn)了不少的錯誤。剛開始的時候把程序?qū)戇M(jìn)去然后運(yùn)行卻發(fā)現(xiàn)有些燈亮不起來而且在完成了一個周期后就循環(huán)不起來了。那時真的不知道從哪里入手,只好一條一條地檢查才發(fā)現(xiàn)了一條指令把常閉寫成了輸出真正的輸出口就沒有收到信號了。雖然找錯誤是一個十分枯燥無味的工作,但只要你耐心的去做的話,你肯定能學(xué)到很多有用的東西。</p><p>  通過這次設(shè)計,使

72、我得到了一次用專業(yè)知識、專業(yè)技能分析和解決問題全面系統(tǒng)的鍛煉。使我在學(xué)習(xí)微機(jī)的過程,以及在常用編程設(shè)計思路技巧(特別是匯編語言)的掌握方面都能向前邁了一大步,為日后成為合格的應(yīng)用型人才打下良好的基礎(chǔ)。</p><p>  15 </p><p><b>  七.參考文獻(xiàn)</

溫馨提示

  • 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論