#include <AT89X52.H>
#define uchar unsigned char
#define uint unsigned int
#define port_count P2//P2接8LED接口
//将计数器的二进制值用8个LED显示出来
uchar count//计数器(存储中断次数)
void main(void)
{
count=0//清零计数器
port_count=~count//清零P2口
IT0=1 //INT0设为边沿触发方式�IT0=0则为电平触发方式
EX0=1 //开INT0中断
EA=1 //开系统中断
while(1)//等待中断处理
}
//INT0中断处理函数
void int0_interrupt() interrupt 0 //INT0中断号0
{
count++
port_count=~count //当达到255时,溢出,又从0开始
}
I/O控制程序:
#include <AT89X52.H>
#include <intrins.h>
#define uchar unsigned char
#define uint unsigned int
#define flowlight P2
void delay10ms()
{uchar a,b
for(a=200a>0a--)
for(b=225b>0b--)
}
void main()
{
uchar flag=0//判断移动方向 flag==0 左移 flag==1 右移
uchar port_state=0x01
flowlight=~port_state
while(1)
{
delay10ms()
if(port_state==0X80&&flag==0)
{
flag=1 //流水灯左移到第八位又移回来 ~1000 0000
}
else
if(port_state==0X01&&flag==1)
{
flag=0 //流水灯右移到第1位又移回来 ~0000 0001
}
if(flag==0)
{
port_state=port_state<<1
flowlight=~port_state
}
else
{
port_state=port_state>>1
flowlight=~port_state
}
}
串口通信程序:
主机程序:
#include <AT89X52.H>
#define NODE_ADDR 3 //目的节点地址
#define COUNT 10 //发送缓冲区buffer大小
typedef unsigned char uchar
uchar buffer[COUNT] //定义buffer
int pt //设置指针
main()//////////////////////////////////////////发送程序
{
//buffer初始化
pt=0
while(pt<COUNT)
{
buffer[pt]='1'+pt //[buffer]=0X31,[buffer+1]= 0X32,[buffer+2] 0X33........
pt++
}
////初始化串口和T1(波特率发生器)/////////PCON缺省为0
PCON=0X00
SCON=0Xc0 //SCON=1100 0000B,置串口为方式3, SM2=0,REN=0,主机不接收地址帧
TMOD=0X20 //20H=0010 0000B,置T1为方式2,TR1控制T1的开关,定时器方式
TH1=253TL1=253 //方式2为自动重装///f(bps)=9600bps (f(osc)=11.0592MHZ)
TR1=1 //启动T1
ET1=0 //关T1中断 由于自动重装
ES=1 //开串口中断
EA=1 //开系统中断
pt=0
///////////////发送地址帧
TB8=1 //地址帧标志
SBUF=NODE_ADDR //发送目的节点地址
while(pt<COUNT) //等待发送完全部数据
while(1)//不执行任何 *** 作
} //end main
/////发送完中断函数
void send()interrupt 4
{
TI=0 //清发送中断标志
if(pt<COUNT)
{
//发送一帧数据
TB8=0//数据帧标志
SBUF=buffer[pt] //启动发送
pt++//指针指向下一单元
}
else
{
ES=0 //关串口中断
EA=0 //关系统中断
return //若发送完则停止发送并返回
}
}
接收程序:
#include<reg52.h>
#define uchar unsigned char
#define NODE_ADDR 3 //本机节点地址
#define COUNT 10 //定义接收缓冲区buffer大小
uchar buffer[COUNT] //定义buffer
int pt //当前位置指针
void send_char_com(unsigned char ch) //向串口发送一个字符的函数声明
void delay(void)
main() ////////////////串行异步从机接收程序
{
PCON=0X00 //初始化串口和T1(波特率发生器)/////////PCON缺省为0
SCON=0XF0 //SCON=1111 0000B,方式3,SM2=1,REN=1,允许接收地址帧
TMOD=0X20 //20H=0010 0000B,置T1为方式2,TR1控制T1的开关,定时器方式
TH1=253TL1=253 //方式2为自动重装///f(bps)=9600bps (f(osc)=11.0592MHZ)
TR1=1 //启动T1
ET1=0 //关T1中断 由于自动重装
ES=1 //开串口中断
EA=1 //开系统中断
pt=0
while(pt<COUNT) //等待接收地址帧和全部数据帧
delay()
//接收完后返回数据
SCON=0XC0 //SCON=1100 0000B,置串口为方式3, SM2=0,REN=0,主机不接收地址帧
EA=0
for(pt=0pt<COUNTpt++)
{
send_char_com(buffer[pt])
}
while(1)
} //end main
///////////串口接收中断函数
void receive()interrupt 4 using 3
{
RI=0 //清除接收中断标志
if(RB8==1) //地址帧
{//若为本机地址,则置SM2=0,以便接收数据
if(SBUF==NODE_ADDR)
{
SM2=0
}
}
/////RB8=0,数据帧
else if(RB8==0)
{buffer[pt]=SBUF //数据帧送buffer
pt++
if(pt>=COUNT)
SM2=1 //若接收完全部数据帧,则通信结束置SM2=1,准备下一次通信
}
}
//向串口发送一个字符
void send_char_com(unsigned char ch)
{
SBUF=ch
while(TI==0)
TI=0
}
///////////////////////////////////////////////////////////////////////////////////
void delay(void)
{uchar i=100
while(i--)
}
MOV DPTR, #ASC_TABMOV A, HEX
MOVC A, @A+DPTR
MOV HEX, A
SJMP $
ASC_TAB:
DB 30H, 31H, 32H, 33H, 34H, 35H, 36H, 37H, 38H, 39H
DB 41H, 42H, 43H, 44H, 45H, 46H
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)