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