版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 課程設(shè)計(jì)報(bào)告</b></p><p> ( 2012-- 2013年度第 1 學(xué)期)</p><p> 名 稱:微型計(jì)算機(jī)原理及應(yīng)用</p><p> 題 目:用8255A實(shí)現(xiàn)四位十進(jìn)制數(shù)簡單計(jì)算器</p><p> 院 系:控制與計(jì)算機(jī)工程學(xué)院</p>
2、<p> 班 級:自動化1003班</p><p> 日期:2013 年 1 月 5 日</p><p> 課程設(shè)計(jì)的目的與要求</p><p> 課程設(shè)計(jì)是培養(yǎng)和鍛煉學(xué)生在學(xué)習(xí)完本門課后綜合應(yīng)用所學(xué)理論知識,解決實(shí)際工程設(shè)計(jì)和應(yīng)用問題的能力的重要教學(xué)環(huán)節(jié)。它具有動手、動腦和理論聯(lián)系實(shí)際的特點(diǎn),是培養(yǎng)在校工科大學(xué)生理論聯(lián)系實(shí)際、敢于動手、
3、善于動手和獨(dú)立自主解決設(shè)計(jì)實(shí)踐中遇到的各種問題能力的一個(gè)重要教學(xué)環(huán)節(jié)。</p><p> 通過課程設(shè)計(jì),要求學(xué)生熟悉和掌握微機(jī)系統(tǒng)的軟件、硬件設(shè)計(jì)的方法、設(shè)計(jì)步驟,使學(xué)生得到微機(jī)開發(fā)應(yīng)用方面的初步訓(xùn)練。讓學(xué)生獨(dú)立或集體討論設(shè)計(jì)題目的總體設(shè)計(jì)方案、編程、軟件硬件調(diào)試、編寫設(shè)計(jì)報(bào)告等問題,真正做到理論聯(lián)系實(shí)際,提高動手能力和分析問題、解決問題的能力,實(shí)現(xiàn)由學(xué)習(xí)知識到應(yīng)用知識的初步過渡。通過本次課程設(shè)計(jì)使學(xué)生熟練掌握
4、微機(jī)系統(tǒng)與接口擴(kuò)展電路的設(shè)計(jì)方法,熟練應(yīng)用8086匯編語言編寫應(yīng)用程序和實(shí)際設(shè)計(jì)中的硬軟件調(diào)試方法和步驟,熟悉微機(jī)系統(tǒng)的硬軟件開發(fā)工具的使用方法。</p><p> 我組根據(jù)微機(jī)原理課程所學(xué)相關(guān)知識及實(shí)驗(yàn)教程相關(guān)內(nèi)容,在基于proteus平臺,使用匯編語言,以8086為核心的情況下,配合可編程并行接口器件8255A,LED數(shù)碼管等器件實(shí)現(xiàn)可進(jìn)行簡單四位數(shù)加減乘除法功能的十進(jìn)制計(jì)算器。在課程設(shè)計(jì)實(shí)踐中,我們不僅鍛
5、煉了實(shí)際動手能力,培養(yǎng)了團(tuán)隊(duì)精神和嚴(yán)肅認(rèn)真的工作態(tài)度,更增強(qiáng)了自己在實(shí)際的工程設(shè)計(jì)中查閱資料,撰寫設(shè)計(jì)報(bào)告表達(dá)設(shè)計(jì)思想和結(jié)果的能力。</p><p> 課程設(shè)計(jì)進(jìn)度及任務(wù)分工</p><p> 課設(shè)進(jìn)度:1.選擇課程設(shè)計(jì)題目,查閱相關(guān)資料。(全體組員)</p><p> 2.需求分析及總體設(shè)計(jì)。(全體組員)</p><p> 3.軟硬
6、件設(shè)計(jì)。(范昌負(fù)責(zé)主程序的框架與整體調(diào)試、LED數(shù)碼顯示部分及硬件構(gòu)架,賈旭負(fù)責(zé)鍵盤管理部分,郭歡、劉玉婷負(fù)責(zé)算法及相關(guān)程序)</p><p> 4.仿真調(diào)試。(范昌、賈旭)</p><p> 5.總結(jié)及撰寫設(shè)計(jì)報(bào)告。(郭歡、劉玉婷)</p><p> 6.個(gè)人總結(jié)(全體組員)</p><p><b> 三、設(shè)計(jì)正文<
7、/b></p><p><b> 需求分析</b></p><p> 操控核心微處理器8086芯片</p><p> 可編程并行接口芯片8255A</p><p> 可編程定時(shí)/計(jì)數(shù)器8253A</p><p> 對輸入掃描的矩陣鍵盤</p><p> 顯
8、示模塊LED數(shù)碼管</p><p> 輔助器件如74LS138譯碼器、74LS373等</p><p><b> 總體設(shè)計(jì)</b></p><p> 確定鍵盤是否有輸入(使用程序不斷進(jìn)行掃描)</p><p> 若有輸入就調(diào)用子程序進(jìn)行判斷,是數(shù)值則進(jìn)行存儲并同時(shí)進(jìn)行顯示,是運(yùn)算符號等就調(diào)用相應(yīng)的子程序進(jìn)行操作&
9、lt;/p><p> 繼續(xù)掃描鍵盤是否有輸入,從而實(shí)現(xiàn)4位十進(jìn)制數(shù)以內(nèi)的加減乘除法或者擴(kuò)展功能運(yùn)算</p><p> 運(yùn)算完成后將運(yùn)算的結(jié)果儲存并顯示到LED顯示器上</p><p><b> 硬件設(shè)計(jì)</b></p><p><b> 見附錄。</b></p><p>
10、<b> 軟件設(shè)計(jì)</b></p><p><b> 見附錄。</b></p><p> 四、課程設(shè)計(jì)總結(jié)或結(jié)論</p><p><b> ?。?)個(gè)人總結(jié)</b></p><p> 本次課程設(shè)計(jì)我們做的課題是用8255A實(shí)現(xiàn)4位十進(jìn)制數(shù)簡易計(jì)算器,四人一組,我負(fù)責(zé)主程
11、序的框架與整體調(diào)試、LED數(shù)碼顯示部分及硬件構(gòu)架。對于主程序的框架,是整個(gè)計(jì)算器的核心,通過與其他組員的商量我們最終確定了我們的主要算法:通過一個(gè)4*4鍵盤,輸入數(shù)據(jù),實(shí)現(xiàn)加減乘除操作,將輸入的數(shù)據(jù)和運(yùn)算符分別存儲,接收到“=”時(shí)進(jìn)行運(yùn)算,并將結(jié)果輸出。</p><p> 看起來簡單的算法,由于涉及到十進(jìn)制和十六進(jìn)制的轉(zhuǎn)換,其中就需要很多中間的轉(zhuǎn)換程序。經(jīng)過反復(fù)修改與查閱資料,我們的程序最終能夠完成部分預(yù)期功能
12、。</p><p> 我還負(fù)責(zé)LED數(shù)碼管顯示部分的程序,四位七段數(shù)碼管的顯示,原理看起來簡單,但是實(shí)際操作時(shí)卻有各種各樣的毛病,按照原理寫好程序,往往不能達(dá)到預(yù)期效果,數(shù)碼管又是不顯示,有時(shí)會顯示亂碼,有時(shí)會閃爍,所有這些,都要一步一步調(diào)試,加入合適的延時(shí)程序是關(guān)鍵,延時(shí)過長、過短都不好。顯示亂碼是程序方面出了問題,經(jīng)過一次次調(diào)試,終于得到了穩(wěn)定的顯示,</p><p> 我對數(shù)碼管
13、的應(yīng)用也更熟練了。</p><p> 由于我之前有接觸過proteus仿真軟件,所以我負(fù)責(zé)硬件的搭建,熟悉使用proteus軟件對我們專業(yè)來說是一項(xiàng)基本技能,通過一次次摸索與百度,我對這個(gè)軟件的使用也越來越熟悉,學(xué)會了怎么連總線,怎么仿真,怎么快速連線,以及常用元件的搜索。其中最讓我滿足的是鍵盤的設(shè)計(jì),如果用16個(gè)按鈕排列當(dāng)然可以實(shí)現(xiàn)我們的要求,但是每次按按鈕有很不方便,所以我在網(wǎng)上查詢資料,學(xué)會了用prote
14、us自身的模型制作自己的元件,上圖左邊是普通矩陣鍵盤,右圖是我利用proteus自身模型制作的的鍵盤,感覺很滿意。整個(gè)硬件仿真的搭建,由于對軟件的不熟悉,本身設(shè)計(jì)的問題,花了我很長時(shí)間,而且重復(fù)連接了很多次,最后我們成功仿真出了我們的計(jì)算器。</p><p> 通過本次課程設(shè)計(jì),就我本身來說我學(xué)會了很多東西,無論是軟件上匯編語言程序的編寫與調(diào)試,還是硬件的搭建技巧與相關(guān)軟件的應(yīng)用的能力都得到了很大提高,同時(shí)也鍛
15、煉了我的自我學(xué)習(xí)能力與交流合作能力,相關(guān)軟件的學(xué)習(xí)使用,相關(guān)芯片與元件的使用與選擇能力都在一定程度上有了很大進(jìn)步。同時(shí),軟硬件的結(jié)合,也體現(xiàn)了我們自動化專業(yè)的特點(diǎn)。</p><p> 最后,有一點(diǎn)遺憾的就是做好了四位的簡易計(jì)算器,我們想進(jìn)一步擴(kuò)展做成八位的計(jì)算器,但是難度有所加大,不是想象中的那么簡單,數(shù)碼管顯示部分就花了很大精力去調(diào)試。最后由于時(shí)間關(guān)系沒有完成8位計(jì)算器的制作。</p><
16、p><b> ?。?)團(tuán)隊(duì)總結(jié)</b></p><p> 本次課程設(shè)計(jì),我們是四人一組,團(tuán)隊(duì)合作的要求就比較高。因?yàn)檫x題的關(guān)系,需要更多的人合作,所以決定四人組隊(duì),各自發(fā)揮特長。</p><p> 在設(shè)計(jì)過程中,我們配合得很好,初期的查閱資料共享,極大地體現(xiàn)了我們?nèi)藬?shù)上的優(yōu)勢。對于整個(gè)設(shè)計(jì)的交流更讓我們在大方向上走上了正確的道路,少走了很多彎路。我們的課題看
17、起來簡單,其實(shí)不然,仔細(xì)分析,涉及的知識面很廣,很考驗(yàn)我們的基本功和自學(xué)能力。軟件方面的算法由于是大家一起討論后決定的,一般都是可行的,也有很多難點(diǎn),比如說十進(jìn)制與十六進(jìn)制的轉(zhuǎn)換,數(shù)據(jù)的輸出與存儲等,但是在我們的通力合作下一一解決了我們面臨的很多難題。硬件方面用的是proteus軟件仿真,硬件電路的設(shè)計(jì)也是一個(gè)難點(diǎn),但是通過查閱資料與相互交流,我們的電路最終是可行的,雖然之前失敗了好幾次。軟件和硬件的結(jié)合再一次考驗(yàn)了我們的合作精神,軟件
18、是建立在硬件上的,硬件體現(xiàn)軟件的功能,主要負(fù)責(zé)硬件和組要負(fù)責(zé)軟件的同學(xué)建立了很好的默契,相互學(xué)習(xí),圓滿的完成了任務(wù)。</p><p> 本次課程設(shè)計(jì)我們對自己的成果相對比較滿意,在設(shè)計(jì)的過程中,大家相互學(xué)習(xí),相互幫助,都收獲很多。但是我們也有很多不足的地方,比如四位的計(jì)算器位數(shù)太少,不能進(jìn)行小數(shù)運(yùn)算等,這些都是對我們能力的極大挑戰(zhàn),為了解決這些問題我們也進(jìn)行了積極探索,設(shè)計(jì)了一個(gè)八位的簡單計(jì)算器,但是由于時(shí)間有
19、限,沒能完成設(shè)計(jì)。</p><p><b> 五、參考文獻(xiàn)</b></p><p> [1]《清華大學(xué)TPC—2003A實(shí)驗(yàn)指導(dǎo)書》,2006版</p><p> [2]《新編16/32位微型計(jì)算機(jī)原理及應(yīng)用》,李繼燦主編,清華大學(xué)出版社,2008版,第四版</p><p> [3] 陳繼紅.微機(jī)原理及應(yīng)用[M]
20、.北京:高等教育出版社,2011年,276-283頁</p><p> [4] 周明德.微型計(jì)算機(jī)系統(tǒng)原理及應(yīng)用[M].北京:清華大學(xué)出版社,2007年</p><p><b> 附錄</b></p><p><b> 軟件設(shè)計(jì)</b></p><p><b> 總程序流程圖<
21、;/b></p><p><b> 掃描程序流程圖</b></p><p><b> 程序代碼</b></p><p> ??;8255A端口地址:A口:40H,B口:44H,C口:42H,控制端口:46H</p><p> DATA SEGMENT</p><p&g
22、t; XDB? , ? , ? , ?;存放數(shù)據(jù)的每一位</p><p> X1DW ?;存放第一個(gè)數(shù)據(jù)值</p><p> X2DW?;存放第二個(gè)數(shù)據(jù)值</p><p> YDW?;存放運(yùn)算結(jié)果</p><p> SDB? ;存放運(yùn)算符號值</p>&
23、lt;p> EDB? ;按下等號鍵標(biāo)記</p><p> CC DB? ;存放運(yùn)算數(shù)據(jù)位數(shù)</p><p> HDB0 ;存放按鍵行號</p><p> LDB0 ;存放按鍵列號</p><p> DISCODEDB 3FH,06H
24、,5BH,4FH,</p><p> 66H,6DH,7DH,07H,</p><p> 7FH,6FH,77H,7CH,</p><p> 39H,5EH,79H,71H;段碼表</p><p> DATA ENDS</p><p> CODE SEGMENT</p><p&g
25、t; ASSUMECS:CODE</p><p><b> DS:DATA</b></p><p> START:MOVAX,DATA</p><p><b> MOVDS,AX</b></p><p> MOVAL,90H ;設(shè)置為A口輸入,B口輸出,C口輸出<
26、/p><p> OUT46H,AL</p><p> MOVDI,OFFSET X+3;DI指向X的高位</p><p> KKK:CALLKEY ;掃描按鍵</p><p><b> JMPKKK</b></p><p> ;以下為按鍵掃描子程序,程序返回后,在變量H
27、和L中存放當(dāng)前按鍵的行列號</p><p><b> KEY PROC</b></p><p> CHECK:CALLDISP ;等待按鍵按下的同時(shí)進(jìn)行顯示</p><p> MOVAL,0F0H ;所有行輸出低電平</p><p> OUT44H,AL</p><p>
28、; INAL,40H</p><p> CMPAL,0FFH ;讀列值</p><p> JZ CHECK ;若都為高電平則無鍵按下,等待</p><p><b> MOVCX,50</b></p><p> LOOP$ ;延時(shí)消抖</p><
29、;p> INAL,DX ;重讀列值</p><p> CMPAL,0FFH</p><p> JZCHECK ;無鍵按下一直等待</p><p> MOVH,0 ;有鍵按下,先把行列號變量清0</p><p><b> MOVL,0</b></p
30、><p> MOVBL,01H</p><p> MOVBH,0FEH ;掃描法讀鍵值:從第一行開始測試,即PC0輸出低電平</p><p> NEXT:MOVAL,BH</p><p> OUT 44H,AL</p><p> NEXTH:INAL,40H ;讀列值,判斷是
31、第幾列有鍵按下</p><p> TESTAL,BL ;從第一列開始判斷</p><p><b> JZWAIT0</b></p><p><b> ROLBL,1</b></p><p> CMPBL,10H ;當(dāng)前行狀態(tài)下沒有列有鍵按下,則轉(zhuǎn)為對下一行的測
32、試</p><p><b> JZNEXTL</b></p><p> INCH ;每判斷一列,列號加1</p><p> JMPNEXTH ;再對下一列進(jìn)行判斷</p><p> NEXTL:MOVH,0</p><p> MOVBL,01H</p&
33、gt;<p> ROLBH,1 ;對下一行測試,讓下一個(gè)PC口輸出低電平</p><p> CMPBH,0EFH</p><p><b> JZEXIT</b></p><p><b> INCL</b></p><p><b> JMP
34、NEXT</b></p><p> WAIT0:INAL,40H ;若有鍵按下,則等該按鍵松開后再計(jì)算鍵值</p><p> CMPAL,0FFH</p><p> JNZWAIT0</p><p><b> MOVCX,50</b></p><p&g
35、t; LOOP$ ;延時(shí)消抖</p><p> INAL,40H</p><p> CMPAL,0FFH</p><p> JNZWAIT0</p><p> CALLKEYVALUE ;調(diào)計(jì)算鍵值子程序</p><p> EXIT:RET</p>
36、<p><b> KEY ENDP</b></p><p> ;以下為計(jì)算鍵值子程序,通過行列號計(jì)算鍵值(鍵值=行號*4+列號)鍵值存放在DL寄存器中</p><p> KEYVALUE PROC</p><p><b> MOVDL,L</b></p><p><b&
37、gt; MOVDH,H</b></p><p><b> SHLDL,1</b></p><p> SHLDL,1 ;列號乘4</p><p><b> ADDDL,DH</b></p><p> CMPDL,9 ;按下的是
38、數(shù)字鍵</p><p> JNGNUM_CALL</p><p><b> CMPDL,14</b></p><p> JLCONT_CALL ;按下的是運(yùn)算鍵</p><p><b> CMPDL,14</b></p><p> JZOUTP_
39、CALL ;按下的是等于鍵</p><p><b> CMPDL,15</b></p><p> JZCLR_CALL ;按下的是清除鍵</p><p> NUM_CALL: CALLNUMBER ;調(diào)數(shù)字鍵處理子程序</p><p><b> JMPEXIT1&
40、lt;/b></p><p> CONT_CALL:MOVS,DL ;存放運(yùn)算鍵的鍵值</p><p><b> MOVE,0</b></p><p> CALLCOUNT 調(diào)運(yùn)算鍵處理子程序,計(jì)算第一個(gè)加數(shù)</p><p><b> JMPEXIT1
41、</b></p><p> OUTP_CALL:CALLOUTP ;調(diào)等號鍵處理子程序</p><p><b> JMPEXIT1</b></p><p> CLR_CALL:CALLCLEAR ;調(diào)清除鍵處理子程序</p><p> EXIT1:RE
42、T</p><p> KEYVALUE ENDP</p><p> ;以下為清除鍵處理子程序,按下清除鍵后,X變量全部清0</p><p> CLEAR PROC</p><p> MOVX[3],0</p><p> MOVX[2],0</p><p> MOVX[1],
43、0</p><p> MOVX[0],0</p><p><b> CALLBITP</b></p><p><b> RET</b></p><p> CLEAR ENDP</p><p> ;以下為等號鍵處理子程序,該子程序負(fù)責(zé)將第二個(gè)運(yùn)算數(shù)據(jù)的數(shù)值計(jì)算出
44、來存入X2變量</p><p> ;并根據(jù)運(yùn)算符號,調(diào)用相應(yīng)的運(yùn)算子程序</p><p> OUTP PROC</p><p><b> PUSHAX</b></p><p><b> PUSHDX</b></p><p><b> PUSHBX&
45、lt;/b></p><p><b> INCE</b></p><p> CALLCOUNT ;調(diào)運(yùn)算鍵處理子程序,計(jì)算第二個(gè)運(yùn)算數(shù)據(jù)</p><p><b> CMPS,10</b></p><p> JZADD_CALL ;運(yùn)算符為加號,則調(diào)用加法子
46、程序</p><p><b> CMPS,11</b></p><p> JZSUB_CALL ;運(yùn)算符為減號,則調(diào)用減法子程序</p><p><b> CMPS,12</b></p><p> JZMUL_CALL ;運(yùn)算符為乘號,則調(diào)用乘法子程序</p&g
47、t;<p><b> CMPS,13</b></p><p> CALLDIVP ;運(yùn)算符為除號,則調(diào)用除法子程序</p><p> JMPSTORE1</p><p> ADD_CALL:CALLADDP</p><p> JMPSTORE1</p>
48、<p> SUB_CALL:CALLSUBP</p><p> JMPSTORE1</p><p> MUL_CALL:CALLMULP</p><p> STORE1:MOVAX,Y</p><p> ;以下程序?qū)⒏鬟\(yùn)算子程序返回的運(yùn)算結(jié)果,按位分解,送入X變量</p><p>&
49、lt;b> MOVDX,0</b></p><p> MOVBX,1000</p><p><b> DIVBX</b></p><p> MOVX[0], AL</p><p><b> MOVAX,DX</b></p><p> M
50、OVBL,100</p><p><b> DIVBL</b></p><p> MOVX[1],AL</p><p><b> MOVAL,AH</b></p><p><b> MOVAH,0</b></p><p><b&g
51、t; MOVBL,10</b></p><p><b> DIVBL</b></p><p> MOVX[2],AL</p><p> MOVX[3],AH</p><p><b> POPBX</b></p><p><b> P
52、OPDX</b></p><p><b> POPAX</b></p><p><b> RET</b></p><p> OUTP ENDP</p><p> ;以下為運(yùn)算鍵處理子程序,該程序?qū)⒌谝粋€(gè)運(yùn)算數(shù)據(jù)的數(shù)值計(jì)算出來并存入X1變量</p><p&
53、gt; ;或者將第二個(gè)運(yùn)算數(shù)據(jù)的數(shù)值計(jì)算出來并存入X2變量</p><p> ;將運(yùn)算符的值存入S變量</p><p> COUNT PROC</p><p><b> PUSHAX</b></p><p><b> PUSHBX</b></p><p>&l
54、t;b> PUSHDX</b></p><p><b> MOVDX,0</b></p><p> CALLBITP ;測試X中的數(shù)據(jù)是多少位</p><p> CMPCC,4 ;輸入的數(shù)據(jù)是4位數(shù) ?</p><p><b> JZC
55、4</b></p><p> CMPCC,3 ;輸入的數(shù)據(jù)是3位數(shù) ?</p><p><b> JZ C3</b></p><p> CMPCC,2 ;輸入的數(shù)據(jù)是2位數(shù) ?</p><p><b> JZC2</b></p
56、><p> JMPC1 ;輸入的數(shù)據(jù)是1位數(shù) ?</p><p> C4:MOVAX,0</p><p> MOVAL,X[0]</p><p> MOV BX,1000</p><p><b> MUL BX</b></p><p&g
57、t; MOV DX,AX</p><p> C3:MOVAL,X[1]</p><p> MOV BL,100</p><p><b> MUL BL</b></p><p> ADD DX,AX</p><p> C2:MOV AL,X[2]</p>
58、<p><b> MOVBL,10</b></p><p><b> MULBL</b></p><p><b> ADDDX,AX</b></p><p> C1:MOVAL,X[3]</p><p><b> MOVAH,0<
59、/b></p><p><b> ADDDX,AX</b></p><p><b> CMPE,1</b></p><p><b> JNZX1_S</b></p><p> MOVX2,DX ;按下的是等號,則將第二個(gè)運(yùn)算數(shù)據(jù)的值存入X2
60、變量</p><p><b> JMPEXIT3</b></p><p> X1_S:MOVX1,DX ;按下的是運(yùn)算符號,則將第一個(gè)運(yùn)算數(shù)據(jù)的值存X1變量</p><p> MOVX[3],0 ;清空X變量</p><p> MOVX[2],0</p><p&g
61、t; MOVX[1],0</p><p> MOV X[0],0</p><p> EXIT3: POP DX</p><p><b> POPBX</b></p><p><b> POPAX</b></p><p><b> RET&l
62、t;/b></p><p> COUNT ENDP</p><p> ;以下為數(shù)字鍵處理子程序</p><p> ;該程序,將輸入的數(shù)據(jù)按位存放在X變量中,并由CC記錄數(shù)據(jù)的位數(shù)</p><p> NUMBER PROC</p><p><b> CMPE,1</b><
63、/p><p> JNZCONTINUE</p><p><b> MOVE,0</b></p><p> CALLCLEAR</p><p> CONTINUE:CMPCC,0 ;目前數(shù)據(jù)為0位,即沒有數(shù)據(jù),則轉(zhuǎn)到SSS</p><p><b> JZS
64、SS</b></p><p><b> PUSHAX</b></p><p><b> PUSHDX</b></p><p> MOVAL,X[3]</p><p> MOVAH,X[2]</p><p> MOVDL,X[1]</p&g
65、t;<p> MOVDH,X[0]</p><p><b> MOV CX,8</b></p><p> LL:SHLAX, 1</p><p><b> RCLDX,1</b></p><p><b> LOOPLL</b></p&
66、gt;<p> MOVX[3],AL</p><p> MOVX[2],AH</p><p> MOVX[1],DL</p><p> MOVX[0],DH</p><p><b> POPDX</b></p><p><b> POPAX</
67、b></p><p> SSS:MOV [DI],DL ;將當(dāng)前鍵入的數(shù)據(jù)存放到X的最低位</p><p> INCCC ;數(shù)據(jù)位數(shù)加1</p><p> CMPCC,4 ;判斷數(shù)據(jù)位數(shù)</p><p><b> JNGEXIT2</b></p&
68、gt;<p> MOVCC,0 ;如果數(shù)據(jù)超過4位,重新從最低位開始存放</p><p> MOVX[2],0</p><p> MOVX[1],0</p><p> MOV X[0],0</p><p> EXIT2: CALL DISP ;調(diào)顯示子程序,顯示輸入的數(shù)據(jù)&l
69、t;/p><p><b> RET</b></p><p> NUMBER ENDP</p><p><b> ;加法子程序</b></p><p> ADDP PROC</p><p><b> PUSHAX</b></p>
70、<p><b> MOVAX,X1</b></p><p><b> ADDAX,X2</b></p><p><b> MOVY,AX</b></p><p><b> POPAX</b></p><p><b>
71、RET</b></p><p> ADDP ENDP</p><p><b> ;減法子程序</b></p><p> SUBP PROC</p><p><b> PUSHAX</b></p><p><b> MOVAX,X1<
72、;/b></p><p><b> SUBAX,X2</b></p><p><b> MOV Y,AX</b></p><p><b> POP AX</b></p><p><b> RET</b></p><p
73、> SUBP ENDP</p><p><b> ;乘法子程序</b></p><p> MULP PROC</p><p><b> PUSHAX</b></p><p><b> PUSHDX</b></p><p> MO
74、V AX,X1</p><p><b> MOVDX,X2</b></p><p><b> MULDX</b></p><p><b> MOVY,AX</b></p><p><b> POPDX</b></p><
75、;p><b> POPAX</b></p><p><b> RET</b></p><p> MULP ENDP</p><p><b> ;除法子程序</b></p><p> DIVP PROC</p><p><b&g
76、t; PUSHAX</b></p><p><b> PUSHBX</b></p><p><b> PUSHDX</b></p><p><b> MOVDX,0</b></p><p> MOV AX,X1</p><p&
77、gt;<b> MOVBX,X2</b></p><p><b> DIV BX</b></p><p><b> MOVY,AX</b></p><p><b> POP DX</b></p><p><b> POP B
78、X</b></p><p><b> POP AX</b></p><p><b> RET</b></p><p> DIVP ENDP</p><p> ;顯示子程序 ,將X中的數(shù)值按位顯示出來</p><p> DISP PROC<
79、/p><p><b> PUSHBX</b></p><p><b> PUSH AX</b></p><p><b> MOVBH,0</b></p><p> LEA SI,DISCODE</p><p> CALLBITP
80、 ;測試X位數(shù)</p><p><b> CMP CC,4</b></p><p><b> JZ QIAN</b></p><p><b> CMP CC,3</b></p><p><b> JZ BAI</b><
81、/p><p><b> CMP CC,2</b></p><p><b> JZ SHI</b></p><p> CMP CC,1</p><p><b> JMP G</b></p><p> JMP NONE</
82、p><p> QIAN:MOVAH,11100000B ;從第4位開始顯示</p><p><b> MOVAL,AH</b></p><p> OUT 44H,AL</p><p> MOV BL,X[0]</p><p> MOV AL,[SI+BX]</p
83、><p> OUT 42H,AL</p><p> CALL DELY</p><p><b> MOV AL,0</b></p><p> OUT 42H,AL</p><p> BAI:MOVAH,11010000B ;從第3位開始顯示</p>&l
84、t;p> MOV AL,AH</p><p> OUT44H,AL</p><p> MOV BL,X[1]</p><p> MOV AL,[SI+BX]</p><p> OUT 42H,AL</p><p> CALL DELY</p><p> MO
85、V AL,0</p><p> OUT 42H,AL</p><p> SHI:MOV AH,10110000B ;從第2位開始顯示</p><p> MOV AL,AH</p><p> OUT 44H,AL</p><p> MOV BL,X[2]</p>&
86、lt;p> MOV AL,[SI+BX]</p><p> OUT 42H,AL</p><p> CALL DELY</p><p> MOV AL,0</p><p> OUT 42H,AL</p><p> G:MOV AH,01110000B ;從第1位開始顯示
87、</p><p><b> MOVAL,AH</b></p><p> OUT 44H,AL</p><p> MOV BL,X[3]</p><p> MOV AL,[SI+BX]</p><p> OUT 42H,AL</p><p> CALL
88、 DELY</p><p> JMP EXIT4</p><p> NONE: MOVAL,0 ;X中沒有數(shù)據(jù),不顯示</p><p> OUT42H,AL</p><p> EXIT4: POP AX</p><p><b> POP BX</b>
89、</p><p><b> RET</b></p><p> DISP ENDP</p><p> ;分析數(shù)據(jù)位數(shù)子程序</p><p> BITP PROC</p><p> CMP X[0],0 ;如果X[0]不為0,則數(shù)據(jù)為4位數(shù)</p>&l
90、t;p> JNZ FOURBIT</p><p> CMP X[1],0 ;如果X[1]不為0,則數(shù)據(jù)為3位數(shù)</p><p> JNZ THREEBIT</p><p> CMP X[2],0 ;如果X[2]不為0,則數(shù)據(jù)為2位數(shù)</p><p> JNZ TOWBIT&l
91、t;/p><p> CMP X[3],0 ;如果X[3]不為0,則數(shù)據(jù)為1位數(shù)</p><p> JNZ ONEBIT</p><p> JMP ZER0BIT ;否則,沒有數(shù)據(jù)</p><p> FOURBIT:MOVCC,4</p><p><b> JM
92、PEXIT5</b></p><p> THREEBIT: MOVCC,3</p><p> JMP EXIT5</p><p> TOWBIT: MOV CC,2</p><p> JMP EXIT5</p><p> ONEBIT: MOV CC,1</p&g
93、t;<p> JMP EXIT5</p><p> ZER0BIT: MOV CC,0</p><p> EXIT5: RET</p><p> BITP ENDP</p><p><b> ;延時(shí)子程序</b></p><p> DELY PROC&
94、lt;/p><p><b> PUSHCX</b></p><p> MOV CX,100</p><p><b> LOOP $</b></p><p><b> POP CX</b></p><p><b> RET<
95、/b></p><p> DELY ENDP</p><p> CODE ENDS</p><p> END START</p><p><b> 硬件設(shè)計(jì)</b></p><p> 1.微處理器8086</p><p> 當(dāng)引腳接高電平時(shí)
96、,CPU工作于最小模式。此時(shí),引腳信號24~31的含義及其功能如下: </p><p> (1)INTA/(interrupt acknowledge):可屏蔽中斷響應(yīng)信號,輸出,低電平有效。 CPU通過信號對外設(shè)提出的可屏蔽中斷請求做出響應(yīng)。為低電平時(shí),表示CPU已經(jīng)響應(yīng)外設(shè)的中斷請求,即將執(zhí)行中斷服務(wù)程序。</p><p> (2)ALE(address lock enable):
97、地址鎖存允許信號,輸出,高電平有效。 CPU利用ALE信號可以把AD15 ~AD0地址/數(shù)據(jù)、A19/S6~A16/S3地址/狀態(tài)線上的地址信息鎖存在地址鎖存器中。 </p><p> (3)DEN/(data enable):數(shù)據(jù)允許控制信號,輸出,三態(tài),低電平有效。信號用作總線收發(fā)器的選通控制信號。當(dāng)為低電平時(shí),表明CPU進(jìn)行數(shù)據(jù)的讀/寫操作。 </p><p> ?。?)DT/(d
98、ata transmit or receive):數(shù)據(jù)發(fā)送/接收信號,輸出,三態(tài)。 DT/信號用來控制數(shù)據(jù)傳送的方向。DT/為高電平時(shí),CPU發(fā)送數(shù)據(jù)到存儲器或I/O端口;DT/為低電平時(shí),CPU接收來自存儲器或I/O端口的數(shù)據(jù)。</p><p> ?。?)IO/M/(memory I/O select):存儲器、I/O端口選擇控制信號。 信號指明當(dāng)前CPU是選擇訪問存儲器還是訪問I/O端口。為高電平時(shí)訪問存儲器
99、,表示當(dāng)前要進(jìn)行CPU與存儲器之間的數(shù)據(jù)傳送。為低電平時(shí),訪問I/O端口,表示當(dāng)前要進(jìn)行CPU與I/O端口之間的數(shù)據(jù)傳送。 </p><p> (6)WR/(write):寫信號,輸出,低電平有效。 信號有效時(shí),表明CPU正在執(zhí)行寫總線周期,同時(shí)由信號決定是對存儲器還是對I/O端口執(zhí)行寫操作。</p><p> (7)HLDA(hold acknowledge):總線保持響應(yīng)信號,輸出
100、,高電平有效。HLDA是與HOLD配合使用的聯(lián)絡(luò)信號。在HLDA有效期間,HLDA引腳輸出一個(gè)高電平有效的響應(yīng)信號,同時(shí)總線將處于浮空狀態(tài),CPU讓出對總線的控制權(quán),將其交付給申請使用總線的8237A控制器使用,總線使用完后,會使HOLD信號變?yōu)榈碗娖?,CPU又重新獲得對總線的控制權(quán)。</p><p> ?。?)HOLD(bus hold request):總線保持請求信號,輸入,高電平有效。在DMA數(shù)據(jù)傳送方式
101、中,由總線控制器8237A發(fā)出一個(gè)高電平有效的總線請求信號,通過HOLD引腳輸入到CPU,請求CPU讓出總線控制權(quán)。 </p><p> 2. 可編程并行接口芯片8255A</p><p> RESET:復(fù)位輸入線,當(dāng)該輸入端外于高電平時(shí),所有內(nèi)部寄存器(包括控制寄存器)均被清除,所有I/O 口均被置成輸入方式。</p><p> PA0~PA7:端口A 輸入
102、輸出線,一個(gè)8 位的數(shù)據(jù)輸出鎖存器/緩沖器, 一個(gè) 8 位的數(shù)據(jù)輸入鎖存器。</p><p> PB0~PB7:端口B 輸入輸出線,一個(gè)8 位的I/O 鎖存器, 一個(gè) 8 位的輸入輸出緩沖器。</p><p> PC0~PC7:端口C 輸入輸出線,一個(gè)8 位的數(shù)據(jù)輸出鎖存器/緩沖器, 一個(gè) 8 位的數(shù)據(jù)輸入緩沖器。端口C 可以通過工作方式設(shè)定而分成2 個(gè)4 位的端口, 每個(gè) 4 位的端
103、口包含一個(gè)4 位的鎖存器,分別與端口A 和端口B 配合使用,可作為控制信號輸出或狀態(tài)信號輸入端口。</p><p> CS:片選信號線,當(dāng)這個(gè)輸入引腳為低電平時(shí),表示芯片被選中,允許8255 與CPU 進(jìn)行通訊。</p><p> RD:讀信號線,當(dāng)這個(gè)輸入引腳為低電平時(shí),允許8255 通過數(shù)據(jù)總線向CPU 發(fā)送數(shù)據(jù)或狀態(tài)信息,即CPU 從8255 讀取信息或數(shù)據(jù)。</p>
104、<p> WR:寫入信號,當(dāng)這個(gè)輸入引腳為低電平時(shí),允許CPU 將數(shù)據(jù)或控制字寫8255。</p><p> D0~D7:三態(tài)雙向數(shù)據(jù)總線,8255 與CPU 數(shù)據(jù)傳送的通道,當(dāng)CPU 執(zhí)行輸入輸出指令時(shí),通過它實(shí)現(xiàn)8 位數(shù)據(jù)的讀/寫操作,控制字和狀態(tài)信息也通過數(shù)據(jù)總線傳送。</p><p> 8255 的讀寫控制:</p><p> 8255
105、 的讀/寫控制邏輯電路接受CPU 發(fā)來的控制口號RD、WR、RESET 和地址信號A1~A0。然后根據(jù)命令端口,控制信號的要求,將端口的數(shù)據(jù)讀出選信CPU 或者將CPU送來的數(shù)據(jù)寫入端口,各端口的工作狀態(tài)。通過用輸出指令對8255A 的控制字寄存器編程,寫入設(shè)定工作方式的控制字,可以讓3個(gè)數(shù)據(jù)口以不同的方式工作,端口A 可工作于3 種方式的任一種,端口B 只能工作于方式0 和方式1,端口C 除了用于輸入輸出端口外,還能配合A 口和B 口
106、工作,為這兩個(gè)端口的輸入輸出操作提供聯(lián)系信號。</p><p> 3.可編程定時(shí)/計(jì)數(shù)器8253A</p><p> 8253A的引腳可以分為兩部分:與CPU的接口引腳和與外設(shè)的接口引腳。</p><p> (1) 與CPU的接口引腳 </p><p> D0~D7:三態(tài)雙向數(shù)據(jù)線,和CPU數(shù)據(jù)總線相連,用于傳輸CPU與82
107、53之間的數(shù)據(jù)信息、控制信息和狀態(tài)信息。</p><p> CS:片選信息,輸入、低電平有效。</p><p> A1、A0:用來對8253A片內(nèi)三個(gè)計(jì)數(shù)通道和控制字寄存器進(jìn)行尋址。</p><p> RD:讀信號,輸入,低電平有效。</p><p> WR:寫信號,輸入,低電平有效。</p><p> (2
108、) 與外設(shè)的接口引腳</p><p> CLK:時(shí)鐘輸入引腳,用于輸入定時(shí)脈沖或計(jì)數(shù)脈沖信號。計(jì)數(shù)器對這個(gè)引腳輸入的脈沖進(jìn)行計(jì)數(shù)。</p><p> GATE:門控輸入端。用于外部控制計(jì)數(shù)器的啟動計(jì)數(shù)和停止計(jì)數(shù)的操作。兩個(gè)或兩個(gè)以上計(jì)數(shù)器連用時(shí),可以用此信號來同步,也可用于與外部某信號的同步。</p><p> OUT:計(jì)數(shù)輸出端。不管8253以何種方式工作,
109、當(dāng)計(jì)數(shù)器計(jì)數(shù)到0時(shí),在OUT引腳上必定有輸出。在不同模式下,可輸出不同形式的信號。</p><p><b> 4.LED數(shù)碼管</b></p><p> LED為發(fā)光二極管構(gòu)成的顯示器件,亦稱數(shù)碼管。由7個(gè)字符段和一個(gè)小數(shù)點(diǎn)段組成,每段對應(yīng)一個(gè)發(fā)光二極管,當(dāng)發(fā)光二極管點(diǎn)亮?xí)r,相應(yīng)的字符段點(diǎn)亮。LED有共陰極和共陽極兩種供應(yīng)狀態(tài)。共陰極顯示時(shí),將LED顯示的COM接
110、地,將八個(gè)字符段端a、b、c、d、e、f、g、dp依次與一個(gè)8位I/O口的最低到最高位連接,當(dāng)I/O給LED的哪個(gè)字符段送入一個(gè)高電平時(shí),該段就被點(diǎn)亮,從而可從這7個(gè)字符段中被點(diǎn)亮的構(gòu)成相應(yīng)的字符顯示出來。同理,COM陽極即將COM端接Vcc,其顯示原理與COM陰極的基本相同,但I(xiàn)/O口送入低電平是相應(yīng)的段才被點(diǎn)亮。 </p><p><b> 5.4×4矩陣按鍵</b><
111、/p><p> 鍵盤是信息輸入元件,由一個(gè)個(gè)按鈕組成,如果是獨(dú)立按鈕的話必須要需要一個(gè)I/O口對它進(jìn)行檢測。因?yàn)?×4矩陣鍵盤有8個(gè)管腳,于是將鍵盤接8255A的PC口。因?yàn)檫M(jìn)行鍵盤掃描一般要求有一部分的I/O口的工作方式是輸入,另一部分I/O是輸出,具體到4×4鍵盤則要求4個(gè)I/O口輸入,另外4個(gè)輸出,這一點(diǎn)PC口剛好符合,而PA、PB口要么全部輸入或輸出,所以只能是PC口接鍵盤。</p
112、><p><b> 4x4矩陣按鍵面板</b></p><p> 6.74L138譯碼器</p><p> ?、佼?dāng)一個(gè)選通端(E1)為高電平,另兩個(gè)選通端((/E2))和/(E3))為低電平時(shí),可將地址端(A0、A1、A2)的二進(jìn)制編碼在Y0至Y7對應(yīng)的輸出端以低電平譯出。比如:A2A1A0=110時(shí),則Y6輸出端輸出低電平信號。 </p
113、><p> ?、诶?E1、E2和E3可級聯(lián)擴(kuò)展成 24 線譯碼器;若外接一個(gè)反相器還可級聯(lián)擴(kuò)展成 32 線譯碼器。 </p><p> ?、廴魧⑦x通端中的一個(gè)作為數(shù)據(jù)輸入端時(shí),74LS138還可作數(shù)據(jù)分配器。 </p><p> ?、芸捎迷?086的譯碼電路中,擴(kuò)展內(nèi)存。</p><p> 7.74LS373D 鎖存器 </p>
114、<p> 373為三態(tài)輸出的八 D 透明鎖存器,共有 54S373 和 74LS373 兩種線路。</p><p> ?、佼?dāng)三態(tài)允許控制端 OE 為低電平時(shí),Q0~Q7為正常邏輯狀態(tài),可用來驅(qū)動負(fù)載或總線。當(dāng) OE 為高電平時(shí),Q0~Q7 呈高阻態(tài),即不驅(qū)動總線,也不為總線的負(fù)載,但鎖存器內(nèi)部的邏輯操作不受影響。 </p><p> ②當(dāng)鎖存允許端 LE 為高電平時(shí),Q 隨
115、數(shù)據(jù) D 而變。當(dāng) LE 為低電平時(shí),D 被鎖存在已建立的數(shù)據(jù)電平。當(dāng) LE 端施密特觸發(fā)器的輸入滯后作用,使交流和直流噪聲抗擾度被改善 400mV。 </p><p><b> ③引出端符號:</b></p><p> D0~D7 數(shù)據(jù)輸入端 </p><p> OE 三態(tài)允許控制端(低電平有效) </p><p&g
溫馨提示
- 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)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 單片機(jī)課程設(shè)計(jì)十進(jìn)制加法計(jì)算器設(shè)計(jì)
- 單片機(jī)課程設(shè)計(jì)報(bào)告---設(shè)計(jì)十進(jìn)制加減乘法計(jì)算器
- 課程設(shè)計(jì)--十進(jìn)制加減法計(jì)算器單片機(jī)設(shè)計(jì)
- 微機(jī)原理課程設(shè)計(jì)--應(yīng)用8255a和8位ad變換器實(shí)現(xiàn)多路數(shù)據(jù)的采集
- 微機(jī)課程設(shè)計(jì)設(shè)計(jì)-應(yīng)用8255a實(shí)現(xiàn)交通燈控制
- 微機(jī)原理簡易計(jì)算器課程設(shè)計(jì)
- 微機(jī)原理課程設(shè)計(jì)--簡易計(jì)算器設(shè)計(jì)
- 微機(jī)課程設(shè)計(jì)--計(jì)算器
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)—十進(jìn)制四則運(yùn)算計(jì)算器的設(shè)計(jì)與實(shí)現(xiàn)
- 微機(jī)課程設(shè)計(jì)--計(jì)算器
- 微機(jī)課程設(shè)計(jì)報(bào)告--8255273實(shí)現(xiàn)六位簡單計(jì)算器
- eda課程設(shè)計(jì)---十進(jìn)制加法計(jì)數(shù)器
- eda課程設(shè)計(jì)--十進(jìn)制加法計(jì)數(shù)器
- 微機(jī)課程設(shè)計(jì)--簡易計(jì)算器
- eda專業(yè)課程設(shè)計(jì)--用vhdl來實(shí)現(xiàn)八位二—十進(jìn)制異步計(jì)數(shù)器
- 數(shù)電課程設(shè)計(jì)報(bào)告--兩位十進(jìn)制計(jì)數(shù)顯示器
- eda課程設(shè)計(jì)--八位十進(jìn)制頻率計(jì)
- 課程設(shè)計(jì)---應(yīng)用8255a實(shí)現(xiàn)交通燈控制設(shè)計(jì)
- eda課程設(shè)計(jì)--2位十進(jìn)制四則運(yùn)算器電路
- eda課程設(shè)計(jì)--2位十進(jìn)制四則運(yùn)算器電路
評論
0/150
提交評論