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;//执行完成复位
}