C8051F320-并行端口與交*開關
C8051F320具有25個I/O引腳,分別為P0、P1、P2、P3.0。為了能根據(jù)需要使用內(nèi)部數(shù)字系統(tǒng)資源,必須利用數(shù)字交*開關將所用的資源映射到具體引腳上。分析如下:
如果沒有用到任何資源,那么所有25個引腳都可以作為正常的并行引腳使用,若用到數(shù)字資源,必須犧牲一部分并行口,將引腳提供給內(nèi)部資源使用。假設有A、B、C三種資源,所需要的引腳數(shù)分別為2、1、3。
1、如果ABC都不用,那么可以正常使用P0、P1、P2以及P3.0
2、如果使用A資源,那么將會占用P0.0、P0.1,其余引腳照樣可以作為并行口用,但是被占用的口無法控制
3、如果同時使用ABC資源,則需要6個腳,故P0口只剩下P0.6、P0.7可用,其他口不受影響
以上只是大概意思,不精確。以下為詳細筆記。
一、寄存器
P0口有P0MDIN、P0MDOUT、P0SKIP三個控制寄存器,同理P1、P2都有,P3沒有SKIP
PxMDIN:設置對應并行端口是否作為模擬輸入,“0”表示模擬輸入。當任意引腳作為模擬輸入時,不能作為IO口受到控制
PxMDOUT:設置對應并行端口為漏極開路或推挽,“0”表示開漏。開漏時只能輸出低電平或高阻,若需要輸出高電平,需要另外加上拉電阻,其電流小于推挽。不過實測還沒感覺出開漏與推挽的區(qū)別,待查。
PxSKIP:用來保護特定的引腳不被內(nèi)部資源使用。為“1”時,表示該引腳被跳過。本來內(nèi)部數(shù)字資源是按照優(yōu)先級列表按順序占用并行端口,如果某個腳你希望留下來自己用,那么可以設置為“1”,那么該腳必然不被占用,可以作為正常的IO口。
二、交*開關
寄存器XBR0、XBR1用來分配引腳給內(nèi)部數(shù)字資源,收到PxSKIP寄存器的影響,分配優(yōu)先級見下圖:
三、實測細節(jié)
準備工作:
1、P0口連接八個發(fā)光二極管,P1.0連接觸點開關,P1.1~P1.7連接7個發(fā)光二極管。
2、編程,首先令PxMDIN=FF,PxMDOUT=FF。再令PxSKIP=0,但P1.0例外,跳過,否則沒法測試
main函數(shù)的作用是開關控制所有的燈,按下全亮,松開全暗。
*XBR1的D6必須等于1,要不所有引腳全都不受控。
評論