串口发送指定命令点灯

#include <REGX52.H>
#include <string.h>
#define size 12
sfr AUXR=0x8E;
sbit D5=P2^1;
char cmd[12];
	
void UartInit1(void)		//9600bps@11.0592MHz
{
	PCON &= 0x7F;		//波特率不倍速
	SCON = 0x50;		//8位数据,可变波特率
	AUXR &= 0xBF;		//定时器1时钟为Fosc/12,即12T
	AUXR &= 0xFE;		//串口1选择定时器1为波特率发生器
	TMOD &= 0x0F;		//清除定时器1模式位
	TMOD |= 0x20;		//设定定时器1为8位自动重装方式
	TL1 = 0xFD;		//设定定时初值
	TH1 = 0xFD;		//设定定时器重装值
	ET1 = 0;		//禁止定时器1中断
	TR1 = 1;		//启动定时器1
}

void UartInit(void)		//9600bps@11.0592MHz
{
	AUXR=0x01;//抗干扰能力
	SCON = 0x50;//配置串口工作方式,REN使能接受
//	PCON
	TMOD &= 0xF0;
	TMOD|=0x20;//定时器1工作方式为8为自动重装
	
	TH1=0xFD;//9600波特率初值
	TL1=0xFD;
	TR1=1;//启动定时器

	EA=1;//开启总中断
	ES=1;//开启串口中断
	
}


void Delay1000ms()		//@11.0592MHz
{
	unsigned char i, j, k;

	i = 8;
	j = 1;
	k = 243;
	do
	{
		do
		{
			while (--k);
		} while (--j);
	} while (--i);
}

void Delay10ms()		//@11.0592MHz
{
	unsigned char i, j;

	i = 18;
	j = 235;
	do
	{
		while (--j);
	} while (--i);
}


void sendByte(char data_msg)
{
	SBUF=data_msg;
	while(TI==0);//串行发送数据第8位结束时,由内部硬件自动置位,即TI=1
	TI=0;
}

void sendString(char* str)
{
	while( *str!='\0' )
	{//对于字符型数组来说,最后一位为\0,字符串结束标志
	sendByte(*str);//*解引用运算
	str++;//指针偏移
	}
}

void main()
{

	D5=1;

	//配置C51的串口通信方式
	UartInit();
	
	while(1)
	{
		Delay1000ms();
		//往发送缓冲区写入数据,就完成数据的发送
		sendString("hello world\r\n");//\r\n位对齐	
	
	}
	
}

void Uart_Handler() interrupt 4

{
	static int i=0;//静态变量被初始化一次
	if(RI)//接受中断处理函数,对于接受中断的响应
	{
		RI=0;
		cmd[i]=SBUF;
		i++;
		if(i==size)
		{
			i=0;
			
		}
		
		if(strstr(cmd,"en"))
		{
			D5=0;
			i=0;
			memset(cmd,'\0',size);
		}
		if(strstr(cmd,"cl"))
		{
			D5=1;
			i=0;	
			memset(cmd,'\0',size);
		}
	
	}

	if(TI);
		
	
}

今天有点困了,明天再详细说明吧

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值