【【51单片机串口向电脑发送数据以及电脑通过串口控制LED】】

51单片机串口向电脑发送数据以及电脑通过串口控制LED

首先我们一起先对串口进行分析
在这里插入图片描述
SM0/FE用来设置FE一听名字就是判断错误的 没有错误就用两位来设置
4种不同的工作状态
但他不使用FE
开始SM0时就和SM1一起组成了状态选择
在这里插入图片描述
因为我们最常用的是模式1 所以SM0选0 SM1选1
接下来看SM2:因为我们讲的是模式1 所以模式 2 3就暂时不用去管它
REN:如果REN=1允许接受,如果REN=0 ,禁止接受
TB8:
RB8:
这两个都是在模式2 模式3 的时候用法,我们这里主要考虑模式1 所以不用这个
T1这个位是用来判断是否发送完毕的,如果发送完毕那么就置为1,没发送完还是0,但是必须及时使用软件复位
在这里插入图片描述
0x40
在这里插入图片描述

这里的有两位是
SMOD:波特率选择位
SMOD=1,波特率加倍。
SMOD=0,波特率不加倍
SMOD0:它主要的作用是控制SM0/FE 是用来检测FE的还是SM0
在这里插入图片描述
设置完上述的SCON 和PCON之后继续设置IE等等,但是这些都是关于中断的,我们不必配置后续
所以来说,大部分已经配置完毕了
在这里插入图片描述
大部分已经配置完成了
但是为了修改波特率需要对定时器进行修改
所以再代码块中加入定时器模块
定时器
因为我们在这里用的定时器1而我们之前却对定时器0进行过分析 所以现在先把代码复制过来然后对全局进行修改

 TMOD &= 0xF0;        //设置定时器模式
TMOD |= 0x01;        //设置定时器模式
TL0 = 0x18;        //设置定时初值
TH0 = 0xFC;        //设置定时初值
TF0 = 0;        //清除TF0标志
TR0 = 1;        //定时器0开始计时
ET0=1;
EA=1;
PT0=0;
因为先用定时器1所以先把TMOD 置为0x0F  然后是对工作模式进行合理的判定

另外对于工作模式也有所不同
我们在实现第一个操作的时候,工作模式置于0 1 16位定时器
而串口有专用的模式M1 M0 1 0 的8位自动重装载定时器
分析8位自动重装
16 位有2个8位 这样计0~65535
双八位是这样的概念 都叫自动重装 肯定牺牲 了计数大这一优势,方便我们自动重装 我们用一半的8位进行计数,用另一半的位数进行记录初值,当计数完成后AR会自动赋初值给CNT,不用代码处理,运行速度很快,但是计数值会变小
所以我们在这里只是把模式改成双8位
在这里插入图片描述

    SCON=0x40;
PCON &= 0x7F;        //波特率不倍速
        TMOD &= 0x0F;        //设置定时器模式
    TMOD |= 0x20;        //设置定时器模式//
    //我在照抄以后根据我们所需的情况,改成了使用定时器1和模式1 0 这种情况
    TL1 = 0xFA;        //设定定时初值
    TH1 = 0xFA;        //设定定时器重装值
    ET1 = 0;        //禁止定时器1中断
    TR1 = 1;        //启动定时器1

在这里插入图片描述

void UART_SendByte(unsigned char Byte)
{
    SBUF=Byte;//直接在SBUF写入需要的东西
while(TI==0);
    TI=0;//执行完成复位
}
void main()
{
    UART_Init();
    UART_SendByte(0x66);
    while(1)
    {
        
    
    }    
    
}
下面是串口向电脑发送数据的全部代码
/main,c
#include <REGX52.H>
#include"Delay.h"
#include"UART.h"
unsigned char Sec;//全局变量初始值为0 
void main()
{
    UART_Init();
    while(1)
    {
        UART_SendByte(Sec);
        Sec++;
        Delay(1000);    
    }    
    
}

//UART.c
#include <REGX52.H>



//串口初始化
//串口发送一个字节的数据
//UART_SendByte(里面填写东西)
//





void UART_Init()//4800bps@11.0592MHz
{
    SCON=0x40;
PCON &= 0x7F;        //波特率不倍速
        TMOD &= 0x0F;        //设置定时器模式
    TMOD |= 0x20;        //设置定时器模式//
    //我在照抄以后根据我们所需的情况,改成了使用定时器1和模式1 0 这种情况
    TL1 = 0xFA;        //设定定时初值
    TH1 = 0xFA;        //设定定时器重装值
    ET1 = 0;        //禁止定时器1中断
    TR1 = 1;        //启动定时器1

}
void UART_SendByte(unsigned char Byte)
{
    SBUF=Byte;//直接在SBUF写入需要的东西
while(TI==0);
    TI=0;//执行完成复位
}

//UART.h
#ifndef __UART_H_
#define __UART_H_

void UART_Init();//4800bps@11.0592MHz
void UART_SendByte(unsigned char Byte);
#endif
/

接下来完成下一个代码电脑通过串口控制LED
首先我们并不会知道电脑会什么时候发过来 ,当我们启动之后,我们可以引入一个中断 串口中断 在整个中断中完成对数据的实现和处理
把串口中断打开
配置完ES EA
EA是所有中断
ES是串口中断
TH1 = 0xFA; //设定定时器重装值
0xFA 在十进制下是250
256-250=6就是每隔6溢出
1/6微妙 就是T1的溢出率
0.1667MHZ/16=0.01041这就是波特率


数据显示模式 以原始数据的形式显示
主要是还有ASIC 种种文本会显示ASIC码值 HEX还有字符形式
慢慢思考
仅仅修改main,c即可

#include <REGX52.H>



//串口初始化
//串口发送一个字节的数据
//UART_SendByte(里面填写东西)
//





void UART_Init()//4800bps@11.0592MHz
{
	SCON=0x50;
PCON &= 0x7F;		//波特率不倍速
		TMOD &= 0x0F;		//设置定时器模式
	TMOD |= 0x20;		//设置定时器模式//
	//我在照抄以后根据我们所需的情况,改成了使用定时器1和模式1 0 这种情况
	TL1 = 0xFA;		//设定定时初值
	TH1 = 0xFA;		//设定定时器重装值
	ET1 = 0;		//禁止定时器1中断
	TR1 = 1;		//启动定时器1
	EA=1;//启动所有中断
	ES=1;//启动串口中断

}
void UART_SendByte(unsigned char Byte)
{
	SBUF=Byte;//直接在SBUF写入需要的东西
while(TI==0);
	TI=0;//执行完成复位
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值