【中颖】SH79F9202 串口通信

2024-06-09 11:20
文章标签 通信 串口 中颖 sh79f9202

本文主要是介绍【中颖】SH79F9202 串口通信,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述


头文件 uart.h

#ifndef UART_H
#define UART_H#include "SH79F9202.h"
#include "LCD.h"
#include "timer2.h"
#include "timer5.h"
#include "cpu.h"
#include "key.h"
#include "io.h"
#include "intrins.h"extern volatile unsigned char RecBuf[8]; // 用于存储接收到的数据
extern volatile unsigned char UART0RecBytecount;        // 数据索引
extern volatile unsigned char UART0_Receive_OverTimer;extern volatile unsigned char SendBuf[8];void UART_Init(void);
unsigned char CheckSum(unsigned char *ptr,unsigned char len);
void UART0_Decode(void);void UART0_SendByte(unsigned char byte);
void UART0_SendPacket(unsigned char* dat, unsigned char length);#endif

源文件 uart.c



参考资料

  • [1] SH79F9202 10位ADC + LCD的增强型8051微控制器用户手册
  • [2] STM32入门笔记(02):USART串口通信注意事项笔记(SPL库函数版)

#include "uart.h"#define SELBANK0		INSCON &= 0xBF  // INSCON (-0-- 11-1)  选择特殊功能寄存器页0
#define SELBANK1		INSCON |= 0x40  // INSCON (-1-- 11-1)  选择特殊功能寄存器页1#define SYSCLK			24000000  // 系统时钟24M
#define BAUDRATE		9600      // 波特率为自带波特率发生器溢出率的1/16
#define SBRTHINIT   32768-(SYSCLK/16/BAUDRATE)    // 波特率发生寄存器
#define SFINE1INIT	SYSCLK/BAUDRATE-16*SBRTHINIT // 波特率微调#define UARTOVERTIME 2						//这个常量是考虑用中断接收,接收的数据长度还不确定的情况。//当检测到多长时间没有接收中断发生以后,就认为是接收数据结束,需要进行解码。//一般在定时中断里面处理。因定时中断和UART中断同步问题,使用时需要留有余量,//取值:当定时器的中断时间大于UART传送一个字节的时间最少是2。当定时器中断时间少于UART发送一个字节的时间时,取值最少因满足UART传送2个字节的时间//定义UART接收数据的最大长度,当接收到数据达到此长度时意味着接收数据已经占满接收缓冲区,此时不管还有无数据接收到都需要进行解码。
//#define UARTRECLENGMAX0	 16				//意义同上void UART_Init(void){SELBANK0;						//切换到bank0UTOS = 0x00;		   // TTL逻辑选择寄存器(CMOS逻辑) RxD(P1.7/P4.0)
=====================串口UART1=====================================
//		P1CR &=0x7F;				//P1.7 input mode RxD1
//		P1CR|= 0x40;				//P1.6 TxD1 output mode
//		P1_7 = 1;
//		P1_6 = 1;
		P1PCR |= 0xC0;			//P1.7 P1.6 上拉打开
//		P1PCR |= 0x80;   // P1.7 输入 开启上拉
//		P1PCR &= 0xbf;   // P1.6 输出 关闭上拉
//		P1SS &= 0x3F;				//将P1.7(SEG5)和P1.6LCD(SEG6)的SEG功能关闭
=====================串口UART0=====================================P3CR |= 0x80;				// P3.7 output TxD0P3_7 = 1;           // 默认为高
//		P3PCR |= 0x80;P3PCR &= 0x7f;  // 输出 关闭上拉P3SS &= 0x7F;				//将P3.7 LCD的SEG功能关闭P4CR &= 0xFE;			//P4.0 input RxD0P4_0 = 1;P4PCR |= 0x01;  // 输入 开启上拉P4SS &= 0xFE;				//将P4.0 LCD的SEG功能关闭
//===========================UART0===============================//EUART0控制及状态寄存器 SCON = 0x50;				// 0101 0000 方式1(8位异步/可变波特率)|无法送冲突软件清零|允许接收|//EUART0 波特率发生寄存器SBRTH = (unsigned char)(SBRTHINIT>>8); // 取高8位 串口0和串口1采用同一波特率SBRTL = (unsigned char)(SBRTHINIT);    // 取低8位
//		SBRTL = (unsigned char)(SBRTHINIT) &= 0x00ff;  SFINE = SFINE1INIT;	     //SFINE[3:0]波特率发生器微调数据寄存器SBRTH |= 0x80; //打开 EUART0 波特率发生器(SBRTEN=1)===========================UART1===============================
//		SELBANK1;						//切换到bank1,初始化UART1寄存器
//		//EUART1控制及状态寄存器 
//		SCON1 = 0x50;				//设置为方式1
//		
//		SBRTH1 = (unsigned char)(SBRTHINIT>>8);
//		SBRTL1 = (unsigned char)(SBRTHINIT);
//		
//		SFINE1 = SFINE1INIT;
//		SBRTH1 |= 0x80;SELBANK0;						//切回到bank0ES0 = 1;						//打开UART0中断
//		ES1 = 1;						//打开UART1中断
}
/****************************************************
* 函数名称: CheckSum
* 校验和:所有字节的相加和取低字节
*****************************************************/
unsigned char CheckSum(unsigned char *ptr,unsigned char len)
{unsigned char i;unsigned char Value = 0;for(i=0;i<len;i++)  //len{Value = Value + ptr[i];}return(Value);
}// UART0数据解析
void UART0_Decode(void)
{unsigned char i;volatile unsigned char *Source;unsigned char RecCheckValue;Source = &RecBuf[0];if(gbUARTRecOK0){gbUARTRecOK0 = 0;// 清标志if((*Source == 0xaa) && (*(Source+6) == 0x00))//帧头 帧尾判定 "aa 15 02 01 00 00 00 c2"、"aa 15 02 01 00 11 00 d3 "{//头尾校验正确RecCheckValue = CheckSum(RecBuf,7);			//接收缓冲区7个字节的校验 if(RecCheckValue == (*(Source+7)))//校验和验证 c2  d3{//校验和验证正确for(i = 0; i < 8; i++){SendBuf[i] = RecBuf[i];
//							SendBuf[i] = *(Source + i);}}
//					else{
//						//error_count ++;// 校验错误计数
//					}}
//				else{
//					//error_count ++;	// 校验错误计数
//				}}}void UART0_SendByte(unsigned char byte) {SBUF = byte;       // 将数据写入SBUF寄存器,开始发送while (TI == 0);   // 等待发送完成TI = 0;            // 清除发送完成标志
}void UART0_SendPacket(unsigned char* dat, unsigned char length) {unsigned char i;for (i = 0; i < length; i++) {UART0_SendByte(dat[i]);}}// UART0 接收相关变量
#define UARTRECLENGMAX0	 8				//
volatile unsigned char RecBuf[8]; // 用于存储接收到的数据
volatile unsigned char UART0RecBytecount = 0;        // 数据索引
volatile unsigned char UART0_Receive_OverTimer;
unsigned char RecCount;
bit gbUARTRecOK0;// UART0 发送相关变量
volatile unsigned char SendBuf[8];void UART0_ISR(void) interrupt 4
{_push_(INSCON);INSCON &= 0xBF;if (RI) { // 接收中断RI = 0;                 // 清除接收中断标志if(!gbUARTRecOK0){RecBuf[UART0RecBytecount++] = SBUF; // 读取接收到的数据UART0_Receive_OverTimer = UARTOVERTIME;if (UART0RecBytecount >= UARTRECLENGMAX0) {UART0RecBytecount = 0;          // 如果接收到8个字节,重置索引gbUARTRecOK0 = 1;}}}_pop_(INSCON);
}

这篇关于【中颖】SH79F9202 串口通信的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1045035

相关文章

RabbitMQ工作模式中的RPC通信模式详解

《RabbitMQ工作模式中的RPC通信模式详解》在RabbitMQ中,RPC模式通过消息队列实现远程调用功能,这篇文章给大家介绍RabbitMQ工作模式之RPC通信模式,感兴趣的朋友一起看看吧... 目录RPC通信模式概述工作流程代码案例引入依赖常量类编写客户端代码编写服务端代码RPC通信模式概述在R

在Spring Boot中实现HTTPS加密通信及常见问题排查

《在SpringBoot中实现HTTPS加密通信及常见问题排查》HTTPS是HTTP的安全版本,通过SSL/TLS协议为通讯提供加密、身份验证和数据完整性保护,下面通过本文给大家介绍在SpringB... 目录一、HTTPS核心原理1.加密流程概述2.加密技术组合二、证书体系详解1、证书类型对比2. 证书获

Python模拟串口通信的示例详解

《Python模拟串口通信的示例详解》pySerial是Python中用于操作串口的第三方模块,它支持Windows、Linux、OSX、BSD等多个平台,下面我们就来看看Python如何使用pySe... 目录1.win 下载虚www.chinasem.cn拟串口2、确定串口号3、配置串口4、串口通信示例5

基于C#实现MQTT通信实战

《基于C#实现MQTT通信实战》MQTT消息队列遥测传输,在物联网领域应用的很广泛,它是基于Publish/Subscribe模式,具有简单易用,支持QoS,传输效率高的特点,下面我们就来看看C#实现... 目录1、连接主机2、订阅消息3、发布消息MQTT(Message Queueing Telemetr

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

如何使用C#串口通讯实现数据的发送和接收

《如何使用C#串口通讯实现数据的发送和接收》本文详细介绍了如何使用C#实现基于串口通讯的数据发送和接收,通过SerialPort类,我们可以轻松实现串口通讯,并结合事件机制实现数据的传递和处理,感兴趣... 目录1. 概述2. 关键技术点2.1 SerialPort类2.2 异步接收数据2.3 数据解析2.

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

vue2 组件通信

props + emits props:用于接收父组件传递给子组件的数据。可以定义期望从父组件接收的数据结构和类型。‘子组件不可更改该数据’emits:用于定义组件可以向父组件发出的事件。这允许父组件监听子组件的事件并作出响应。(比如数据更新) props检查属性 属性名类型描述默认值typeFunction指定 prop 应该是什么类型,如 String, Number, Boolean,

linux中使用rust语言在不同进程之间通信

第一种:使用mmap映射相同文件 fn main() {let pid = std::process::id();println!(