實(shí)驗(yàn)內(nèi)容 1) 編寫(xiě)程序,用P1.0~P1.2口連LED,查詢撥盤(pán)開(kāi)關(guān)SW1的狀態(tài)來(lái)控制LED的亮和滅(P1.7口接SW1)。 2) 編寫(xiě)程序,用P1.0~P1.2口連LED ,用按鍵開(kāi)關(guān)KEY1作為外部中斷輸入INT0控制LED的亮和滅。(每按一次按鍵LED狀態(tài)取反一次)。 實(shí)驗(yàn)原理 Ø P0口的特點(diǎn): P0口是一個(gè)雙功能的端口:地址/數(shù)據(jù)分時(shí)復(fù)用口和通用I/O口; 具有高電平、低電平和高阻抗3種狀態(tài)的I/O端口稱為雙向I/O端口。P0口作地址/數(shù)據(jù)總線復(fù)用口時(shí),相當(dāng)于一個(gè)真正的雙向I/O口。而用作通用I/O口時(shí),由于引腳上需要外接上拉電阻,端口不存在高阻(懸空)狀態(tài),此時(shí)P0口只是一個(gè)準(zhǔn)雙向口; 為保證引腳上的信號(hào)能正確讀入,在讀入操作前應(yīng)首先向鎖存器寫(xiě)1; 單片機(jī)復(fù)位后,鎖存器自動(dòng)被置1; 一般情況下,如果P0口已作為地址/數(shù)據(jù)復(fù)用口時(shí),就不能再用作通用I/O口使用; P0口能驅(qū)動(dòng)8個(gè)TTL負(fù)載。 Ø P1口的特點(diǎn): P1口由于有內(nèi)部上拉電阻,沒(méi)有高阻抗輸入狀態(tài),所以稱為準(zhǔn)雙向口。作為輸出口時(shí),不需要再在片外拉接上拉電阻; P1口讀引腳輸入時(shí),必須先向鎖存器寫(xiě)入1,其原理與P0口相同; P1口能驅(qū)動(dòng)4個(gè)TTL負(fù)載。 Ø P2口的特點(diǎn): P2口用作高8位地址輸出線應(yīng)用時(shí),與P0口輸出的低8位地址一起構(gòu)成16位的地址總線,可以尋址64KB地址空間。 當(dāng)P2口作高8位地址輸出口時(shí),其輸出鎖存器原鎖存的內(nèi)容保持不變。 作為通用I/O口使用時(shí),P2口為準(zhǔn)雙向口,功能與P1口一樣。 P2口能驅(qū)動(dòng)4個(gè)TTL負(fù)載。 Ø P3口的特點(diǎn): P2口用作高8位地址輸出線應(yīng)用時(shí),與P0口輸出的低8位地址一起構(gòu)成16位的地址總線,可以尋址64KB地址空間。 當(dāng)P2口作高8位地址輸出口時(shí),其輸出鎖存器原鎖存的內(nèi)容保持不變。 作為通用I/O口使用時(shí),P2口為準(zhǔn)雙向口,功能與P1口一樣。 P2口能驅(qū)動(dòng)4個(gè)TTL負(fù)載。 Ø 端口功能總結(jié): (1)P0~P3口都是并行I/O口,但P0口和P2口,還可用來(lái)構(gòu)建系統(tǒng)的數(shù)據(jù)總線和地址總線,所以在電路中有一個(gè)MUX,以進(jìn)行轉(zhuǎn)換。而P1口和P3口無(wú)構(gòu)建系統(tǒng)的數(shù)據(jù)總線和地址總線的功能,因此,無(wú)MUX。 P0口的MUX的一個(gè)輸入端為“地址/數(shù)據(jù)”信號(hào)。P2口的MUX的一個(gè)輸入信號(hào)為“地址”信號(hào)。 (2)在4個(gè)口中只有P0口是一個(gè)真正的雙向口,P1~P3口都是準(zhǔn)雙向口。原因:P0口作數(shù)據(jù)總線使用時(shí),需解決芯片內(nèi)外的隔離問(wèn)題,即只有在數(shù)據(jù)傳送時(shí)芯片內(nèi)外才接通;不進(jìn)行數(shù)據(jù)傳送時(shí),芯片內(nèi)外應(yīng)處于隔離狀態(tài)。為此,P0口的輸出緩沖器應(yīng)為三態(tài)門(mén)。 P0口中輸出三態(tài)門(mén)是由兩只場(chǎng)效應(yīng)管(FET)組成,所以是一個(gè)真正的雙向口。P1~P3口,上拉電阻代替P0口中的場(chǎng)效應(yīng)管,輸出緩沖器不是三態(tài)的-準(zhǔn)雙向口。 (3)P3口的口線具有第二功能,為系統(tǒng)提供一些控制信號(hào)。因此P3口增加了第二功能控制邏輯。這是P3口與其它各口的不同之處。 Ø 五個(gè)中斷請(qǐng)求源: (1)INT0*—外部中斷請(qǐng)求0,由引腳INT0*輸入,中斷請(qǐng)求標(biāo)志為IE0。 (2)INT1*—外部中斷請(qǐng)求1,由引腳INT1*輸入,中斷請(qǐng)求標(biāo)志為IE1。 (3)定時(shí)器/計(jì)數(shù)器T0溢出中斷請(qǐng)求,中斷請(qǐng)求標(biāo)志為T(mén)F0。 (4)定時(shí)器/計(jì)數(shù)器T1溢出中斷請(qǐng)求,中斷請(qǐng)求標(biāo)志為T(mén)F1。 (5)串行口中斷請(qǐng)求,中斷請(qǐng)求標(biāo)志為T(mén)I或RI。 Ø 終端控制: (1)EA:中斷允許總控制位 0:CPU屏蔽所有的中斷請(qǐng)求(CPU關(guān)中斷); 1:CPU開(kāi)放所有中斷(CPU開(kāi)中斷)。 (2)ES:串行口中斷允許位 0:禁止串行口中斷; 1:允許串行口中斷。 (3)ET1:定時(shí)器/計(jì)數(shù)器T1的溢出中斷允許位 (4)EX1:外部中斷1中斷允許位 (5)ET0:定時(shí)器/計(jì)數(shù)器T0的溢出中斷允許位 (6)EX0:外部中斷0中斷允許位。 實(shí)驗(yàn)匯編代碼
(1) ORG 0000H LJMP Main ORG 0100H ; Main: SETB P1.7 ;將P1.7設(shè)置為輸入端口,事實(shí)上由于RESET會(huì)上電,可以省略該步 JB P1.7,SET_lED ;檢測(cè)撥盤(pán)開(kāi)關(guān)是否閉合 SETB P1.0 ;若撥盤(pán)開(kāi)關(guān)未閉合,熄滅LED SETB P1.1 SETB P1.2 SJMP Main ; SET_LED: CLR P1.0 ;若撥盤(pán)開(kāi)關(guān)閉合則跳轉(zhuǎn)到SET_LED點(diǎn)亮LED CLR P1.1 CLR P1.2 SJMP Main ; END
(2)
ORG 0000H LJMP Main ORG 0003H ;外部中斷0中斷入口地址 LJMP INTT ORG 0100H ; Main: SETB IT0 ;設(shè)置外部中斷為邊沿觸發(fā) SETB EX0 ;打開(kāi)-INT0中斷允許 SETB EA ;打開(kāi)CPU中斷允許 SJMP $ ;等待中斷 ; INTT: CLR EX0 ;關(guān)閉外部中斷 CPL P1.0 ;LED狀態(tài)取反 CPL P1.1 CPL P1.2 CLR IE0 ;清除可能已經(jīng)產(chǎn)生的中斷請(qǐng)求 SETB EX0 ;打開(kāi)-INT0中斷允許(按鍵抖動(dòng)) RETI ;中斷返回 ; END
都是編譯通過(guò)的。
|