实验芯片:Microchip PIC 18F4550
集成开发环境:MPLAB IDE v8.53
编译器:Microchip C18
单片机和外设的交互都是经过I/O端口进行,每个I/O端口均有三个操作存放器:
1、TRISx———数据方向存放器
用来操控I/O引脚的方向,即用来操控PORTx是输入仍是输出。
2、PORTx——— 端口存放器
用来锁存输出数据。当读PORTx时,器材直接读I/O引脚电平(而不是锁存值)。
3、LATx——— 输出数据锁存器
写端口便是写该锁存器(LATx)。数据锁存器也能够直接读写。假如外设没有运用该引脚,并且TRISx位装备该引脚为输出,则将锁存器内的数据输出到引脚。
在复位状况下,TRISx的复位值为0xff,即TRISx存放器的8个位(D0 ~ D7)的值均为1。此刻相应的PORTx引脚被界说为输入,相应的输出驱动器呈现高阻状况。设置为0时表明相应的引脚界说为输出。
这儿应留意的是写PORT便是写LAT,但读PORT和读LAT不同。读PORT读的是引脚的状况,不管该引脚设置为输入引脚仍是输出引脚。而读LAT得到的是输出数据锁存器的存储值,读LAT得到的值或许和读PORT得到的值存在不同。
在Microchip C18中,I/O端口三个操作存放器能够按位(bit)操作,也能够按字节(byte)操作。
如端口B的方向存放器用TRISB(或DDRB)表明,某一位用TRISBbits.TRISB0(或DDRB bits.RB0)表明。字节用TRISB(或DDRB)表明。
如端口B的PORT存放器用PORTB表明,某一位用PORTBbits.RB0表明。字节用PORTB表明。
如端口B的输出数据锁存器用LATB表明,某一位用LATBbits.LATB0表明。字节用LATB表明。
因为芯片复位后,LATx(PORTx)锁存器的值是随机的,为了扫除I/O引脚电平呈现毛刺的或许性,在初始化端口时,首要初始化该PORT的数据锁存器(LAT或PORT存放器),然后再初始化数据方向存放器TRIS。
下面用一个实例阐明一下详细使用,下图PIC18F4550与电源、晶振和发光二极管组成一个最简略的8位单片机体系,要求一起点亮8个发光二极管。
首要能够挑选按位操作的办法完成。不难看出,按位操作实践不是真实完成一起点亮与PORTB相连的8个发光二极管,仅仅发光二极管发光的延时效应掩盖了顺次点亮的现实,使得终究作用达到了一起点亮。以下是按位操作方法的完成代码。
#include
void main(void)
{
PORTBbits.RB0=1;
TRISBbits.TRISB0=0;//点亮第1个LED
PORTBbits.RB1=1;
TRISBbits.TRISB1=0; //点亮第2个LED
PORTBbits.RB2=1;
TRISBbits.TRISB2=0; //点亮第3个LED
PORTBbits.RB3=1;
TRISBbits.TRISB3=0; //点亮第4个LED
PORTBbits.RB4=1;
TRISBbits.TRISB4=0; //点亮第5个LED
PORTBbits.RB5=1;
TRISBbits.TRISB5=0; //点亮第6个LED
PORTBbits.RB6=1;
TRISBbits.TRISB6=0; //点亮第7个LED
PORTBbits.RB7=1;
TRISBbits.TRISB7=0; //点亮第8个LED
while(1);
}
其次能够按字节操作来完成,代码比按位操作要简略许多,并且真实完成了一起点亮的要求。以下是按字节操作方法的完成代码。
#include
void main(void)
{
PORTB=0xff;
TRISB=0x00;//点亮8个LED
while(1);
}