当前位置: 首页 > news >正文

51单片机:电脑通过串口控制LED亮灭(附溢出率和波特率详解)

一、功能实现

1.电脑通过串口发送数据:0F

2.点亮4个LED

二、注意事项

1.发送和接受数据的文本模式

2.串口要对应

3.注意串口的波特率要和程序中的波特率保持一致

4.有无校验位和停止位

三、如何使用串口波特率计算器

1.以本程序为例

2.生成代码如下

void Uart1_Init(void)	//9600bps@11.0592MHz
{SCON = 0x50;		//8位数据,可变波特率AUXR |= 0x40;		//定时器时钟1T模式AUXR &= 0xFE;		//串口1选择定时器1为波特率发生器TMOD &= 0x0F;		//设置定时器模式TL1 = 0xE0;			//设置定时初始值TH1 = 0xFE;			//设置定时初始值ET1 = 0;			//禁止定时器中断TR1 = 1;			//定时器1开始计时
}

3.需要手动配置中断系统

根据原理图

配置代码
	//手动配置中断系统ES=1;EA=1;PS=0;

四、如何理解软件生成的波特率

void UART_Init()			
{//由软件自动生成SCON=0x50;				//STC89C52操作手册P235方式1PCON &= 0x7F;			//波特率不倍速TMOD &= 0x0F;			//设置定时器1模式TMOD |= 0x20;			//设置定时器1模式TL1 = 0xFA;			//设置定时初始值TH1 = 0xFA;			//设置定时重载值ET1 = 0;			//禁止定时器中断TR1 = 1;			//定时器1开始计时//需要手动配置中断系统ES=1;EA=1;PS=0;
}

以上述代码为例子进行分析

    由于配置是8位自动重载,TL1=TH1=0xFA ,0xFA=250;
    总计八位,那么数据范围0~255(256溢出)
    256-250=6
    那么每计6个数溢出一次
    晶体振荡器的输出经12 分频后得到输入的时钟脉冲
    一个机器周期内有12 个振荡周期。故其频率为晶振频率的1/12。
    此设备是11.0592M 的晶振,1.085μs为一个输入脉冲的时间
    则6.51μs溢出一次
    1/6.51,则0.1536098MHz就是定时器的溢出率
    再看PCON=0111 1111
    可知SMOD=0(参考串口模式图)
    那么波特率=0.1536098MHz   /2  /16
    波特率为0.00480030625MHz约等于4800Hz
    约等于没有误差

串口模式图

五、如何计算波特率

参考STC89C52手册P235

六、串口中断函数

中断函数(函数可自由命名,但是要加上中断号"interrupt 4")

void UART_Routine(void) interrupt 4      
{if (TI==1)				//检测串口1发送中断{//功能......TI = 0;			//清除串口1发送中断请求位}if (RI==1)				//检测串口1接收中断{//功能......RI = 0;			//清除串口1接收中断请求位}
}

中断函数查询表P166

七、模块化代码:

1.main.c

#include <REGX52.H>
#include "UART.h"unsigned char Sec=0;void main()
{UART_Init();while(1){}}/*** @brief  中断函数查询P166,函数命名可自由,但是要更上中断号"interrupt 4"* @param  无* @retval 无*/
void UART_Routine(void) interrupt 4      
{if(RI==1){P2=~SBUF;RI=0;}
}

2.UART.c

#include <REGX52.H>/*** @brief  串口初始化//4800bps@11.0592MHz* @param  无* @retval 无*/void UART_Init()			
{SCON=0x50;				//STC89C52操作手册P235方式1PCON &= 0x7F;			//波特率不倍速TMOD &= 0x0F;			//设置定时器1模式TMOD |= 0x20;			//设置定时器1模式TL1 = 0xFA;			//设置定时初始值TH1 = 0xFA;			//设置定时重载值ET1 = 0;			//禁止定时器中断TR1 = 1;			//定时器1开始计时//补上中断系统ES=1;EA=1;PS=0;
}/*** @brief  串口发送一个字节的数据* @param  Byte  要发送的一个字节数据* @retval 无*/void UART_SendByte(unsigned char Byte)
{SBUF=Byte;while(TI==0);			//TI=0,数据完整发送出去,TI=1,跳出循环TI=0;			//TI=0,使用软件复位}

3.UART.h

#ifndef __UART_H__
#define __UART_H__void UART_Init();void UART_SendByte(unsigned char Byte);#endif

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • SVN 解决冲突
  • 《算法笔记》总结No.6——贪心
  • Elasticsearch:Node.js ECS 日志记录 - Morgan
  • 【全面介绍语言模型的原理,实战和评估】
  • 使用Python绘制气泡图
  • 共话未来 | 人大金仓即将亮相TDBC 2024可信数据库发展大会
  • linux_进程概念——理解冯诺依曼体系结构
  • C基础day8
  • 微软推出全新的学习网站 Microsoft Learn
  • wifi模组Ai-M62-32S的IO映射和UDP透传测试
  • LAZYNVIM学习使用笔记
  • 构造函数语意学(The Semantics of Constructors)
  • Mybatis之动态sql、缓存、分页、配置数据源
  • 防御笔记第四天(持续更新)
  • 最优化(10):牛顿类、拟牛顿类算法
  • Android组件 - 收藏集 - 掘金
  • Angularjs之国际化
  • HashMap ConcurrentHashMap
  • iOS高仿微信项目、阴影圆角渐变色效果、卡片动画、波浪动画、路由框架等源码...
  • maven工程打包jar以及java jar命令的classpath使用
  • Python学习之路13-记分
  • React Native移动开发实战-3-实现页面间的数据传递
  • SegmentFault 2015 Top Rank
  • Web Storage相关
  • 阿里云购买磁盘后挂载
  • 经典排序算法及其 Java 实现
  • 前端每日实战:70# 视频演示如何用纯 CSS 创作一只徘徊的果冻怪兽
  • 远离DoS攻击 Windows Server 2016发布DNS政策
  • 你对linux中grep命令知道多少?
  • ​油烟净化器电源安全,保障健康餐饮生活
  • # .NET Framework中使用命名管道进行进程间通信
  • # Pytorch 中可以直接调用的Loss Functions总结:
  • #我与Java虚拟机的故事#连载12:一本书带我深入Java领域
  • $HTTP_POST_VARS['']和$_POST['']的区别
  • (2024)docker-compose实战 (9)部署多项目环境(LAMP+react+vue+redis+mysql+nginx)
  • (22)C#传智:复习,多态虚方法抽象类接口,静态类,String与StringBuilder,集合泛型List与Dictionary,文件类,结构与类的区别
  • (web自动化测试+python)1
  • (ZT)薛涌:谈贫说富
  • (纯JS)图片裁剪
  • (二十五)admin-boot项目之集成消息队列Rabbitmq
  • (附源码)php新闻发布平台 毕业设计 141646
  • (一)springboot2.7.6集成activit5.23.0之集成引擎
  • (原創) 如何解决make kernel时『clock skew detected』的warning? (OS) (Linux)
  • (转)Linux NTP配置详解 (Network Time Protocol)
  • (轉貼) 寄發紅帖基本原則(教育部禮儀司頒布) (雜項)
  • **PHP分步表单提交思路(分页表单提交)
  • .chm格式文件如何阅读
  • .halo勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复
  • .L0CK3D来袭:如何保护您的数据免受致命攻击
  • .mysql secret在哪_MYSQL基本操作(上)
  • .NET 8.0 中有哪些新的变化?
  • .NET CLR Hosting 简介
  • .Net IE10 _doPostBack 未定义
  • .net mvc actionresult 返回字符串_.NET架构师知识普及
  • .NET Windows:删除文件夹后立即判断,有可能依然存在