【Proteus仿真】51单片机串口接收实验

【Proteus仿真】51单片机串口接收实验


  • 📌相关篇《【Proteus仿真】51单片机串口输出实验

  • 🔖Proteus仿真基础实验-串口单字符接收打印

  • 🌿Proteus8.12平台

  • 🌿本实验代码基于VSM Studio,采用SDCC编译器。

  • 🌿调试串口波特率:9600

  • 🎬仿真实验演示:
    在这里插入图片描述

🏳‍🌈配置条件

🔨需要安装虚拟串口工具,并创建2个虚拟端口:
在这里插入图片描述

🏳‍🌈注意事项

  • ⚡针对字符串数据接收,需要根据所设定的波特率,计算好位处理时间并在数据响应第一个接收数据时,设定好数据长度和计算好相对应的延时时间。
波特率为9600表示的是串口每秒钟可以传输9600bit,每传输1bit所需时间:
1 s / 9600 b i t = 1000000 ( u s ) / 9600 ( b i t ) = 1000 / 9.6 = 104.1667 u s 1s/9600bit = 1000000(us)/9600(bit) =1000/9.6 =104.1667us 1s/9600bit=1000000(us)/9600(bit)=1000/9.6=104.1667us
那么8bit就是 104.16678 = 833.3336us 104.1667*8 =833.3336us 104.16678=833.3336us
实际项目中,串口通信时数据格式是:起始位+8位数据+奇偶校验位+停止位 ,一般都没有奇偶校验位,所以是10位
也就是一个字节的时间为 104.166710 = 1041.667us 104.1667*10 =1041.667us 104.166710=1041.667us

📝实验代码一

  • ✨本示例实现的是单字节数据接收,并打印。
/* Main.c file generated by New Project wizard
 *
 * Created:   周一 5月 22 2023
 * Processor: 80C52
 * Compiler:  SDCC for 8051
 */

#include <8052.h>
//#include <stc89.h>
#include <stdio.h>

#define FOSC 11059200UL      //System frequency
#define BAUD 9600           //UART baudrate

typedef unsigned char uchar;

#define LED P2_1

void uart_init()
{
    SCON = 0x50;
    TMOD = 0x20;
 //  TH1 = 0xFD;//波特率9600
 //   TL1 = 0xFD;
	TH1 = (unsigned char)(((65536 - (FOSC/32/BAUD) )>>8)  - 2) ; 
	TL1 =  (unsigned char)(65536- (FOSC/32/BAUD)  - 2) ;
    TR1 = 1;       //Timer1 start run
    ES = 1;                 //Enable UART interrupt
	EA = 1;
}

unsigned char serialReceiveByte()
{
		while(RI == 0);
		RI=0;
		return SBUF;
}

void SendData(uchar data1)
{
    SBUF = data1;
    while (!TI) ;
    TI = 0;
}

void SendString(uchar *buffer)
{
    unsigned char *p = buffer;
    while (*p)
    {
        SendData(*p);
        p++;
    }
}
void delayms(unsigned int ms)
{
        unsigned int x, y;
 
        for (y = ms; y > 0; y--) {
                for (x = 227; x > 0; x--);
        }
}
void main(void)
{

    unsigned char buf;
    uart_init();
    SendString("Hello world!\r\n");

    while (1)
    {
		buf = serialReceiveByte();
        SendString("recv data: ");
		SendData(buf);
		SendString("\r\n");
}
}

📚实验一资源

链接: https://pan.baidu.com/s/1ACi5_Q3CqrCfycNKREzsZg
提取码: 6g2u

📑实验二

  • ✨本示例实现的是字符串数据接收,并打印。
  • 🔖所定义的接收字符串数组长度为8,限定接收字符串对象的长度为8,串口接收中断响应到数据接收完成等待的最小延时时间:1042us * 8
    在这里插入图片描述
/* Main.c file generated by New Project wizard
 *
 * Created:   周六 5月 20 2023
 * Processor: 80C52
 * Compiler:  SDCC for 8051
 */
//#include <mcs51reg.h>
#include <8052.h>
//#include <stc89.h>
#include <stdio.h>

#define FOSC 11059200UL      //System frequency
#define BAUD 9600           //UART baudrate

typedef unsigned char uchar;

 uchar BUF[8] = "";
static uchar cnt = 0;
__bit Rece_flag = 0;


#define LED P2_1

void uart_init()
{
    SCON = 0x50;
    TMOD = 0x20;
 //  TH1 = 0xFD;//波特率9600
 //   TL1 = 0xFD;
	TH1 = (unsigned char)(((65536 - (FOSC/32/BAUD) )>>8)  - 2) ; 
	TL1 =  (unsigned char)(65536- (FOSC/32/BAUD)  - 2) ;
    TR1 = 1;       //Timer1 start run
    ES = 1;                 //Enable UART interrupt
	EA = 1;
}

void USART_ISR (void) __interrupt 4 __using 1
{
	
	if(RI){		
    BUF[cnt] = SBUF;
		RI=0;
		cnt++;
		Rece_flag = 1;//接收标志位
		}
}
void SendData(uchar data1)
{
    SBUF = data1;
    while (!TI) ;
    TI = 0;
}

void SendString(uchar *buffer)
{
    unsigned char *p = buffer;
    while (*p)
    {
        SendData(*p);
        p++;
    }
}

void delayms(unsigned int ms)
{
        unsigned int x, y;
        for (y = ms; y > 0; y--) {
                for (x = 227; x > 0; x--);
        }
}

void main(void)
{
	uchar i = 0;
    uart_init();
    SendString("Hello world!\r\n");

    while (1)
    {
		if(Rece_flag)
		{
		delayms(10);	//这个延时时间是,等待字符串接收完成1BYTES=1041.667us
        SendString("recv data: ");
		SendString(BUF);
		SendString("\r\n");
		for(i=0;i<8;i++)
		{
			BUF[i] = 0;	//清空字符串
		}

		cnt = 0;
		Rece_flag = 0;

		}
	}
}

📚示例二仿真资源


链接: https://pan.baidu.com/s/1s76SyCfhh_eFrz2yepjxFQ
提取码: fk1u
  • 0
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1.基本任务 (1)已知甲机接 8 个开关,乙机接 8 个发光二极管,利用它们的串口方式 1,波 特率自定义,实现:将甲机中 8 个开关所代表的数据传送到乙机,并在乙机的 8 个 LED 灯显示。请在 Proteus 中画出电路原理图,并编写程序仿真实现上述功能。 (2)已知单片机的 P0 口接了 8 个发光二极管 LED0~LED7,现要求通过单片机的 串口收发上位机的命令,实现对这 8 个发光二极管的控制。PC 端采用串口调试程序进 行数据发送(如使用 stc-isp 烧写软件向单片机发送“88 FB AF XX FC FC”6 个字节的 命令,其中“88 FB AF”及“FC FC”为数据的帧头和帧尾,“XX”为 00~07 数据。 )单片机 使用串口中断进行数据接收,同时需要判断帧头和帧尾的正确性。判断帧头和帧尾完毕 后,若正确的话再判断“XX” 数据,对应“XX” 数据对 LED0~LED7 进行点亮、熄灭控 制;若不正确丢掉数据, 转入等待接收。 请在 Proteus 中画出电路原理图,并编写程 序仿真实现上述功能。 2.拓展任务 在以上基本任务 1 的基础上,奇校验,实现甲机和乙机的全双工通信,即甲机和乙 机都分别接 8 个开关和 8 个发光二极管,甲机 8 个开关所代表的数据能传送到乙机并在 乙机的 8 个 LED 灯显示,同时乙机 8 个开关所代表的数据能传送到甲机并在甲机的 8 个 LED 灯显示,若校验出错则指示灯(自定义)闪烁。请在 Proteus 中画出电路原理图, 并编写程序仿真实现上述功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值