MCU 中輸入/輸出口的使用
在HT49C30-1/HT49R30A-1 中有8 個雙向的輸入/輸出口(PA 口,8 位),6 個輸入口(PB 口);HT49C50-1/HT49R50A-1 中有12 個雙向的輸入/輸出口(PA 口,8 位;PC 口,4 位),8 個輸入口(PB 口);HT49C70-1/HT49R70A-1 中有16 個雙向的輸入/輸出口(PA 口,8 位;PC 口,8 位),8 個輸入口(PB 口)PA、PB、PC 分別對應(yīng)RAM 中地址[12H] 、[14H] 、[16H] 。掩膜時可選擇PA、PC 口的結(jié)構(gòu)(NMOS 或CMOS),及該口是否具有上拉電阻。
若PA、PC 口結(jié)構(gòu)NMOS 時,在讀取數(shù)據(jù)之前,必須向相關(guān)位寫“1”以關(guān)閉場效應(yīng)管NMOS 使其作為一個輸入口。也就是說,要先執(zhí)行指令SET [m].i 以關(guān)閉相關(guān)的NMOS,然后才能用MOV A,[m] 來讀取穩(wěn)定的數(shù)據(jù)。
圖1 輸入輸出口
一些指令稱為讀-修改-寫指令,該指令先讀取引腳的值,而且是將八位引腳的狀態(tài)全部讀取,進(jìn)行相應(yīng)的位操作后,重寫回鎖存器中。這樣,有些位的鎖存器會因為該操作而改變原來的狀態(tài),致使再次輸出時產(chǎn)生錯誤。例如,指令“SET [m].i”、“CLR [m].i”、“CPL[m]”、“CPLA[m] ”就是先將數(shù)據(jù)讀取至CPU 中,然后進(jìn)行定義的操作(位操作)后,再將結(jié)果寫回鎖存器或是累加器中。所以口在輸入狀態(tài)時執(zhí)行此類指令,可能會使內(nèi)部鎖存的狀態(tài)改變,需要加以注意。
輸入輸出口應(yīng)用程序舉例
1.掩膜選擇:pa.0~pa.3 選擇CMOS 結(jié)構(gòu),帶上拉電阻;
硬件要求:pa.0~pa.3 接LED;pa.4~pa.7 接開關(guān)
電路圖:
圖2 電路圖
程序說明:
如上圖所示,pa.0~pa.3 作為輸出,pa.4~pa.7 作為輸入,利用程序?qū)a.4~pa.7 口上的開關(guān)數(shù)讀入單片機,經(jīng)過高4 位與低4 位互換,再向pa.0~pa.3 輸出pa.4~pa.7 的開關(guān)狀態(tài),使LED 的發(fā)光次序與pa.4~pa.7 上的開關(guān)設(shè)置相符。
2.掩膜選擇:PC口選為CMOS并帶上拉電阻
硬件連接:PA.7與PA.0口相連接程序說明:本程序的目的要說明在執(zhí)行讀-修改-寫指令時發(fā)生的特殊情況。
程序說明:
執(zhí)行以上程序,我們會發(fā)現(xiàn)PA.0和PA.7引腳的值始終為0,但實際上PA.0和PA.7 內(nèi)部鎖存器的值是變化的,參見程序注釋。
如果用單步調(diào)試,我們就能觀察到“Read—Modify—Write”的過程。當(dāng)程序執(zhí)行完(2)時,將連接PA.0和PA.7的導(dǎo)線斷開,則執(zhí)行完下一條語句后PA.0引腳的值會變?yōu)?。
加上(3)語句,如果在執(zhí)行完(2)時斷開連接,則最后結(jié)果為PA.0=1、PA.7=1;如果在執(zhí)行完(3)時斷開連接,則最后結(jié)果為PA.0=0、Pa.7=1。在使用過程中因注意以上區(qū)別所以某個口當(dāng)為NMOS結(jié)構(gòu),要作為輸入口時,一定要先向該口寫“1”,再讀入該口的輸入狀態(tài),
并且讀口狀態(tài)的操作一定要緊接在寫“1”操作之后,避免因執(zhí)行“Read—Modify—Write”指令而發(fā)生錯誤。
光敏電阻相關(guān)文章:光敏電阻工作原理
評論